Skip to main content

Simple DRM for motor client

Project description

MDocument

pipeline status coverage report pypi link

Simple DRM for async mongo motor client

Usage

import asyncio

from mdocument import Document

import motor.motor_asyncio

client = motor.motor_asyncio.AsyncIOMotorClient()

class Comment(Document):
    collection = "comments"
    database = "mdocument"
    client = client


class Video(Document):
    collection = "videos"
    database = "mdocument"
    client = client

    @Document.related(self_field="_id", other_field="video")
    def comments(self):
        pass

async def main():
    video = await Video.create(
        title="Test",
    )

    comment1 = await Comment.create(
        video=video._id,
        message="First!",
    )

    comment2 = await Comment.create(
        video=video._id,
        message="Second!"
    )

loop = asyncio.get_event_loop()
loop.run_until_complete(main())

Now we can easily access our comments using our related documents

print(await video.comments)
[
    Comment(_id=5e7533d55eb6a8c6d24d3cc7, video=5e7533d55eb6a8c6d24d3cc6, message=First!),
    Comment(_id=5e7533d55eb6a8c6d24d3cc8, video=5e7533d55eb6a8c6d24d3cc6, message=Second!)
]

Document methods

Here is a list of Document basic methods

.create

@classmethod
async def create(cls, **kwargs):

If you want to create a new document you can do it easily with .create method. Example:

import asyncio

from mdocument import Document

import motor.motor_asyncio

client = motor.motor_asyncio.AsyncIOMotorClient()

class Message(Document):
    collection = "messages"
    database = "mdocument"
    client = client


loop.run_until_complete(
    Message.create(from_user="admin", text="Test message!")
)

This will create document in database:

{
    '_id': ObjectId('5e75373e5eb6a8c6d14d3ccd'),
    'from_user': 'admin',
    'text': "Test message!"
}

.push_update

Updates document and all @related fields.

await Message.push_update()

.delete

Deletion of document from database. Based on your set @related rules all related documents will be modified too.

message = await Message.one(from_user="admin")

await message.delete()

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

mdocument-3.0.1586561692.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

mdocument-3.0.1586561692-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file mdocument-3.0.1586561692.tar.gz.

File metadata

  • Download URL: mdocument-3.0.1586561692.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.8.2

File hashes

Hashes for mdocument-3.0.1586561692.tar.gz
Algorithm Hash digest
SHA256 b2257f080de009a81500bb88feb2fa1cc9938d4efa130c3a82586415b793d91c
MD5 32b5c59534ecae099392c2abcaaa01bc
BLAKE2b-256 4a4cd2dccbadf704144c7c28d711e3ac0cedf6d114e0b082f1101ebfa38c467e

See more details on using hashes here.

File details

Details for the file mdocument-3.0.1586561692-py3-none-any.whl.

File metadata

  • Download URL: mdocument-3.0.1586561692-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.8.2

File hashes

Hashes for mdocument-3.0.1586561692-py3-none-any.whl
Algorithm Hash digest
SHA256 415b4ad2290849b07871c94532c3d02c3dc739903ae810d0825f15c12bb4d50d
MD5 64317fa91343f0746da525db87ff967a
BLAKE2b-256 9319f1778c76d35afd33460ae1f0a6d473895641a1893164c2a9ea8d4acfbbfd

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