Skip to main content

TinyDB bridge implementation for asyncio-based applications

Project description

tinybridge

TinyDB bridge implementation for asyncio-based applications.

AIOBridge is an async-safe adapter for TinyDB, inspired by its design and intended for use within asyncio-based concurrent tasks. It enables safe and structured interaction with TinyDB from asynchronous Python code.

Key capabilities

  • Implements an async context manager for automatic resource handling
  • Ensures concurrency safety via a shared asyncio.Lock per DB file path
  • Executes all TinyDB operations using asyncio.to_thread() for non-blocking behavior
  • Provides functional-style error handling via Result objects
  • Supports configurable per-operation timeouts for robustness under load

Installation

Install via pip:

pip install tinybridge

Or using uv:

uv add tinybridge

tinybridge depends on tinydb and result, both installed automatically as dependencies.

Configuration

AIOBridge accepts the following options during initialization:

Parameter Type Default Description
path str Path to the TinyDB JSON file
timeout int 10 Timeout (in seconds) applied to each operation
tinydb_class type TinyDB Optional class to override the default TinyDB implementation
**kwargs dict Additional keyword arguments passed to the TinyDB constructor

Customizing tinydb_class

You can override the default TinyDB class either by passing a custom class directly or by subclassing AIOBridge.

Via tinydb_class argument

from tinybridge import AIOBridge
from tinydb import TinyDB
from tinydb.storages import MemoryStorage

class InMemoryTinyDB(TinyDB):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, storage=MemoryStorage, **kwargs)

async with AIOBridge("db.json", tinydb_class=InMemoryTinyDB) as db:
    ...

By subclassing AIOBridge

from tinybridge import AIOBridge
from tinydb import TinyDB
from tinydb.storages import JSONStorage
from tinydb.middlewares import CachingMiddleware

class CustomTinyDB(TinyDB):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, storage=CachingMiddleware(JSONStorage), **kwargs)

class CustomAIOBridge(AIOBridge):
    tinydb_class = CustomTinyDB

Usage Example

Minimal example demonstrating asynchronous insert:

import asyncio
from tinybridge import AIOBridge

async def main():
    async with AIOBridge("db.json") as db:
        result = await db.insert({"name": "Alice"})
        if result.is_ok():
            print("Inserted:", result.unwrap())
        else:
            print("Insert failed:", result.unwrap_err())

asyncio.run(main())

All standard TinyDB operations—such as get, search, update, and remove—are supported. Each method is wrapped for async compatibility and returns a Result object for safe error handling.

Similar Projects

Alternative community-driven efforts to add async capabilities to TinyDB:

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

tinybridge-0.1.0.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tinybridge-0.1.0-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file tinybridge-0.1.0.tar.gz.

File metadata

  • Download URL: tinybridge-0.1.0.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.4.18

File hashes

Hashes for tinybridge-0.1.0.tar.gz
Algorithm Hash digest
SHA256 25c4daef021888194812e9af7f5e56fd639b9ce0a0df6ad61ff609e2f12e7660
MD5 09f7b986b961aa2b46c7a72590a98ae8
BLAKE2b-256 1e57fe40e6cecf7fa16c9138d4dcbf038acf104eacd447bf4b158736769590bd

See more details on using hashes here.

File details

Details for the file tinybridge-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: tinybridge-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 5.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.4.18

File hashes

Hashes for tinybridge-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 98705df1a7b5ec651daadc58838d58adeae802119747508868861d247dabca28
MD5 d8fef7e8ea166d57554f6286a033c834
BLAKE2b-256 197fd888c85bacbed0cc2df03cb26b7f66dc7e06d68bb32a195773d13e96c1a6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page