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.8 | |
generator default templating engine | handlebars | |
helpMsg | 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 + json schema validation - json schema keyword validation may be selectively disabled with SchemaConfiguration - enums of type string/integer/boolean typed using typing.Literal - mypy static type checking run on generated sample - 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) - 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 |
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 | |
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 |
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 |
Extension name | Description | Applicable for | Default value |
---|---|---|---|
x-enum-varnames | A list of strings that defines the enum variable names, must be adjacent to enum | SCHEMA | [] |
x-enum-descriptions | A list of strings that defines the enum descriptions, must be adjacent to enum | SCHEMA | [] |
Type/Alias | Instantiated By |
---|---|
array | tuple |
boolean | bool |
integer | int |
null | None |
number | typing.Union[float, int] |
object | immutabledict.immutabledict |
string | str |
- None
- bool
- bytes
- date
- datetime
- dict
- file
- float
- int
- list
- object
- str
- @property
- and
- as
- assert
- async
- await
- bool
- break
- class
- continue
- cookie_params
- datetime
- decimal
- def
- del
- dict
- elif
- else
- except
- exec
- false
- finally
- float
- for
- from
- functools
- global
- header_params
- if
- immutabledict
- import
- in
- int
- io
- is
- lambda
- list
- none
- nonlocal
- not
- or
- pass
- path_params
- property
- query_params
- raise
- re
- resource_path
- return
- schemas
- self
- str
- true
- try
- tuple
- typing
- typing_extensions
- uuid
- 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 |
Security | ✓ | OAS2,OAS3 |
Servers | ✓ | 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 |
Const | ✓ | OAS3 |
Contains | ✓ | OAS3 |
Default | ✓ | OAS2,OAS3 |
DependentRequired | ✓ | OAS3 |
DependentSchemas | ✓ | OAS3 |
Discriminator | ✓ | OAS2,OAS3 |
Else | ✓ | OAS3 |
Enum | ✓ | OAS2,OAS3 |
ExclusiveMinimum | ✓ | OAS2,OAS3 |
ExclusiveMaximum | ✓ | OAS2,OAS3 |
Format | ✓ | OAS2,OAS3 |
If | ✓ | OAS3 |
Items | ✓ | OAS2,OAS3 |
MaxContains | ✓ | OAS3 |
MaxItems | ✓ | OAS2,OAS3 |
MaxLength | ✓ | OAS2,OAS3 |
MaxProperties | ✓ | OAS2,OAS3 |
Maximum | ✓ | OAS2,OAS3 |
MinContains | ✓ | 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 |
PatternProperties | ✓ | OAS3 |
PrefixItems | ✓ | OAS3 |
Properties | ✓ | OAS2,OAS3 |
PropertyNames | ✓ | OAS3 |
Ref | ✓ | OAS2,OAS3 |
Required | ✓ | OAS2,OAS3 |
Then | ✓ | OAS3 |
Type | ✓ | OAS2,OAS3 |
UnevaluatedItems | ✓ | OAS3 |
UnevaluatedProperties | ✓ | 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 |