API Decorators
Project description
API Decorators
from 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/{_id}')
@jwt_auth
#@is_owner('book')
@get('book')
async def get_book(document):
return document
@routes.put('/api/book/{_id}/push/{push}')
@jwt_auth
#@is_owner('book')
@validate_push(validator=validator_comments)
@push('book')
async def handle_push(document, request, payload):
return document
@routes.put('/api/book/{_id}/pull/{pull}/{sub_id}')
@jwt_auth
#@is_owner('book')
@pull('book')
async def handle_pull(document, request, payload):
pass
@routes.post('/api/book')
@jwt_auth
@validate(validator=validator)
@insert('book')
async def handle_post(document, request, payload):
return document
@routes.put('/api/book/{_id}')
@jwt_auth
#@is_owner('book')
@validate(update=True, validator=validator)
@update('book')
async def handle_put(document, request, payload):
return document
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.1.tar.gz
(3.0 kB
view hashes)
Built Distribution
Close
Hashes for apidecorators-0.0.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | fc8b3a0e793f5fd41efc21ca9bd660f69650c172742cc8bef517bfeb26068608 |
|
MD5 | fab8906ed9bbb5cd891137f12de86e60 |
|
BLAKE2b-256 | 7330c9791b41c9dab69d7de2e4eb66851918f4dd3306223da93db6dc551036ba |