Skip to main content

A minimalistic JSON API framework in Python with support for graphql-style queries.

Project description

jsonapi Travis Coveralls github Codacy grade GitHub tag Python versions

A minimalistic JSON API framework in Python with support for graphql-style queries.

jsonapi is heavily inspired by graphql, but aimed at a much simpler use case. The idea is to have a minimal framework for easily building JSON based APIs, that doesn't require any particular frontend technology. The design is inspired in graphql's idea of a single fully customizable endpoint, but instead of defining a specific query language, jsonapi is entirely based on JSON both for the query and the response, requires much less boilerplate code, only works in Python 3, and of course, is much less battle-tested. If you find graphql amazing but would like to try a decaffeinated version that you can setup in 10 lines, then give jsonapi a shot.

Instalation

The easiest installation is through pip. Unfortunately the cute name jsonapi was taken already in PyPi, so the project is registered under jsonapi-simple.

pip install jsonapi-simple

You can also just clone and distribute with your project's source code:

git clone https://github.com/apiad/jsonapi.git

Hello world

To illustrate the usage is best to start with an example. The main class in jsonapi is (wait for it...) JsonApi, which defines all the available commands in the API as public methods:

>>> from jsonapi import JsonApi

>>> class HelloWorld(JsonApi):
...     def say(self, message, args):
...         return message.format(args)

Afterwards, create an instance of this API and call it, passing along either a JSON-enconded string, or a pure Python dictionary, to query either methods or attributes:

>>> api = HelloWorld()

>>> api({"say": { "$message": "Hello {0}!", "$args": "world" }})
{'say': 'Hello world!'}

Moving on

There is more that can be done with jsonapi, read the documentation to learn more:

Contributing

Contributions are highly appreciated. Just fork and submit a pull request. All contributors will be granted credit on the following list:

Changelog

In the roadmap

  • Automatic API documentation.

v0.2.2

v0.2.1

  • Support for typed arguments.

v0.2.0

  • Support for meta operators in dictionaries (_count, _items, _keys, _values).
  • The JsonObj constructor now receives either str, dict or a **kwargs mapping.

v0.1.4

  • Support for some meta operators for lists (_count and _items).

v0.1.3

  • Basic implementation of JsonObj for JSON manipulation.

v0.1.2

  • Suport for complex method arguments (parsed via JsonObj).

v0.1.1

  • Suport for plain method arguments.

v0.1

  • Basic layout of the API.
  • Simple attribute and method based navigation.
  • Automatic serialization to a JSON compatible object.
  • Basic documentation.

Colaboration

This project is licensed MIT, so you know the drill. Fork, open a pull request, and make sure to have up-to-date tests with (ideally) a 100% coverage.

MIT License

Copyright (c) 2018 Alejandro Piad

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

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

jsonapi-simple-0.2.2.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

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

jsonapi_simple-0.2.2-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file jsonapi-simple-0.2.2.tar.gz.

File metadata

  • Download URL: jsonapi-simple-0.2.2.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.6.7

File hashes

Hashes for jsonapi-simple-0.2.2.tar.gz
Algorithm Hash digest
SHA256 05f9670a9bdc8f58759453ba0de3778b48d6f16640a622f34c1f12a7a1c9f5cd
MD5 0326921cbc9a616551c30945702cd2af
BLAKE2b-256 12a9c11572734f1e81bd39385ab42d5c6b059c22fee5ed04e44c8868d0d4c5fd

See more details on using hashes here.

File details

Details for the file jsonapi_simple-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: jsonapi_simple-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 7.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.6.7

File hashes

Hashes for jsonapi_simple-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 2d9c03ce340f8fa1cd9d68c62a6ed22af3cc789d21358348077ef17437506c7e
MD5 b3f23eff0431eeccf3659d891d6800e5
BLAKE2b-256 aa3a7d31e87e974efcc0822309a8d35c71680c3fa1a89f66db5968415e01ef52

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