Skip to main content

Generate API clients by parsing Swagger definitions

Project description

Swagger codegen for Python

Continuous Integration

Installation

pip install swagger-codegen

Swagger version

Currently, only OpenApi 3.x (aka Swagger 3) is supported.

Usage example

# Generate Petstore Api client using 'petstore' package name.
swagger_codegen generate https://petstore3.swagger.io/api/v3/openapi.json petstore

python

Python 3.8.1 (default, Jan 23 2020, 13:58:52) 
[Clang 11.0.0 (clang-1100.0.33.16)] on darwin
Type "help", "copyright", "credits" or "license" for more information.

>>> from petstore import new_client, Configuration
>>> from swagger_codegen.api.adapter.requests import RequestsAdapter
>>> from petstore.apis.user.createUser import User
>>> client = new_client(RequestsAdapter(), Configuration(host="http://petstore3.swagger.io"))
>>> pets = client.pet.findPetsByStatus()
>>> print(pets)
[Pet(category=Category(id=1, name='Dogs'), id=69, name='aHldog', photoUrls=['string'], status='available',...]

You can see example source code for PetStore Api in example directory of a project.

You can test example client with following command:

# Run from project directory.
python -m example.petstore_example 

Code generators (also known as renderers)

There are two code generator strategies in project:

  1. Render client as usual python package via PackageRenderer
  2. Render client as installable python package via InstallablePackageRenderer

You can choose what renderer to use by specifying renderer key in .swagger-codegen.toml file. Please see .swagger-codegen.toml.example for allowed values.

Known issues

  • Content of generated files differs run-to-run because each time functions or data transfer objects ordered differently. Functionally clients stay the same, but each time the code is generated there are a large diff generated by git.
  • Not fully Openapi compliant: the project was built to fulfill my personal needs: a support for FastAPI-generated schemas, and I needed this feature quickly, that is why there are too many large dependencies (schemathesis) and incompatibilities. Anyway, I'm looking forward to fixing this issues by time.
  • There are may be delays in reaction to issues due to small amount of free time (however PR's with tests are merged asap).

Work in progress

Though library gives nice results for generated API, it is still in development. Some tests are missing. API is a subject to change until stable release.

Anyway backward compatibility will be kept as much as possible.

The code is not optimized yet and mostly dirty because the project was born as a holiday prototype.

Also example directory may be out of sync with actual generated code.

Contributors

You can see all people who helped this project at the contributors page

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

swagger-codegen-0.1.31.tar.gz (21.5 kB view details)

Uploaded Source

Built Distribution

swagger_codegen-0.1.31-py3-none-any.whl (33.4 kB view details)

Uploaded Python 3

File details

Details for the file swagger-codegen-0.1.31.tar.gz.

File metadata

  • Download URL: swagger-codegen-0.1.31.tar.gz
  • Upload date:
  • Size: 21.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.11 CPython/3.9.6 Darwin/21.1.0

File hashes

Hashes for swagger-codegen-0.1.31.tar.gz
Algorithm Hash digest
SHA256 5a6f53151640a1178f4d291e17718a104a96f16337af25e2988072fc2106b3a1
MD5 af6e0b4d510143154800eb45cd5dfbf1
BLAKE2b-256 77953019581fec32e932e701d1f965fb4ead814dbfffc7c086037c2b1e8f6e7d

See more details on using hashes here.

File details

Details for the file swagger_codegen-0.1.31-py3-none-any.whl.

File metadata

File hashes

Hashes for swagger_codegen-0.1.31-py3-none-any.whl
Algorithm Hash digest
SHA256 b97b52ebb50f4408858a3bf58ad65d7241e00aa7803f4f350c8f9f1809b67ad3
MD5 9e6563389f4ba0abfbfcb5e98bc9782f
BLAKE2b-256 dec820a6dddd8b99b45f8bd5e016afa9c18551c53f78d749e085834670bb227c

See more details on using hashes here.

Supported by

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