Skip to main content

Client and Validator of OpenAPI 3 Specifications. Forked from dorthu/openapi3 ad modifications made on top of it

Project description

This project is forked from https://github.com/Dorthu/openapi3 Additional capabilities added on top of it

A Python OpenAPI 3 Specification client and validator for Python 3.

GitHub Actions Build Badge https://badge.fury.io/py/openapi3.svg

Validation Mode

This module can be run against a spec file to validate it like so:

python3 -m openapi3 /path/to/spec

Usage as a Client

This library also functions as an interactive client for arbitrary OpenAPI 3 specs. For example, using Linode’s OpenAPI 3 Specification for reference:

from openapi3 import OpenAPI
import yaml

# load the spec file and read the yaml
with open('openapi.yaml') as f:
    spec = yaml.safe_load(f.read())

# parse the spec into python - this will raise if the spec is invalid
api = OpenAPI(spec)

# call operations and receive result models
regions = api.call_getRegions()

# authenticate using a securityScheme defined in the spec's components.securitySchemes
api.authenticate('personalAccessToken', my_token)

# call an operation that requires authentication
linodes  = api.call_getLinodeInstances()

# call an opertaion with parameters
linode = api.call_getLinodeInstance(parameters={"linodeId": 123})

# the models returns are all of the same (generated) type
print(type(linode))                      # openapi.schemas.Linode
type(linode) == type(linodes.data[0])    # True

# call an operation with a request body
new_linode = api.call_createLinodeInstance(data={"region":"us-east","type":"g6-standard-2"})

# the returned models is still of the correct type
type(new_linode) == type(linode)     # True

HTTP basic authentication and HTTP digest authentication works like this:

# authenticate using a securityScheme defined in the spec's components.securitySchemes
# Tuple with (username, password) as second argument
api.authenticate('basicAuth', ('username', 'password'))

Running Tests

This project includes a test suite, run via pytest. To run the test suite, ensure that you’ve installed the dependencies and then run pytest in the root of this project.

Roadmap

The following features are planned for the future:

  • Request body models, creation, and validation.

  • Parameters interface with validation and explicit typing.

  • Support for more authentication types.

  • Support for non-json request/response content.

  • Full support for all objects defined in the specification.

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

openapi3v1-0.0.2.tar.gz (21.8 kB view details)

Uploaded Source

Built Distribution

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

openapi3v1-0.0.2-py3-none-any.whl (26.6 kB view details)

Uploaded Python 3

File details

Details for the file openapi3v1-0.0.2.tar.gz.

File metadata

  • Download URL: openapi3v1-0.0.2.tar.gz
  • Upload date:
  • Size: 21.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.7.8rc1

File hashes

Hashes for openapi3v1-0.0.2.tar.gz
Algorithm Hash digest
SHA256 577bf91f487a7e9d3ff340be2c06b493509abd8745a85cd48c97d853675d1cdb
MD5 740034fb718afb4f2eecd2052f0d84a0
BLAKE2b-256 7636aeff4c9736c6dbe7743d77ef1d4cc51b6b732b4c19754e38d1defbc27ec1

See more details on using hashes here.

File details

Details for the file openapi3v1-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: openapi3v1-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 26.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.7.8rc1

File hashes

Hashes for openapi3v1-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 46bc146205729a0d79b3be28d62fa3d915a9500f8bddec3c7a22a96b7705b8b4
MD5 0b66fc14a7b4434707fbe8071ee16457
BLAKE2b-256 d83acb4caef8cb1c848d0f31f1b8208f8bf4e85e5ec9beeb0ca4a80541fa324b

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