coupon-admin/vendor/zircote/swagger-php/src/Annotations/Components.php

111 lines
2.3 KiB
PHP

<?php declare(strict_types=1);
/**
* @license Apache 2.0
*/
namespace OpenApi\Annotations;
use OpenApi\Generator;
/**
* @Annotation
* A Components Object: https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.0.md#components-object
*
* Holds a set of reusable objects for different aspects of the OA.
* All objects defined within the components object will have no effect on the API unless they are explicitly referenced from properties outside the components object.
*/
class Components extends AbstractAnnotation
{
/**
* Schema reference.
*
* @var string
*/
const SCHEMA_REF = '#/components/schemas/';
/**
* Reusable Schemas.
*
* @var Schema[]
*/
public $schemas = Generator::UNDEFINED;
/**
* Reusable Responses.
*
* @var Response[]
*/
public $responses = Generator::UNDEFINED;
/**
* Reusable Parameters.
*
* @var Parameter[]
*/
public $parameters = Generator::UNDEFINED;
/**
* Reusable Examples.
*
* @var Examples[]
*/
public $examples = Generator::UNDEFINED;
/**
* Reusable Request Bodys.
*
* @var RequestBody[]
*/
public $requestBodies = Generator::UNDEFINED;
/**
* Reusable Headers.
*
* @var Header[]
*/
public $headers = Generator::UNDEFINED;
/**
* Reusable Security Schemes.
*
* @var SecurityScheme[]
*/
public $securitySchemes = Generator::UNDEFINED;
/**
* Reusable Links.
*
* @var Link[]
*/
public $links = Generator::UNDEFINED;
/**
* Reusable Callbacks.
*
* @var callable[]
*/
public $callbacks = Generator::UNDEFINED;
/**
* @inheritdoc
*/
public static $_parents = [
OpenApi::class,
];
/**
* @inheritdoc
*/
public static $_nested = [
Schema::class => ['schemas', 'schema'],
Response::class => ['responses', 'response'],
Parameter::class => ['parameters', 'parameter'],
RequestBody::class => ['requestBodies', 'request'],
Examples::class => ['examples', 'example'],
Header::class => ['headers', 'header'],
SecurityScheme::class => ['securitySchemes', 'securityScheme'],
Link::class => ['links', 'link'],
];
}