Skip to main content

Build and document REST APIs with Flask and apispec

Project description

Latest version Documentation status Travis-CI Code coverage

flask-apispec is a lightweight tool for building REST APIs in Flask. flask-apispec uses webargs for request parsing, marshmallow for response formatting, and apispec to automatically generate Swagger markup. You can use flask-apispec with vanilla Flask or a fuller-featured framework like Flask-RESTful.

Install

pip install flask-apispec

Quickstart

from flask import Flask
from flask_apispec import use_kwargs, marshal_with

from marshmallow import fields, Schema

from .models import Pet

app = Flask(__name__)

class PetSchema(Schema):
    class Meta:
        fields = ('name', 'category', 'size')

@app.route('/pets')
@use_kwargs({'category': fields.Str(), 'size': fields.Str()})
@marshal_with(PetSchema(many=True))
def get_pets(**kwargs):
    return Pet.query.filter_by(**kwargs)

flask-apispec works with function- and class-based views:

from flask import make_response
from flask_apispec.views import MethodResource

class PetResource(MethodResource):

    @marshal_with(PetSchema)
    def get(self, pet_id):
        return Pet.query.filter(Pet.id == pet_id).one()

    @use_kwargs(PetSchema)
    @marshal_with(PetSchema, code=201)
    def post(self, **kwargs):
        return Pet(**kwargs)

    @use_kwargs(PetSchema)
    @marshal_with(PetSchema)
    def put(self, pet_id, **kwargs):
        pet = Pet.query.filter(Pet.id == pet_id).one()
        pet.__dict__.update(**kwargs)
        return pet

    @marshal_with(None, code=204)
    def delete(self, pet_id):
        pet = Pet.query.filter(Pet.id == pet_id).one()
        pet.delete()
        return make_response('', 204)

flask-apispec generates Swagger markup for your view functions and classes. By default, Swagger JSON is served at /swagger/, and Swagger-UI at /swagger-ui/.

from apispec import APISpec
from flask_apispec.extension import FlaskApiSpec

spec = APISpec(
    title='pets',
    version='v1',
    plugins=['apispec.ext.marshmallow'],
)
docs = FlaskApiSpec(app, spec)

docs.register(get_pets)
docs.register(PetResource)

Notes

flask-apispec isn’t stable yet, and the interface and internals may change. Bug reports and pull requests are much appreciated.

flask-apispec is strongly inspired by Flask-RESTful and Flask-RESTplus, but attempts to provide similar functionality with greater flexibility and less code.

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

flask-apispec-0.3.1.tar.gz (1.0 MB view details)

Uploaded Source

Built Distribution

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

flask_apispec-0.3.1-py2.py3-none-any.whl (1.0 MB view details)

Uploaded Python 2Python 3

File details

Details for the file flask-apispec-0.3.1.tar.gz.

File metadata

  • Download URL: flask-apispec-0.3.1.tar.gz
  • Upload date:
  • Size: 1.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for flask-apispec-0.3.1.tar.gz
Algorithm Hash digest
SHA256 5c6904e703216f0858c5702ba04a9d3e5fd91cab5d1563ad5135ef70993c32b9
MD5 8a7762da0cb19edb220d169247d1777e
BLAKE2b-256 11f018fedcf8b6f0d5b8abadae05d882ff5c31e26c5cd20933a2c2d16cc76521

See more details on using hashes here.

File details

Details for the file flask_apispec-0.3.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for flask_apispec-0.3.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 ff479da19dcad4f0ba6a35d6412c712567b5337d8556eeba5d378dbfc73862d2
MD5 82bf9f29fb8dcda49e5dc6bdb5958549
BLAKE2b-256 08c7d4951f6dee3b1118343d37c5c08040cf4a4952ba613a177704e69abcf8d0

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