/fregger

Automatically generate Swagger docs for Flask-Restful.

Primary LanguagePython

Fregger

Automatically generate Swagger docs for Flask-Restful.

Installation

Install this extension with pip:

$ pip install fregger

Usage

from flask import Flask
from flask_restful import Api, Resource, reqparse
from fregger import Fregger

app = Flask(__name__)

# Blueprints are also supported 

api = Api(app, prefix='/api/v1')
fregger = Fregger(api, title='APIs for admins modules')

parser = reqparse.RequestParser()
parser.add_argument('name', type=str, location='json', store_missing=False)
parser.add_argument('email', type=str, location='json', store_missing=False)
parser.add_argument('password', type=str, location='json', store_missing=False)


class AdminResource(Resource):

    @fregger.generate_doc(summary='Retrieve specific admin info')
    def get(self, aid):
        return {'info': 'info of admin %d' % aid}

    @fregger.generate_doc(parser, summary='Modify specific admin info')
    def post(self, aid):

        # Modify admin info here

        return {'status': 'ok'}


# must setup fregger before add_resource
api.add_resource(AdminResource, '/admins')

if __name__ == "__main__":
    # Fregger is only enabled under DEBUG mode for security reason
    app.config['DEBUG'] = True
    app.run()

Then you can visit:

http://localhost:5000/admin/api/v1/fregger.html

Note:

Fregger is Only enabled when `flask.config['DEBUG'] = True` for security reason