Skip to main content

Tiny wrapper on starlette and marshmallow-jsonapi for fast JSON:API compliant python services.

Project description

starlette_jsonapi

A minimal "framework" intended to help write json:api compliant services in async Python, written on top of starlette and marshmallow-jsonapi.

In the maintainer's view, REST frameworks that come with a complete data layer implementation are quite limiting and rarely usable in production systems due to business logic needs or authorization constraints. The default implementation they come with is usually getting in the way, more than helping.

Because of that, starlette_jsonapi does not contain a data layer implementation, so you should be able to pick any available async ORM. This also means that you are going to get a very basic interface for writing a REST resource, with some helpers to make your experience more pleasant, but nothing fancy.

Installing

pip install starlette-jsonapi

Since this project is under development, please pin your dependencies to avoid problems.

Features

  • 100% tests coverage
  • basic json:api serialization
  • including related resources
  • starlette friendly route generation
  • exception handlers to serialize as json:api responses
  • relationship resources
  • sparse fields
  • support for client generated IDs
  • support top level meta objects
  • pagination helpers
  • OpenAPI 3.x (f.k.a Swagger) integration

Todo:

Documentation

Available on Read The Docs

You should take a look at the examples directory for full implementations.

To generate documentation files locally, you should create a virtualenv, then activate it and install the requirements:

cd docs
pip install -r requirements.txt

With the docs virtualenv activated, you can then run make html to generate the HTML files.

The result will be written to docs/build, and you can open docs/build/html/index.html in your browser of choice to view the pages.

Contributing

This project is in its early days, so any help is appreciated.

Running tests:

As simple as running tox.

If you plan to use pyenv and want to run tox for multiple python versions, you can create multiple virtual environments and then make them available to tox by running something like: pyenv shell starlette_jsonapi_venv36 starlette_jsonapi_venv37 starlette_jsonapi_venv38 starlette_jsonapi_venv39.

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

starlette_jsonapi-2.2.1.tar.gz (23.9 kB view details)

Uploaded Source

Built Distribution

starlette_jsonapi-2.2.1-py3-none-any.whl (26.5 kB view details)

Uploaded Python 3

File details

Details for the file starlette_jsonapi-2.2.1.tar.gz.

File metadata

  • Download URL: starlette_jsonapi-2.2.1.tar.gz
  • Upload date:
  • Size: 23.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.7.13

File hashes

Hashes for starlette_jsonapi-2.2.1.tar.gz
Algorithm Hash digest
SHA256 af21fea01876de77c37fbe3c3ac68da41452c89a93bd745182c9ff236172f87a
MD5 25e06691544a9bd9433d1f54508098a1
BLAKE2b-256 5525cdd25c278f2846a8299ec0ae2465c30d8299c43d61e5ea3ba22537579021

See more details on using hashes here.

File details

Details for the file starlette_jsonapi-2.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for starlette_jsonapi-2.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 569d98d39f2d02c40c18469dd24afce632c7caffcb8e79bf437c10b2579cdc32
MD5 34b83469308f672066344eb03db411ff
BLAKE2b-256 80d0b3f6c2c7e0d7c3725e86195ab52d999990462d594770655af13a118a7432

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page