Generate API clients by parsing Swagger definitions
Project description
Swagger codegen for Python
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://petstore.swagger.io:8080"))
>>> print(client.user.createUser(User(id=1, username="Swagger-Codegen")))
id=1 username='Swagger-Codegen' firstName=None lastName=None email=None password=None phone=None userStatus=0
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:
- Render client as usual python package via
PackageRenderer
- 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 data transfer objects ordered differently. Functionally clients stay the same, but each time the code is generated there are 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 fix 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 most 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
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 swagger_codegen-0.1.29-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3084a9ad4b0641698615a1f3eff5f315fea18f09498d198f106681272eb516d8 |
|
MD5 | 1a6105efbbec8ad9acffb6b54c547916 |
|
BLAKE2b-256 | abccbe0be6639c5be65bbc44d5d529b8afa9f36ece56c6a4c7f7a288cddb2eb7 |