Kimberlite Logo

Kimberlite

Crates.io Downloads Documentation Rust Edition License CI VOPR Fuzz Nightly Formal Verification Discord

A verifiable database for healthcare.

Built for clinical and digital-health systems where PHI integrity is non-negotiable.

πŸ”¬ Developer Preview - Explore deterministic database concepts through production-quality code

Kimberlite is a verifiable, durable database engine designed for environments where data integrity, auditability, and trust are non-negotiable. Built around a single principle:

All data is an immutable, ordered log. All state is a derived view.

Why Kimberlite?

The compliance tax is real. In healthcare, you’re forced to build: - Immutable audit trails for every change - Cryptographic proof of data integrity - Per-tenant encryption and isolation - Point-in-time reconstruction

Most teams bolt these onto existing databases. Kimberlite builds them in.

Key approach: - Immutable audit trail - Hash-chained append-only log means every action is recorded - Time-travel queries - Reconstruct any point-in-time state via MVCC (AT OFFSET n and AS OF TIMESTAMP '...' both shipped) - Multi-tenant isolation - Cryptographic boundaries prevent cross-tenant access - Multi-layer verification - TLA+ protocol specs, Coq crypto proofs, Alloy structural models, Ivy Byzantine invariants, Kani bounded model checking, MIRI UB detection (details)

Designed for healthcare: EHR-adjacent systems, digital-health platforms, payer/RCM workloads, and clinical research β€” every primitive is sized to HIPAA, with GDPR (international health) and SOC 2 / FedRAMP (clinical SaaS / federal health) as load-bearing extensions.

Who Should Explore This

Perfect for learning. Not yet recommended for production deployments (see Status below).

Quick Start

5-minute quickstart: See Getting Started for a complete tutorial with explanations.

TL;DR:

# Install (see docs/start/installation.md for all options)
curl -fsSL https://kimberlite.dev/install.sh | sh

# Initialize (or: kimberlite init  for interactive wizard)
kimberlite init myproject
kimberlite dev
# Studio: http://localhost:5555, DB: 127.0.0.1:5432

Try time-travel queries:

CREATE TABLE patients (id INTEGER, name TEXT);
INSERT INTO patients VALUES (1, 'Alice'), (2, 'Bob');

-- View current state
SELECT * FROM patients;

-- View state as of a specific log offset (MVCC time-travel)
SELECT * FROM patients AT OFFSET 0;

-- Or as of a wall-clock timestamp (resolved via the audit-log index)
SELECT * FROM patients AS OF TIMESTAMP '2026-01-15T00:00:00Z';

Documentation

Building from Source

# Clone and build
git clone https://github.com/kimberlitedb/kimberlite.git
cd kimberlite
cargo build --release -p kimberlite-cli

# Binary is at ./target/release/kimberlite

Development Commands

just build          # Debug build
just build-release  # Release build
just test           # Run all tests
just nextest        # Faster test runner
just clippy         # Linting
just pre-commit     # Run before committing

Key Features

What Makes Kimberlite Unique:

See CHANGELOG.md for per-release detail; ROADMAP.md for what’s next.

Use Cases

Kimberlite is built for healthcare: - EHR / EMR systems β€” patient records, clinical notes, encounters with FHIR R4 and HL7 v2 native types - Payer / RCM β€” X12 837 claim ingestion, 835 remittance reconciliation, audit-by-default - Clinical research β€” IRB-aware retention, consent-bound queries, Safe Harbor de-identification for secondary use - Digital health β€” multi-tenant SaaS with per-tenant encryption and BAA-ready audit chain

Examples

See the examples/ directory for: - quickstart/ - Getting started - rust/ - Rust SDK examples - docker/ - Docker deployments - healthcare/ - HIPAA-ready schema

Architecture

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  Kernel (pure state machine: Cmd -> State + FX)  β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  Append-Only Log (hash-chained, CRC32)           β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  Crypto (SHA-256, BLAKE3, AES-256-GCM, Ed25519)  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

See docs/concepts/architecture.md for details.

Why Kimberlite vs.Β Traditional Databases?

Feature PostgreSQL Kimberlite
Data model Mutable tables Immutable log + derived views
Audit trail Manual triggers Built-in (every write logged)
Time-travel Extensions (complex) Native SQL (AS OF TIMESTAMP)
Integrity Checksums Hash chains + CRC32
Consensus Streaming replication VSR (deterministic, multi-node)
Best for General OLTP Compliance-heavy workloads

Trade-offs: Kimberlite trades some write throughput for built-in auditability and tamper-evidence. Quantitative re-baseline against current hardware is a v0.9.0 target; see FAQ for the qualitative comparison.

Learning Resources

Documentation Deep Dive

Community

Status

v0.x β€” Developer Preview. Stable enough for prototypes, learning, internal tools, and compliance research. Not yet battle-tested at scale.

Use for: internal tools, prototypes, learning database internals, compliance research.

Wait for v1.0 if you need: API stability guarantees, large-scale production deployment, commercial support, or third-party SOC 2 / HIPAA / GDPR attestations. v1.0 is checklist-gated with no fixed date β€” see ROADMAP.md for the gates.

Post-v1.0: a managed cloud service (Kimberlite Cloud) is planned alongside the OSS core. The core stays OSS; the cloud adds ops, scaling, and compliance-ready shared-responsibility β€” similar to CockroachDB Serverless on top of CockroachDB OSS.

Known Limitations (v0.8.0)

We surface these up front so you don’t trip over them:

See ROADMAP.md for the full list of in-flight and deferred items, and the v1.0 readiness gates.

Compliance posture

Kimberlite ships the cryptographic and architectural primitives that HIPAA demands, with GDPR / SOC 2 / ISO 27001 / FedRAMP as overlays: hash-chained immutable audit log (server-walked attestation via audit.verifyChain()), AES-256-GCM at rest, Ed25519 signed exports, multi-tenant key isolation, GDPR Article 17 erasure orchestration with requestId correlation, GDPR Article 6 consent-basis tracking on the wire, column-level masking policies that compose with RBAC + break-glass, Safe Harbor de-identification of all 18 Β§164.514(b)(2) identifiers, and healthcare-relevant frameworks formally modelled (TLA+ + Coq + Kani + VOPR scenarios) β€” see docs/compliance/certification-package.md.

What we have NOT done: third-party SOC 2 Type II audit, HIPAA attestation + BAA, FedRAMP authorization, GDPR readiness review. These are v1.0 gates. Until then, Kimberlite enables your compliance posture; certification remains your team’s responsibility (BAA with your hosting provider, pen test, audit firm engagement, internal controls). If you’re a regulated startup, you can build on Kimberlite today knowing the substrate is sound β€” but the audit letters and certifications are work you (or we, post-v1.0) still have to do.

SDKs

Kimberlite provides idiomatic client libraries for multiple languages:

Language Status Package Install
Rust βœ… Ready kimberlite-client cargo add kimberlite-client
TypeScript βœ… Ready (Node 18/20/22/24, prebuilt napi) @kimberlitedb/client npm install @kimberlitedb/client
Python βœ… Ready kimberlite pip install kimberlite
Go πŸ“‹ Planned (v0.9.0 Phase 1) β€” See ROADMAP
Java πŸ“‹ Planned (v1.0 gate) com.kimberlite:kimberlite-client Maven / Gradle
C++ πŸ“‹ Planned (v1.0 gate, via FFI) kimberlite-cpp Coming soon

See docs/reference/sdk/overview.md for architecture and docs/reference/protocol.md for wire protocol specification.

License

Apache 2.0

Contributing