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-1.0.17.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-1.0.17-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: nedb_engine_client-1.0.17.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-1.0.17.tar.gz
Algorithm Hash digest
SHA256 00644a5e394d3667addc68389197ee028206eb184426945e116ed97796b861d0
MD5 d2d9824333e0cf2775c625b519f57654
BLAKE2b-256 ecfcd8dc3c9ad169dae0cc835ad4cb419615566cab429c7016013f978067b5cb

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for nedb_engine_client-1.0.17-py3-none-any.whl
Algorithm Hash digest
SHA256 21ed2f3f00be045f947f4e2908ddb1b20062921079a2011f0d977c4450b336d0
MD5 1799f541b618dbc3e1e5153f6cd76b49
BLAKE2b-256 2f8e7034f98bf2541b904a93dc7b3152732e54e6d61a940b8a40444eb785abd1

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