Starlette API layer inherited from APIStar
Project description
Starlette API
- Version: 0.3.0
- Status: Production/Stable
- Author: José Antonio Perdiguero López
Introduction
That library aims to bring a layer on top of Starlette framework to provide useful mechanism for building APIs. It's based on API Star, inheriting some nice ideas like:
- Schema system based on Marshmallow that allows to declare the inputs and outputs of endpoints and provides a reliable way of validate data against those schemas.
- Dependency Injection that ease the process of managing parameters needed in endpoints.
- Components as the base of the plugin ecosystem, allowing you to create custom or use those already defined in your endpoints, injected as parameters.
- Starlette ASGI objects like
Request
,Response
,Session
and so on are defined as components and ready to be injected in your endpoints.
Requirements
- Python 3.6+
- Starlette 0.9+
Installation
$ pip install starlette-api
Example
from marshmallow import Schema, fields, validate
from starlette_api.applications import Starlette
# Data Schema
class Puppy(Schema):
id = fields.Integer()
name = fields.String()
age = fields.Integer(validate=validate.Range(min=0))
# Database
puppies = [
{"id": 1, "name": "Canna", "age": 6},
{"id": 2, "name": "Sandy", "age": 12},
]
# Application
app = Starlette()
# Views
@app.route("/", methods=["GET"])
def list_puppies(name: str = None) -> Puppy(many=True):
"""
List the puppies collection. There is an optional query parameter that
specifies a name for filtering the collection based on it.
Request example:
GET http://example.com/?name=Sandy
Response example:
200
[
{"id": 2, "name": "Sandy", "age": 12}
]
"""
return [puppy for puppy in puppies if puppy["name"] == name]
@app.route("/", methods=["POST"])
def create_puppy(puppy: Puppy) -> Puppy:
"""
Create a new puppy using data validated from request body and add it
to the collection.
Request example:
POST http://example.com/
{
"id": 1,
"name": "Canna",
"age": 6
}
Response example:
200
{
"id": 1,
"name": "Canna",
"age": 6
}
"""
puppies.append(puppy)
return puppy
Credits
That library started mainly as extracted pieces from APIStar and adapted to work with Starlette.
Contributing
This project is absolutely open to contributions so if you have a nice idea, create an issue to let the community discuss it.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
starlette-api-0.3.0.tar.gz
(25.8 kB
view hashes)
Built Distribution
Close
Hashes for starlette_api-0.3.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 590a53ce7ebb64d615e3214c17ce5c19edc881c0841b890cb1dbb1634fdce250 |
|
MD5 | f03ec9f8a2af3edd41d58f4440dfbae7 |
|
BLAKE2b-256 | d7e948b7d6056755323a5069a6d45c7855f84aa0542987d070179c4217893c98 |