-
Notifications
You must be signed in to change notification settings - Fork 98
Expand file tree
/
Copy pathLink.php
More file actions
59 lines (53 loc) · 1.63 KB
/
Link.php
File metadata and controls
59 lines (53 loc) · 1.63 KB
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
<?php
/**
* @copyright Copyright (c) 2018 Carsten Brandt <mail@cebe.cc> and contributors
* @license https://github.com/cebe/php-openapi/blob/master/LICENSE
*/
namespace cebe\openapi\spec;
use cebe\openapi\SpecBaseObject;
/**
* The Link object represents a possible design-time link for a response.
*
* @link https://github.com/OAI/OpenAPI-Specification/blob/3.0.2/versions/3.0.2.md#linkObject
*
* @property string $operationRef
* @property string $operationId
* @property array $parameters
* @property mixed $requestBody
* @property string $description
* @property Server|null $server
*
*/
class Link extends SpecBaseObject
{
/**
* @return array array of attributes available in this object.
*/
protected function attributes(): array
{
return [
'operationRef' => Type::STRING,
'operationId' => Type::STRING,
'parameters' => [Type::STRING, Type::ANY], // TODO: how to specify {expression}?
'requestBody' => Type::ANY, // TODO: how to specify {expression}?
'description' => Type::STRING,
'server' => Server::class,
];
}
/**
* Perform validation on this object, check data against OpenAPI Specification rules.
*/
protected function performValidation()
{
if (!empty($this->operationId) && !empty($this->operationRef)) {
$this->addError('Link: operationId and operationRef are mutually exclusive.');
}
}
/**
* @param string $name parameter name
*/
public function removeParameter(string $name): void
{
$this->deleteProperty('parameters', $name);
}
}