Skip to main content

An ORM-like wrapper for the rethinkdb asyncio driver

Project description

## Introduction

Resync is a Django-ORM inspired wrapper around the official rethinkdb driver's (currently undocumented) asyncio connection class.

### Usage Examples

import asyncio
import resync
from resync import fields
from resync.models import Model, NestedDocument

from myapp.auth.models import User

class Grommet(NestedDocument):
Nested documents don't have a table associated, but allow you to define a
schema for arbitrary json sub-documents in a model.
weight = fields.FloatField()
enabled = fields.BooleanField(default=False)

class Widget(Model):
Model classes refer to a table in the database. By default, the table
name is the lowercased name of the class.

id = fields.StrField()
grommet = fields.NestedDocumentField(Grommet)
foo = fields.StrField()
owner = fields.ForeignKeyField(User)

async def create_widget(user: User) -> None:
Model objects can be created and manipulated like ordinary python objects,
then saved to the database.
new_widget = Widget(owner=user, foo='bar')
new_widget.grommet = Grommet(weight=15.0)
print( # '45226082-976e-4226-b2c7-0d2c86c45b73': generated by rethinkdb

async def get_widget_by_id(id: str) -> Widget:
Use the 'objects' class attribute to query the database to retrieve an
widget = await Widget.objects.get(id=id)
return widget

async def get_all_widgets() -> typings.List[Widget]:
Querysets can be `await`ed to get all the results in a list ...
widgets = await Widget.objects.all()
return widgets

async def send_all_widgets_to_socket(socket: aiohttp.web.WebSocketResponse) -> None:
... or iterated over using `async for`
async for widget in Widget.objects.all():
serializer = MyWidgetSerializer(widget)

async def rename_all_widgets() -> None:
Make simple changes to the database in a single query without extracting
the objects to python code.
await Widget.objects.all().update(foo='baz')

async def get_enabled_widgets_for_user(user: User) -> typings.List[Widget]:
Querying related fields works similarly to django, returning a queryset
that can be manipulated as normal
ret = []
async for widget in user.widget_set.filter(enabled=True):
return ret

def main():
Resync deals transparently with connections, managing a connection pool to
reuse open connections when available.
'host': 'my.rethinkdb.fqdn',
'db': 'my_database_name',
'user': 'test',
'password': '123456'
}) # These arguments are passed to rethinkdb.connect
# (docs:

loop = asyncio.get_event_loop()
fut = asyncio.ensure_future(get_all_widgets())
print(fut.result()) # List of widgets...

teardown = asyncio.ensure_future(resync.teardown())
loop.run_until_complete(teardown) # Closes all connections.

### TODO

- Tests
- Docs

### Contributors

- James Keys (author) <@skolsuper>

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for resync-orm, version 0.2.1
Filename, size File type Python version Upload date Hashes
Filename, size resync_orm-0.2.1-py2.py3-none-any.whl (16.3 kB) File type Wheel Python version py2.py3 Upload date Hashes View
Filename, size resync-orm-0.2.1.tar.gz (14.0 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page