Skip to content

putnopvut/swagger-py

Repository files navigation

About

Swagger.py is a Python library for using Swagger defined API's.

Swagger itself is best described on the Swagger home page:

Swagger is a specification and complete framework implementation for describing, producing, consuming, and visualizing RESTful web services.

The Swagger specification defines how API's may be described using Swagger.

Swagger.py also supports a WebSocket extension, allowing a WebSocket to be documented, and auto-generated WebSocket client code.

Usage

Install swagger.py using the setup.py script.

$ sudo ./setup.py install

API

Swagger.py will dynamically build an object model from a Swagger-enabled RESTful API.

Here is a simple example using the Asterisk REST Interface

#!/usr/bin/env python

import json
import requests
import requests.auth

from swaggerpy.client import SwaggerClient

session = requests.Session()

session.auth = requests.auth.HTTPBasicAuth('hey', 'peekaboo')

ari = SwaggerClient(
    discovery_url="http://localhost:8088/ari/api-docs/resources.json",
    session=session).apis

ws = ari.events.eventWebsocket(app='hello')

for msg_str in iter(lambda: ws.recv(), None):
    msg_json = json.loads(msg_str)
    if msg_json['type'] == 'StasisStart':
        channelId = msg_json['channel']['id']
        ari.channels.answerChannel(channelId=channelId)
        ari.channels.playOnChannel(channelId=channelId,
                                   media='sound:hello-world')
        ari.channels.deleteChannel(channelId=channelId)

swagger-codegen

There are the beginnings of a Mustache-based code generator, but it's not functional... yet.

Data model

The data model presented by the swagger_model module is nearly identical to the original Swagger API resource listing and API declaration. This means that if you add extra custom metadata to your docs (such as a _author or _copyright field), they will carry forward into the object model. I recommend prefixing custom fields with an underscore, to avoid collisions with future versions of Swagger.

There are a few meaningful differences.

  • Resource listing
    • The file and base_dir fields have been added, referencing the original .json file.
    • The objects in a resource_listing's api array contains a field api_declaration, which is the processed result from the referenced API doc.
  • API declaration
    • A file field has been added, referencing the original .json file.

Development

The code is documented using Sphinx, which allows IntelliJ IDEA to do a better job at inferring types for autocompletion.

To keep things isolated, I also recommend installing (and using) virtualenv.

$ sudo pip install virtualenv
$ mkdir -p ~/virtualenv
$ virtualenv ~/virtualenv/swagger
$ . ~/virtualenv/swagger/bin/activate

Setuptools is used for building.

$ ./setup.py develop   # prep for development (install deps, launchers, etc.)
$ ./setup.py nosetests # run unit tests
$ ./setup.py bdist_egg # build distributable

Nose is used for unit testing, with the coverage plugin installed to generated code coverage reports. Pass --with-coverage to generate the code coverage report. HTML versions of the reports are put in cover/index.html.

License

Copyright (c) 2013, Digium, Inc. All rights reserved.

Swagger.py is licensed with a BSD 3-Clause License.

About

Swagger client library for Python

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%