Skip to main content

No project description provided

Project description

RestCodeGen

RestCodeGen is a tool for generating Python clients based on OpenAPI 3 specifications.
This tool enables testers to quickly create client libraries for interacting with REST APIs implemented with OpenAPI.

Installation

To install, you need the required dependencies. Make sure you have Python 3.10 or higher installed.

pip install restcodegen

Usage

Once installed, you can use the restcodegen command to generate a client.

Command Syntax

restcodegen generate -u "http://example.com/openapi.json" -s "my-service" -a false

Command Parameters

- --url, -u: URL of the OpenAPI specification (required).
- --service-name, -s: Name of the service (required).
- --async-mode, -a: Flag to enable asynchronous client generation (default is false).

Example

To generate a client for an API available at the URL https://petstore3.swagger.io/api/v3/openapi.json, you can use the following command:

restcodegen generate -u "https://petstore3.swagger.io/api/v3/openapi.json" -s "petstore" -a false

Result

After a successful command execution, a client library will be created with a name corresponding to the provided service name. The generated files will contain classes and methods for interacting with the API described in the provided specification.

Structure:

└── clients                      
     └── http     
        ├── schemas               # OpenAPI 3.0.0 schemas for all generated apis                   
        └── service_name          # Service name     
            ├── apis              # APIs                    
            └── models            # Pydantic models   

Generated client usage

from restcodegen.rest_client.client_sync import ApiClient
from restcodegen.rest_client.configuration import Configuration
from clients.http.petstore import PetApi


if __name__ == '__main__':
    configuration = Configuration(host="https://petstore3.swagger.io/api/v3")
    api_client = ApiClient(configuration)
    pet_api = PetApi(api_client)
    response = pet_api.get_pet_pet_id(pet_id=1)
    print(response)

License

This project is licensed under the MIT License. See the LICENSE file for more information.


I hope that RestCodeGen will simplify your work with REST APIs. If you have any questions or suggestions, please create an issue in the repository.

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

restcodegen-0.1.1.tar.gz (11.7 kB view details)

Uploaded Source

Built Distribution

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

restcodegen-0.1.1-py3-none-any.whl (16.3 kB view details)

Uploaded Python 3

File details

Details for the file restcodegen-0.1.1.tar.gz.

File metadata

  • Download URL: restcodegen-0.1.1.tar.gz
  • Upload date:
  • Size: 11.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for restcodegen-0.1.1.tar.gz
Algorithm Hash digest
SHA256 aa97907da98bda3d2a71bc85c2bf5a08f4c01417810960a1a932272e4f38bf4f
MD5 4a39d4a37a0648f9047d3f4874267e11
BLAKE2b-256 e1e6a5b7c815ddc2f060304fd07acfc2f777c19fd391a848df1ac0ffde68b2f3

See more details on using hashes here.

File details

Details for the file restcodegen-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: restcodegen-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 16.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for restcodegen-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4f954c51d4c2351617085594bffea96a6515d297babf72c8f44d83a18fd07f62
MD5 158567c7ac6ba3dec6aad0e9e91a258e
BLAKE2b-256 03aaf9c139dc6bcdba6dabb2fb6eff849d3e89aaa62ffc3448e1fdf871b3f30b

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