Skip to main content

Flask extension to create REST web api according to JSONAPI 1.0 specification with Flask, Marshmallow and data provider of your choice (SQLAlchemy, MongoDB, ...)

Project description

flask-rest-jsonapi-next

PyPi Status license tests Documentation Status python_versions

This is a fork of miLibris/flask-rest-jsonapi project.

flask-rest-jsonapi-next is a flask extension for building REST APIs around a strong specification JSON:API 1.0.

Documentation: http://flask-rest-jsonapi-next.readthedocs.io/en/latest/

Install

pip install flask-rest-jsonapi-next

A minimal API

from flask import Flask
from flask_rest_jsonapi_next import Api, ResourceDetail, ResourceList
from flask_sqlalchemy import SQLAlchemy
from marshmallow_jsonapi.flask import Schema
from marshmallow_jsonapi import fields

# Create the Flask application and the Flask-SQLAlchemy object.
app = Flask(__name__)
app.config['DEBUG'] = True
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db'
db = SQLAlchemy(app)

# Create model
class Person(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String)

# Create the database.
db.create_all()

# Create schema
class PersonSchema(Schema):
    class Meta:
        type_ = 'person'
        self_view = 'person_detail'
        self_view_kwargs = {'id': '<id>'}
        self_view_many = 'person_list'

    id = fields.Integer(as_string=True, dump_only=True)
    name = fields.Str()

# Create resource managers
class PersonList(ResourceList):
    schema = PersonSchema
    data_layer = {'session': db.session,
                    'model': Person}

class PersonDetail(ResourceDetail):
    schema = PersonSchema
    data_layer = {'session': db.session,
                    'model': Person}

# Create the API object
api = Api(app)
api.route(PersonList, 'person_list', '/persons')
api.route(PersonDetail, 'person_detail', '/persons/<int:id>')

# Start the flask loop
if __name__ == '__main__':
    app.run()

This example provides the following API structure:

URL method endpoint Usage
/persons GET person_list Get a collection of persons
/persons POST person_list Create a person
/persons/<int:person_id> GET person_detail Get person details
/persons/<int:person_id> PATCH person_detail Update a person
/persons/<int:person_id> DELETE person_detail Delete a person

Thanks

Flask, marshmallow, marshmallow_jsonapi, sqlalchemy, Flask-RESTful and Flask-Restless are awesome projects. These libraries gave me inspiration to create flask-rest-jsonapi-next, so huge thanks to authors and contributors.

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_rest_jsonapi_next-0.46.0.tar.gz (125.5 kB view details)

Uploaded Source

Built Distribution

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

flask_rest_jsonapi_next-0.46.0-py3-none-any.whl (37.5 kB view details)

Uploaded Python 3

File details

Details for the file flask_rest_jsonapi_next-0.46.0.tar.gz.

File metadata

  • Download URL: flask_rest_jsonapi_next-0.46.0.tar.gz
  • Upload date:
  • Size: 125.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for flask_rest_jsonapi_next-0.46.0.tar.gz
Algorithm Hash digest
SHA256 920aad2f2eca88a76411e6177d92902f60000e7858f104ff565d9e17b1a3e604
MD5 2da4d7895788e12b9d52be44b5744cbd
BLAKE2b-256 4b5e10e7fc381f6930c880250e0a99dab8b67714ee296e73bf21eb4515b8b345

See more details on using hashes here.

Provenance

The following attestation bundles were made for flask_rest_jsonapi_next-0.46.0.tar.gz:

Publisher: pypi-publish.yaml on tadams42/flask-rest-jsonapi-next

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flask_rest_jsonapi_next-0.46.0-py3-none-any.whl.

File metadata

File hashes

Hashes for flask_rest_jsonapi_next-0.46.0-py3-none-any.whl
Algorithm Hash digest
SHA256 28ea2600246ec9cb158e1ead3ba2fa243bf2459db5fe675b7dc3c691fe9d1a50
MD5 f35cc3888d7aec34afb5829aeac4aa23
BLAKE2b-256 231c7171ab54c58181c67bc895c8b34b1cd39a3ff41b14cc9eb6838559dee0e8

See more details on using hashes here.

Provenance

The following attestation bundles were made for flask_rest_jsonapi_next-0.46.0-py3-none-any.whl:

Publisher: pypi-publish.yaml on tadams42/flask-rest-jsonapi-next

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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