Skip to main content

Async Python client for nedbd — the nedb-engine server daemon

Project description

nedb-engine-client

Async Python client for nedbd — the NEDB server daemon.

PyPI Python License

Connect to any running nedbd instance — local or remote — with a clean async API. No engine code embedded, no Rust toolchain required. Just HTTP.


Install

pip install nedb-engine-client

Requires Python ≥ 3.8 and httpx.


Quick start

import asyncio
from nedb_client import NedbClient

async def main():
    async with NedbClient("http://127.0.0.1:7070", db="mydb") as db:

        # Write a document
        await db.put("blocks", "618000", {
            "height": 618000,
            "hash": "000000000000000000024bead8df69990852c202db0e0097c1a12ea637d7e96d",
            "tx_count": 2734,
        })

        # Query with NQL
        rows = await db.query("FROM blocks ORDER BY height DESC LIMIT 10")

        # Time-travel: what did the DB look like at seq 100?
        old = await db.query("FROM blocks AS OF 100 WHERE height > 600000")

        # Bi-temporal: what was true on 2024-06-15?
        valid = await db.query('FROM policy VALID AS OF "2024-06-15"')

        # Causal trace: why was this written?
        trace = await db.query("FROM blocks TRACE caused_by")

        # BLAKE2b Merkle head — changes on every write, anchorable
        head = await db.head()
        print(f"head: {head}")

        # Tamper-evidence check across all objects
        report = await db.verify()
        assert report["ok"], "tamper detected!"

asyncio.run(main())

nedbd — start the server

pip install nedb-engine

# v1 AOF engine (default)
nedbd --data ./data

# v2 DAG engine (recommended — instant cold start, tamper-evident)
NEDBD_DAG=1 nedbd --data ./data

# With AES-256-GCM encryption
NEDBD_DAG=1 NEDB_TMK=<32-byte-hex> nedbd --data ./data

# Check health
curl http://127.0.0.1:7070/health
# {"ok":true,"version":"2.0.8","service":"nedbd","encrypted":true}

API reference

Client lifecycle

# Async context manager (recommended)
async with NedbClient(url, db=name, token=token) as db:
    ...

# Manual
db = NedbClient(url="http://127.0.0.1:7070", db="mydb", token="secret")
await db.open()
await db.close()

Writes

Method Description
await db.put(coll, id, doc, **opts) Write a document
await db.delete(coll, id) Tombstone delete (history preserved in DAG)
await db.batch(ops) Batch put/del in one HTTP round-trip
await db.create_index(coll, field) Create sorted index for ORDER BY

Put options:

await db.put("claims", "c1", {"fact": "..."}, 
    caused_by=["abc123hash"],   # DAG causal provenance
    valid_from="2024-01-01",    # bi-temporal valid window
    valid_to="2024-12-31",
    evidence="sensor-42",       # human-readable provenance note
    confidence=0.95,            # confidence score 0–1
    idem="dedup-key",           # idempotency key
)

Reads

Method Description
await db.get(coll, id) Fetch current version of a document
await db.query(nql) NQL query → list of dicts
await db.query_full(nql) NQL query → full response (rows + seq + head)

NQL — NEDB Query Language

FROM <collection>
  [AS OF <seq>]                  transaction time (when was it written?)
  [VALID AS OF "<date>"]         valid time (when was it true in the world?)
  [WHERE field = value [AND ...]] op: = != < <= > >=
  [ORDER BY field [DESC]]
  [LIMIT n]
  [GROUP BY field COUNT|SUM|AVG|MIN|MAX]
  [TRACE caused_by [REVERSE]]    causal graph traversal
  [SEARCH "text"]                full-text search

Integrity

Method Description
await db.verify() BLAKE2b tamper-evidence check across all objects
await db.head() Current Merkle root — changes on every write
await db.seq() Current global sequence number
await db.log(limit) Recent write log
await db.checkpoint() Explicit checkpoint (no-op on v2 DAG)

Server management

Method Description
await db.health() Server health — version, databases, encryption
await db.ping() Boolean reachability check
await db.list_databases() All databases on this server
await db.create_database() Create this database explicitly
await db.drop_database() Drop this database (irreversible)

Error handling

from nedb_client import NedbClient, NedbError

async with NedbClient("http://127.0.0.1:7070", db="mydb") as db:
    try:
        await db.put("coll", "id", {"data": "value"})
    except NedbError as e:
        print(f"HTTP {e.status}: {e.message}")

Queries on missing collections return [] rather than raising — resilient by default.


Links


© INTERCHAINED, LLC · GPL-3.0-or-later · Built with Hyperagent

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

nedb_engine_client-2.2.7.tar.gz (8.1 kB view details)

Uploaded Source

Built Distribution

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

nedb_engine_client-2.2.7-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file nedb_engine_client-2.2.7.tar.gz.

File metadata

  • Download URL: nedb_engine_client-2.2.7.tar.gz
  • Upload date:
  • Size: 8.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for nedb_engine_client-2.2.7.tar.gz
Algorithm Hash digest
SHA256 26a60d1b2654ed437723531701bda6d149522fdf9e3d426754191f23d94c36bd
MD5 0a957ecbfd8e81c97f6a2e1b9b3ba13e
BLAKE2b-256 4fd02d40ef3cc51e72e585b54db74892960e43a2fc2035d1b0915fbe5c889cd7

See more details on using hashes here.

File details

Details for the file nedb_engine_client-2.2.7-py3-none-any.whl.

File metadata

File hashes

Hashes for nedb_engine_client-2.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 69642e622940937130957744511ce6ea3bff455759334ffd7cfbb2d9bf3d1c43
MD5 48f7e08b7ef48b5bd1e7db64e3408b1a
BLAKE2b-256 87e4059d4689502cec0121584e0dc5dc13c705dfbd17c715d3f46f064e9ad4a7

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