forked from zircote/swagger-php
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Xml.php
75 lines (65 loc) · 2.05 KB
/
Xml.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<?php declare(strict_types=1);
/**
* @license Apache 2.0
*/
namespace OpenApi\Annotations;
use OpenApi\Generator;
/**
* @Annotation
*
* A "XML Object": https://github.com/OAI/OpenAPI-Specification/blob/OpenAPI.next/versions/3.0.md#xmlObject
*/
class Xml extends AbstractAnnotation
{
/**
* Replaces the name of the element/attribute used for the described schema property. When defined within the Items Object (items), it will affect the name of the individual XML elements within the list. When defined alongside type being array (outside the items), it will affect the wrapping element and only if wrapped is true. If wrapped is false, it will be ignored.
*
* @var string
*/
public $name = Generator::UNDEFINED;
/**
* The URL of the namespace definition. Value SHOULD be in the form of a URL.
*
* @var string
*/
public $namespace = Generator::UNDEFINED;
/**
* The prefix to be used for the name.
*
* @var string
*/
public $prefix = Generator::UNDEFINED;
/**
* Declares whether the property definition translates to an attribute instead of an element. Default value is false.
*
* @var bool
*/
public $attribute = Generator::UNDEFINED;
/**
* MAY be used only for an array definition. Signifies whether the array is wrapped (for example, <books><book/><book/></books>) or unwrapped (<book/><book/>). Default value is false. The definition takes effect only when defined alongside type being array (outside the items).
*
* @var bool
*/
public $wrapped = Generator::UNDEFINED;
/**
* {@inheritdoc}
*/
public static $_types = [
'name' => 'string',
'namespace' => 'string',
'prefix' => 'string',
'attribute' => 'boolean',
'wrapped' => 'boolean',
];
/**
* {@inheritdoc}
*/
public static $_parents = [
AdditionalProperties::class,
Schema::class,
Property::class,
Schema::class,
Items::class,
XmlContent::class,
];
}