Skip to main content

Generate modern Python clients from OpenAPI

Project description

triaxtec Code style: black codecov

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

pip install openapi-python-client

Usage

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.

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

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

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.1.0.dev0.tar.gz (13.6 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.1.0.dev0-py3-none-any.whl (17.9 kB view details)

Uploaded Python 3

File details

Details for the file openapi-python-client-0.1.0.dev0.tar.gz.

File metadata

  • Download URL: openapi-python-client-0.1.0.dev0.tar.gz
  • Upload date:
  • Size: 13.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.3 CPython/3.8.1 Darwin/19.3.0

File hashes

Hashes for openapi-python-client-0.1.0.dev0.tar.gz
Algorithm Hash digest
SHA256 1463c568472205b5be202888b04f38b06182078afa834ef7a3f92a2b885a3932
MD5 b5a82dc1fd4b020261077442c471b6a0
BLAKE2b-256 71ccbcbef29cb91ff28efa0f846b8b69d3154d6ea6e43e8fee3e93e1d9d89432

See more details on using hashes here.

File details

Details for the file openapi_python_client-0.1.0.dev0-py3-none-any.whl.

File metadata

File hashes

Hashes for openapi_python_client-0.1.0.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 e0f845b52dfa57efbddac18d2fe456ba9064cfffafd0191c2059addb6b40d02c
MD5 20b938a8895ff7770c14a2fa4e79d8bd
BLAKE2b-256 c80a7b0fab29c7aa33fdc7db3c3eb55f3f8870d549f1c12a6fea03322936b1a7

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