API Decorators
Project description
API Decorators
# book.py
from apidecorators.api import jwt_auth, is_owner, get, insert, is_owner, has_role, update, push, pull, \
validate, validate_push
from cerberus import Validator
schema = {
'author': {'type': 'string'},
'title': {'type': 'string'}
}
validator = Validator(schema)
schema_comments = {
'author': {'type': 'string'},
'message': {'type': 'string'}
}
validator_comments = Validator(schema_comments)
def set_routes_book(routes):
@routes.get('/api/book')
@jwt_auth
@collection('book')
@get_many
async def get_many_book(query, payload):
author = query["author"]
return {"author": author, "__owner": payload['user']}, 0, 10
@routes.delete('/api/book/{_id}')
@jwt_auth
@collection('book')
@is_owner
@delete
async def delete_book(query):
pass
@routes.get('/api/book/{_id}')
@jwt_auth
@collection('book')
#@read_access({'root': ['title']})
@read_access(public)
@get
async def get_book(document):
return document
@routes.put('/api/book/{_id}/push/comments')
@jwt_auth
@collection('book')
@write_access({'__owner': ['*'], 'root': ['author']})
@validate_push(validator=validator_comments)
@push('comments')
async def handle_push(document, request, payload):
return document
# TODO permissions, quizas con un argumento array de usuarios en @pull
@routes.put('/api/book/{_id}/pull/{pull}/{sub_id}')
@jwt_auth
@pull
async def handle_pull(document, request, payload):
pass
@routes.post('/api/book')
@jwt_auth
@collection('book')
@write_access(public)
@validate(validator=validator)
@insert
async def handle_post(document, request, payload):
return document
@routes.put('/api/book/{_id}')
@jwt_auth
@collection('book')
@write_access({'__owner': ['*'], 'root': ['author']})
@validate(update=True, validator=validator)
@update
async def handle_put(document, request, payload):
return document
#app.py
import asyncio
from book import set_routes_book
from aiohttp import web
from apidecorators.api import cors_factory
from apidecorators.hooks import on_insert, on_update
@on_insert('book')
def on_insert_book(book):
print('insert', book)
@on_update('book')
def on_update_book(book):
print('update', book)
async def handle(loop):
app = web.Application(loop=loop, middlewares=[cors_factory])
routes = web.RouteTableDef()
set_routes_book(routes)
app.router.add_routes(routes)
app.router.add_static('/', './dist')
await loop.create_server(app.make_handler(), '0.0.0.0', 8089)
def main():
loop = asyncio.get_event_loop()
loop.run_until_complete(handle(loop))
print("Server started at port 8089")
loop.run_forever()
loop.close()
docker-compose.yml
version: '3'
services:
api:
build: .
environment:
- DB_URI=mongodb://<user>:<password>@url:port/data-base
- DB=data-base
- SECRET=secret
stdin_open: true
tty: true
ports:
- "8089:8089"
volumes:
- ./:/usr/src/app
command: python -m watchgod app.main
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
apidecorators-0.0.6.tar.gz
(4.5 kB
view hashes)
Built Distribution
Close
Hashes for apidecorators-0.0.6-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 94b933ba9c5f9c497051677f11e2d21578f62710fcee3d52a66c5e67db20a7a3 |
|
MD5 | 2a7546f522d53c294128c641c7f6a3c2 |
|
BLAKE2b-256 | db4dd80bce96af45df615d90654b28bbd20572d692618266bea0bc82b040d512 |