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

Uploaded Python 3

File details

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

File metadata

  • Download URL: nedb_engine_client-2.3.3.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.3.3.tar.gz
Algorithm Hash digest
SHA256 085d11b614ed63575555104060900b52c81b6d9d04c0d1464938212430e75216
MD5 d961ee0a8d6e78a3f13d63ab92397989
BLAKE2b-256 f5f0bf654410c74aca3d16eede5816df1dbdd6a100c1ccfd3bd0ad33ad08f3a6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for nedb_engine_client-2.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9fe5d2e92aab500bdd421287d62fdf8e6660b4f08aaf722e171516f22198da78
MD5 891af40db8f0aaba69107789123cc27f
BLAKE2b-256 4ed0a1a2c9c87caf632feee8bead5a9a34332152c1c918d7d21e5ace9d071912

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