Generate modern Python clients from OpenAPI
Project description
openapi-python-client
Generate modern Python clients from OpenAPI 3.x documents.
This generator does not support OpenAPI 2.x FKA Swagger. If you need to use an older document, try upgrading it to version 3 first with one of many available converters.
This project is still in development and does not support all OpenAPI features
Why This?
The Python clients generated by openapi-generator support Python 2 and therefore come with a lot of baggage. This tool aims to generate clients which:
- Use all the latest and greatest Python features like type annotations and dataclasses
- Don't carry around a bunch of compatibility code for older version of Python (e.g. the
six
package) - Have better documentation and more obvious usage instructions
Additionally, because this generator is written in Python, it should be more accessible to contribution by the people using it (Python developers).
Installation
I recommend you install with pipx so you don't conflict with any other packages
you might have: pipx install openapi-python-client
.
Better yet, use pipx run openapi-python-client <normal params / options>
to always use the latest version of the generator.
You can install with normal pip if you want to though: pip install openapi-python-client
Then, if you want tab completion: openapi-python-client --install-completion
Usage
Create a new client
openapi-python-client generate --url https://my.api.com/openapi.json
This will generate a new client library named based on the title in your OpenAPI spec. For example, if the title of your API is "My API", the expected output will be "my-api-client". If a folder already exists by that name, you'll get an error.
Update an existing client
openapi-python-client update --url https://my.api.com/openapi.json
For more usage details run
openapi-python-client --help
or read usage
What You Get
- A
pyproject.toml
file with some basic metadata intended to be used with Poetry. - A
README.md
you'll most definitely need to update with your project's details - A Python module named just like the auto-generated project name (e.g. "my_api_client") which contains:
- A
client
module which will have both aClient
class and anAuthenticatedClient
class. You'll need these for calling the functions in theapi
module. - An
api
module which will contain one module for each tag in your OpenAPI spec, as well as adefault
module for endpoints without a tag. Each of these modules in turn contains one function for calling each endpoint. - A
models
module which has all the classes defined by the various schemas in your OpenAPI spec
- A
For a full example you can look at the end_to_end_tests
directory which has an openapi.json
file.
"golden-record" in that same directory is the generated client from that OpenAPI document.
OpenAPI features supported
- All HTTP Methods
- JSON and form bodies, path and query parameters
- File uploads with multipart/form-data bodies
- float, string, int, date, datetime, string enums, and custom schemas or lists containing any of those
- html/text or application/json responses containing any of the previous types
- Bearer token security
Configuration
You can pass a YAML (or JSON) file to openapi-python-client with the --config
option in order to change some behavior.
The following parameters are supported:
class_overrides
Used to change the name of generated model classes. This param should be a mapping of existing class name (usually a key in the "schemas" section of your OpenAPI document) to class_name and module_name. As an example, if the name of the a model in OpenAPI (and therefore the generated class name) was something like "_PrivateInternalLongName" and you want the generated client's model to be called "ShortName" in a module called "short_name" you could do this:
Example:
class_overrides:
_PrivateInternalLongName:
class_name: ShortName
module_name: short_name
The easiest way to find what needs to be overridden is probably to generate your client and go look at everything in the models folder.
project_name_override and package_name_override
Used to change the name of generated client library project/package. If the project name is changed but an override for the package name
isn't provided, the package name will be converted from the project name using the standard convention (replacing -
's with _
's).
Example:
project_name_override: my-special-project-name
package_name_override: my_extra_special_package_name
field_prefix
When generating properties, the name
attribute of the OpenAPI schema will be used. When the name
is not a valid
Python identifier (e.g. begins with a number) this string will be prepended. Defaults to "field_".
Example:
field_prefix: attr_
package_version_override
Specify the package version of the generated client. If unset, the client will use the version of the OpenAPI spec.
Example:
package_version_override: 1.2.3
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for openapi-python-client-0.6.2.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 071da2ee490cecb8aef18eedcefd0bca0e29a4983231233ea211f0f6eaf5ac38 |
|
MD5 | c8992a3db4b7b2b7678c937bb6e837e6 |
|
BLAKE2b-256 | a275dc54c4c76d7720903fdd3834d47c68eddd6bc537ffd3dc51e806d1c857f6 |
Hashes for openapi_python_client-0.6.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2b863dedc493356c66e529590d1b41e7f07d9107a507d36913f36d8a1e65fe11 |
|
MD5 | 046afb0840d5a5220b885c6a37b11823 |
|
BLAKE2b-256 | 17c0c1f25eefeede8ff95d18862631d05127335b793afc726305fc69c7865a4e |