Skip to main content

Generate modern Python clients from OpenAPI

Project description

triaxtec Code style: black codecov PyPI version shields.io

openapi-python-client

Generate modern Python clients from OpenAPI

This project is still in early 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:

  1. Use all the latest and greatest Python features like type annotations and dataclasses
  2. Don't carry around a bunch of compatibility code for older version of Python (e.g. the six package)
  3. 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

  1. A pyproject.toml file with some basic metadata intended to be used with Poetry.
  2. A README.md you'll most definitely need to update with your project's details
  3. A Python module named just like the auto-generated project name (e.g. "my_api_client") which contains:
    1. A client module which will have both a Client class and an AuthenticatedClient class. You'll need these for calling the functions in the api module.
    2. An api module which will contain one module for each tag in your OpenAPI spec, as well as a default module for endpoints without a tag. Each of these modules in turn contains one function for calling each endpoint.
    3. A models module which has all the classes defined by the various schemas in your OpenAPI spec

For a full example you can look at tests/test_end_to_end which has a declared FastAPI server and the resulting openapi.json file in the "fastapi" directory. "golden-master" is the generated client from that OpenAPI document.

OpenAPI features supported

  1. All HTTP Methods
  2. JSON and form bodies, path and query parameters
  3. float, string, int, datetimes, string enums, and custom schemas or lists containing any of those
  4. html/text or application/json responses containing any of the previous types
  5. Bearer token security

Configuration

You can pass a YAML (or JSON) file to openapi-python-client in order to change some behavior. The following parameters are supported:

class_overrides

Used to change the name of generated model classes, especially useful if you have a name like ABCModel which, when converted to snake case for module naming will be a_b_c_model. 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.

Example:

class_overrides:
    ABCModel:
      class_name: ABCModel
      module_name: abc_model

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.

Contributors

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

openapi-python-client-0.2.0.tar.gz (17.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

openapi_python_client-0.2.0-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file openapi-python-client-0.2.0.tar.gz.

File metadata

  • Download URL: openapi-python-client-0.2.0.tar.gz
  • Upload date:
  • Size: 17.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.5 CPython/3.8.2 Linux/5.0.0-1032-azure

File hashes

Hashes for openapi-python-client-0.2.0.tar.gz
Algorithm Hash digest
SHA256 f3617e5650cfc780e9a60b6223a3ef6306442af3a95cfbb57ab0be959e2b9cd1
MD5 fbce51b74810f6d45fb722c45b912aa4
BLAKE2b-256 966469708d4744a8737133daf2ecd1bba99084ca149f66232bc07c39cd0ae6ca

See more details on using hashes here.

File details

Details for the file openapi_python_client-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for openapi_python_client-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d1b63fd8f4fccffbb11e5d95aa587fc56e9d957ece7cfcb45d07642afc3501d9
MD5 bb7273edf2ae72eb4a50449d42ff6b0d
BLAKE2b-256 5645504639b4a72be7d8fcb4938e6db4bdbabba91183f915b20a945b5be4cb34

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page