Skip to main content

Tornado RESTful API with Peewee

Project description

TCrudge - simple async CRUDL based on Tornado and Peewee ORM (Peewee Async)

Documentation Status Build Status Code Climate Issue Count Coverage Status

Full documentation (http://tcrudge.readthedocs.io/en/latest/)

What is it?

Simple configurable framework to create CRUDL (Create, Read, Update, Delete, List) for models. TCrudge is under heavy development - tons of bugs are expected. You can use it in production, but API can be broken at any moment.

Why?

Tornado is fast. Peewee is great. REST is wonderful.

Dependencies

Installation

tcrudge is distributed via pypi: https://pypi.python.org/pypi/tcrudge/

pip install tcrudge

You can manually install latest version via GitHub:

pip install git+https://github.com/CodeTeam/tcrudge.git

How to?

Describe models using Peewee ORM. Subclass tcrudge.ApiListHandler and tcrudge.ApiItemHandler. Connect handlers with models using model_cls handler attribute. Add urls to tornado.Application url dispatcher.

For detailed example see tests (also, tests are available in Docker container with py.test).

You can run tests in docker container only. You’ll need docker and docker-compose.

  1. Go to project root directory

  2. Run docker-compose up, it builts and runs containers.

  3. Go to tcrudge container bash: docker exec -ti tcrudge_tcrudge_1 bash

  4. Run: DATABASE_URL=postgresql://user:dbpass@pg/test pytest

Features?

  1. DELETE request on item is disabled by default. To enable it implement _delete method in your model.

  2. Models are fat. _create, _update, _delete methods are supposed to provide different logic on CRUD operations

  3. Django-style filtering in list request: __gt, __gte, __lt, __lte, __in, __isnull, __like, __ilike, __ne are supported. Use /?model_field__<filter_type>=<filter_condition> for complex or /?model_field=<filter_condition> for simple filtering.

  4. Django-style order by: use /?order_by=<field_1>,<field_2> etc

  5. Serialization is provided by Peewee: playhouse.shortcuts.model_to_dict. recurse, exclude and max_depth params are implemented in base class for better experience. If you want to serialize recurse foreign keys, do not forget to modify get_queryset method (see Peewee docs for details, use .join() and .select())

  6. Validation is provided out-of-the box via jsonschema. Just set input schemas for base methods (e.g. post_schema_input, get_schema_input etc). Request query is validated for GET and HEAD. Request body is validated for POST, PUT and DELETE.

  7. Pagination is activated by default for lists. Use default_limit and max_limit for customization. Pagination params are set through headers (X-Limit, X-Offset) or query: /?limit=100&offset=5. Total amount of items is not returned by default. HEAD request should be sent or total param set to 1: /?total=1

  8. List handler supports default filtering and ordering. Use default_filter and default_order_by class properties.

Example

import asyncio

import peewee
import peewee_async
from playhouse.db_url import parse
from tornado import web
from tornado.ioloop import IOLoop

from tcrudge.handlers import ApiListHandler, ApiItemHandler
from tcrudge.models import BaseModel

# Configure Tornado to use asyncio
IOLoop.configure('tornado.platform.asyncio.AsyncIOMainLoop')

# Create database
DATABASE_URL = 'postgresql://user:dbpass@pg/test'

db_param = parse(DATABASE_URL)

db = peewee_async.PooledPostgresqlDatabase(**db_param)


# CRUDL Model
class Company(BaseModel):
    name = peewee.TextField()
    active = peewee.BooleanField()

    class Meta:
        database = db


# CL Handler
class CompanyDetailHandler(ApiItemHandler):
    model_cls = Company


# RUD Handler
class CompanyListHandler(ApiListHandler):
    model_cls = Company
    default_filter = {'active': True}


app_handlers = [
    ('^/api/v1/companies/', CompanyListHandler),
    ('^/api/v1/companies/([^/]+)/', CompanyDetailHandler)
]

application = web.Application(app_handlers)

# ORM
application.objects = peewee_async.Manager(db)

with application.objects.allow_sync():
    # Creates table, if not exists
    Company.create_table(True)

application.listen(8080, '0.0.0.0')
loop = asyncio.get_event_loop()
# Start application
loop.run_forever()

Сontributors

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

tcrudge-0.9.11.tar.gz (34.3 kB view details)

Uploaded Source

Built Distribution

tcrudge-0.9.11-py3-none-any.whl (41.4 kB view details)

Uploaded Python 3

File details

Details for the file tcrudge-0.9.11.tar.gz.

File metadata

  • Download URL: tcrudge-0.9.11.tar.gz
  • Upload date:
  • Size: 34.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for tcrudge-0.9.11.tar.gz
Algorithm Hash digest
SHA256 79d207fca14645bbeccf93909b83ef82ab3c063cd977799c8dcf99778e5aac01
MD5 bbb5601246f7e5cc5ac41d5cc159e61f
BLAKE2b-256 8ef17ee27257d45ad0246a79456d40869254c283be956e2eec348fc530fea874

See more details on using hashes here.

File details

Details for the file tcrudge-0.9.11-py3-none-any.whl.

File metadata

File hashes

Hashes for tcrudge-0.9.11-py3-none-any.whl
Algorithm Hash digest
SHA256 c2883631934b84bfcb2da555506ec069744fbb05b58c68b4a0685598ec219de9
MD5 5ca01aa0854538a482213be33226da5b
BLAKE2b-256 aceff94f25cb171fcd6ad4d66032420358e35400745a116a33d98a4c687ed99a

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