title |
---|
Documentation for the python Generator |
Property | Value | Notes |
---|---|---|
generator name | python | pass this to the generate command after -g |
generator stability | STABLE | |
generator type | CLIENT | |
generator language | Python | |
generator language version | >=3.7 | |
generator default templating engine | handlebars | |
helpTxt | Generates a Python client library Features in this generator: - type hints on endpoints and model creation - model parameter names use the spec defined keys and cases - robust composition (oneOf/anyOf/allOf/not) where payload data is stored in one instance only - endpoint parameter names use the spec defined keys and cases - inline schemas are supported at any location including composition - multiple content types supported in request body and response bodies - run time type checking - Sending/receiving decimals as strings supported with type:string format: number -> DecimalSchema - Sending/receiving uuids as strings supported with type:string format: uuid -> UUIDSchema - quicker load time for python modules (a single endpoint can be imported and used without loading others) - all instances of schemas dynamically inherit from all matching schemas so one can use isinstance to check if validation passed - composed schemas with type constraints supported (type:object + oneOf/anyOf/allOf) - schemas are not coerced/cast. For example string + date are both stored as string, and there is a date accessor - Exceptions: int/float is stored as Decimal, When receiving data from headers it will start as str and may need to be cast for example to int |
These options may be applied as additional-properties (cli) or configOptions (plugins). Refer to configuration docs for more details.
Option | Description | Values | Default |
---|---|---|---|
generateSourceCodeOnly | Specifies that only a library source code is to be generated. | false | |
hideGenerationTimestamp | Hides the generation timestamp when files are generated. | true | |
library | library template (sub-template) to use: urllib3 | urllib3 | |
nonCompliantUseDiscriminatorIfCompositionFails | When true, If the payload fails to validate against composed schemas (allOf/anyOf/oneOf/not) and a discriminator is present, then ignore the composition validation errors and attempt to use the discriminator to validate the payload. Note: setting this to true makes the generated client not comply with json schema because it ignores composition validation errors. Please consider making your schemas more restrictive rather than setting this to true. You can do that by:
|
|
false |
packageName | python package name (convention: snake_case). | openapi_client | |
packageUrl | python package URL. | null | |
packageVersion | python package version. | 1.0.0 | |
projectName | python project name in setup.py (e.g. petstore-api). | null | |
recursionLimit | Set the recursion limit. If not set, use the system default value. | null | |
useNose | use the nose test framework | false |
Type/Alias | Instantiated By |
---|---|
array | tuple |
boolean | schemas.BoolClass |
integer | decimal.Decimal |
null | schemas.NoneClass |
number | decimal.Decimal |
object | frozendict.frozendict |
string | str |
- bool
- bytes
- date
- datetime
- dict
- file
- file_type
- float
- int
- list
- none_type
- object
- str
- and
- as
- assert
- async
- await
- bool
- break
- class
- continue
- def
- del
- dict
- elif
- else
- except
- exec
- false
- finally
- float
- for
- from
- frozendict
- global
- if
- import
- in
- int
- is
- lambda
- list
- none
- nonlocal
- not
- or
- pass
- property
- raise
- return
- self
- str
- true
- try
- tuple
- while
- with
- yield
Name | Supported | Defined By |
---|---|---|
BasePath | ✗ | ToolingExtension |
Authorizations | ✗ | ToolingExtension |
UserAgent | ✗ | ToolingExtension |
MockServer | ✗ | ToolingExtension |
Name | Supported | Defined By |
---|---|---|
schemas | ✓ | OAS3 |
responses | ✓ | OAS3 |
parameters | ✓ | OAS3 |
examples | ✗ | OAS3 |
requestBodies | ✓ | OAS3 |
headers | ✓ | OAS3 |
securitySchemes | ✓ | OAS3 |
links | ✗ | OAS3 |
callbacks | ✗ | OAS3 |
pathItems | ✗ | OAS3 |
Name | Supported | Defined By |
---|---|---|
Custom | ✗ | OAS2,OAS3 |
Int32 | ✓ | OAS2,OAS3 |
Int64 | ✓ | OAS2,OAS3 |
Integer | ✓ | OAS2,OAS3 |
Float | ✓ | OAS2,OAS3 |
Double | ✓ | OAS2,OAS3 |
Number | ✓ | OAS2,OAS3 |
String | ✓ | OAS2,OAS3 |
Byte | ✗ | OAS2,OAS3 |
Binary | ✓ | OAS2,OAS3 |
Boolean | ✓ | OAS2,OAS3 |
Date | ✓ | OAS2,OAS3 |
DateTime | ✓ | OAS2,OAS3 |
Password | ✗ | OAS2,OAS3 |
File | ✓ | OAS2 |
Uuid | ✓ | OAS2,OAS3 |
Array | ✓ | OAS2,OAS3 |
Null | ✓ | OAS3 |
AnyType | ✓ | OAS2,OAS3 |
Object | ✓ | OAS2,OAS3 |
Enum | ✓ | OAS2,OAS3 |
Name | Supported | Defined By |
---|---|---|
Readme | ✓ | ToolingExtension |
Servers | ✓ | OAS3 |
Security | ✓ | OAS2,OAS3 |
ComponentSchemas | ✓ | OAS3 |
ComponentResponses | ✓ | OAS3 |
ComponentParameters | ✓ | OAS3 |
ComponentRequestBodies | ✓ | OAS3 |
ComponentHeaders | ✓ | OAS3 |
ComponentSecuritySchemes | ✓ | OAS3 |
ComponentLinks | ✗ | OAS3 |
ComponentCallbacks | ✗ | OAS3 |
ComponentPathItems | ✗ | OAS3 |
Api | ✓ | ToolingExtension |
Name | Supported | Defined By |
---|---|---|
Info | ✓ | OAS2,OAS3 |
Servers | ✓ | OAS3 |
Paths | ✓ | OAS2,OAS3 |
Webhooks | ✗ | OAS3 |
Components | ✓ | OAS3 |
Security | ✓ | OAS2,OAS3 |
Tags | ✓ | OAS2,OAS3 |
ExternalDocs | ✗ | OAS2,OAS3 |
Name | Supported | Defined By |
---|---|---|
Responses_HttpStatusCode | ✓ | OAS3 |
Responses_RangedResponseCodes | ✓ | OAS3 |
Responses_Default | ✓ | OAS3 |
Responses_RedirectionResponse | ✓ | OAS3 |
Name | Supported | Defined By |
---|---|---|
Name | ✓ | OAS2,OAS3 |
Required | ✓ | OAS2,OAS3 |
In_Path | ✓ | OAS2,OAS3 |
In_Query | ✓ | OAS2,OAS3 |
In_Header | ✓ | OAS2,OAS3 |
In_Cookie | ✗ | OAS3 |
Style_Matrix | ✓ | OAS3 |
Style_Label | ✓ | OAS3 |
Style_Form | ✓ | OAS3 |
Style_Simple | ✓ | OAS3 |
Style_SpaceDelimited | ✓ | OAS3 |
Style_PipeDelimited | ✓ | OAS3 |
Style_DeepObject | ✗ | OAS3 |
Explode | ✓ | OAS3 |
Schema | ✓ | OAS3 |
Content | ✓ | OAS3 |
Name | Supported | Defined By |
---|---|---|
AdditionalProperties | ✓ | OAS2,OAS3 |
AllOf | ✓ | OAS2,OAS3 |
AnyOf | ✓ | OAS3 |
Default | ✓ | OAS2,OAS3 |
Discriminator | ✓ | OAS2,OAS3 |
Enum | ✓ | OAS2,OAS3 |
ExclusiveMinimum | ✓ | OAS2,OAS3 |
ExclusiveMaximum | ✓ | OAS2,OAS3 |
Format | ✓ | OAS2,OAS3 |
Items | ✓ | OAS2,OAS3 |
MaxItems | ✓ | OAS2,OAS3 |
MaxLength | ✓ | OAS2,OAS3 |
MaxProperties | ✓ | OAS2,OAS3 |
Maximum | ✓ | OAS2,OAS3 |
MinItems | ✓ | OAS2,OAS3 |
MinLength | ✓ | OAS2,OAS3 |
MinProperties | ✓ | OAS2,OAS3 |
Minimum | ✓ | OAS2,OAS3 |
MultipleOf | ✓ | OAS2,OAS3 |
Not | ✓ | OAS3 |
Nullable | ✓ | OAS3 |
OneOf | ✓ | OAS3 |
Pattern | ✓ | OAS2,OAS3 |
Properties | ✓ | OAS2,OAS3 |
Required | ✓ | OAS2,OAS3 |
Type | ✓ | OAS2,OAS3 |
UniqueItems | ✓ | OAS2,OAS3 |
Xml | ✗ | OAS2,OAS3 |
Name | Supported | Defined By |
---|---|---|
HTTP_Basic | ✓ | OAS2,OAS3 |
ApiKey | ✓ | OAS2,OAS3 |
OpenIDConnect | ✗ | OAS3 |
HTTP_Bearer | ✓ | OAS2,OAS3 |
OAuth2_Implicit | ✗ | OAS2,OAS3 |
OAuth2_Password | ✗ | OAS2,OAS3 |
OAuth2_ClientCredentials | ✗ | OAS2,OAS3 |
OAuth2_AuthorizationCode | ✗ | OAS2,OAS3 |
Name | Supported | Defined By |
---|---|---|
JSON | ✓ | OAS2,OAS3 |
XML | ✗ | OAS2,OAS3 |
PROTOBUF | ✗ | ToolingExtension |
Custom | ✓ | OAS2,OAS3 |