forked from openapi-generators/openapi-python-client
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathreference.py
More file actions
46 lines (33 loc) · 1.53 KB
/
reference.py
File metadata and controls
46 lines (33 loc) · 1.53 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
from typing import Annotated, Any, Literal, TypeVar
from pydantic import BaseModel, ConfigDict, Discriminator, Field, Tag
from pydantic_core import ArgsKwargs
class Reference(BaseModel):
"""
A simple object to allow referencing other components in the specification, internally and externally.
The Reference Object is defined by [JSON Reference](https://tools.ietf.org/html/draft-pbryan-zyp-json-ref-03)
and follows the same structure, behavior and rules.
For this specification, reference resolution is accomplished as defined by the JSON Reference specification
and not by the JSON Schema specification.
References:
- https://swagger.io/docs/specification/using-ref/
- https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#referenceObject
"""
ref: str = Field(alias="$ref")
model_config = ConfigDict(
extra="allow",
populate_by_name=True,
json_schema_extra={
"examples": [{"$ref": "#/components/schemas/Pet"}, {"$ref": "Pet.json"}, {"$ref": "definitions.json#/Pet"}]
},
)
T = TypeVar('T')
def _reference_discriminator(obj: Any) -> Literal['ref', 'other']:
if isinstance(obj, dict):
return 'ref' if '$ref' in obj else 'other'
if isinstance(obj, ArgsKwargs):
return 'ref' if 'ref' in obj.kwargs else 'other'
return 'ref' if isinstance(obj, Reference) else 'other'
ReferenceOr = Annotated[
Annotated[Reference, Tag('ref')] |
Annotated[T, Tag('other')],
Discriminator(_reference_discriminator)]