Package Exports
- loki-mode
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (loki-mode) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Loki Mode
The spec-driven autonomous builder with verified completion.
The free, source-available autonomous coding agent by Autonomi. Same Loki CLI, SDK, and MCP for everyone; the commercial editions for teams and enterprises are sold under the Autonomi brand (Autonomi Cloud, Autonomi Enterprise).
Hand it a spec. It does not accept "done" on an empty diff or failing tests.
Website | Documentation | Installation | Changelog | Purple Lab -- deprecated v7.44.0
How it works: Drop a spec -- a PRD, GitHub issue, OpenAPI/JSON/YAML, or one-line brief. Loki Mode classifies complexity (
run.sh:detect_complexity()), assembles an agent team from 41 specialized agent roles across 8 domains - prompt-defined specifications the orchestrator adopts per phase, with parallel review (blind council) and optional worktree streams on Claude Code, sequential on other providers - and runs autonomous RARV cycles (Reason - Act - Reflect - Verify, seerun.sh:run_autonomous()) with 8 quality gates (seeskills/quality-gates.md). Code is not "done" until it passes automated verification. Output is a Git repo with source, tests, configs, and audit logs.
Why Loki Mode?
- Spec-driven, autonomous, with a built-in trust layer -- Hand Loki a spec, walk away, come back to working code with tests. The full RARV-C closure loop (Reason - Act - Reflect - Verify - Close) runs until the work is actually done, not just attempted. The verified-completion evidence gate (
skills/quality-gates.md) refuses any "done" claim on an empty git diff against the run-start commit, and blocks completion when tests run red, so "complete" means proven, not promised. - Production quality built in -- 8 quality gates (
skills/quality-gates.md), blind 3-reviewer code review (run.sh:run_code_review()), anti-sycophancy checks - Standalone verification:
loki verify-- Run Loki's deterministic gates (build, tests, static analysis, secret scan, dependency audit) against any branch or PR diff, including code written by other agents or humans. CI-ready exit codes (0 VERIFIED, 1 CONCERNS, 2 BLOCKED), machine-readable evidence at.loki/verify/evidence.json. Inconclusive evidence is never reported as VERIFIED (v7.27.0). - Living spec and pre-build interrogation --
loki speclocks a spec and detects drift deterministically (spec.lock,drift-report.json, and aSPEC_DRIFTfinding inloki verifywith CI exit codes), so you can tell when the build diverges from what was agreed.loki grillruns a Devil's-Advocate interrogation of the spec before you build, surfacing gaps and contradictions early (v7.28.0). - Mid-flight model switching -- switch the model a live run uses from the dashboard (applies at the next iteration, current run only). A Fable tier lever exists in the CLI, dashboard, and override paths, but Claude Fable 5 is not yet available at the API, so selecting Fable currently collapses to Opus at every dispatch chokepoint and the
loki planquote reflects Opus accordingly. For every model lever (session pin, mid-flight override, architect pass) and everyLOKI_MAX_TIERpath, theloki planquote, the dashboard's reported model, and the actual dispatched model agree, with the ceiling enforced (v7.31.0; Fable-to-Opus collapse v7.39.1). - A calmer CLI -- the help surface is ~20 grouped workflow entries instead of a 70-command wall; merged commands live on as aliases that forward byte-identically with a one-line stderr pointer, so no script breaks (v7.31.0).
- Guided first build:
loki quickstart-- four quick questions (setup check, one-line idea, template pick, plan review) and your build starts; pressing Enter through every step builds the sample Todo app. The plan step quotes the real cost/time estimate before anything is spent, andloki demonow confirms its estimate the same way. If no AI provider CLI is installed, Loki offers to install Claude Code (consent-gated, interactive terminals only) (v7.29.0). - Live App Preview -- The dashboard embeds the locally-running app in an iframe so you can interact with it immediately during a build. Use
loki preview(aliasloki open) to print the URL and open it in your browser. Local-first: no hosted service, no vendor lock (v7.24.0). - Compose-first fullstack -- When a spec needs more than one service (web + database + cache) Loki generates a 12-factor
docker-compose.ymlwith healthchecks,depends_onwiring, env-var config, and a.env.example. The Live App Preview surfaces the web service URL (not a database port), and health reflects the web service's Docker healthcheck so a crashed app shows as crashed even when the database stays up. Single-service apps stay on a plain run command. All local-first, no hosted service (v7.26.0). - Intelligent
loki start-- For interactive foreground runs the dashboard auto-opens in the browser (cross-platform; skipped in CI, SSH-without-TTY, and piped runs; opt out withLOKI_NO_AUTO_OPEN=1). The completion summary shows "Your app is live at" so you know exactly where to try what Loki just built. The autonomous loop passes Claude Code's --effort,--max-budget-usd, and--fallback-modelon every iteration (each gated on CLI support and individual opt-out env vars) for better long-run unattended execution (v7.25.0). - Cross-project memory -- Episodic/semantic/procedural memory with vector search; knowledge learned on one project surfaces on the next (v5.15.0+, see
memory/engine.py) - Self-hosted and private -- Your keys, your infrastructure, no data leaves your network
- Legacy system healing --
loki modernize healarchaeology/stabilize/isolate/modernize/validate phases (v6.67.0, seeskills/healing.md) - MCP server -- 34 tools (including ChromaDB code search) plus 3 resources and 2 prompts (
mcp/server.py, with magic tools registered frommcp/magic_tools.pyand the managed-memory tool frommcp/managed_tools.py). Of the 34, 33 are always available;loki_memory_redactis registered but only succeeds whenLOKI_MANAGED_AGENTS=trueandLOKI_MANAGED_MEMORY=true. Launch withloki mcp(bootstraps the Python MCP SDK on first run). - Full-stack output -- Source code, tests, Docker Compose stacks (multi-service with healthchecks), CI/CD pipelines, audit logs
- Provider-agnostic -- runs on Claude, Codex, Cline, or Aider with automatic failover (
loki-ts/src/runner/providers.ts); no vendor lock-in. Gemini CLI deprecated v7.5.18. - Source-available (BUSL-1.1) -- Free for personal, internal, and academic use.
Get Started in 30 Seconds
bun install -g loki-mode # install (npm/brew/Docker also work, see below)
loki init my-app --template simple-todo-app # scaffold a starter PRD
cd my-app && loki start prd.md # autonomous build from the specThat is the happy path. One thing to know first: Loki drives a separate coding-agent CLI (Claude Code is the recommended one) and needs it plus a couple of common tools on your PATH. Run loki doctor any time and it tells you exactly what is present and what is missing, with a copy-pasteable install command for each gap.
loki doctor # check your setup before the first buildWhat Loki needs (and what loki doctor checks)
Required:
- An agent provider CLI: Claude Code (
claude, Tier 1, recommended and E2E-verified - the provider Loki Mode is built for). Codex, Cline, and Aider are supported as experimental providers (wiring in place; not yet E2E-verified by us). Loki cannot run a build without one of these installed and authenticated. - Python 3.10+ (
python3) for the dashboard, memory system, and orchestration helpers. - Git 2.x (
git) for checkpoints and worktrees. curlfor installation and network calls.
Recommended:
- Bun 1.3.0+ (
bun) for the fast runtime (the recommended install path above installs it). - Node.js 18+ and npm if you install via npm instead of Bun.
jqfor nicer JSON handling in shell flows.- Docker if you want Loki's App Runner to run containerized projects, or to run Loki itself from the published image.
You also need credentials for whichever provider you use (for Claude Code, an authenticated claude login or ANTHROPIC_API_KEY). loki doctor flags a missing or unauthenticated provider as the first thing to fix.
If you do not have Bun yet:
curl -fsSL https://bun.sh/install | bash # macOS / Linux (or: brew install oven-sh/bun/bun)Other spec sources work the same way:
loki start owner/repo#123 # a GitHub issue
loki start ./openapi.yaml # an OpenAPI/YAML specOr skip scaffolding and go straight to a quick task:
loki quick "build a landing page with a signup form"Other install methods (all work, all keep working):
| Method | Command | Notes |
|---|---|---|
| Bun (recommended) | bun install -g loki-mode |
Fastest startup for CLI commands. |
| Homebrew | brew tap asklokesh/tap && brew install loki-mode |
Auto-installs Bun as a dep |
| Docker (easiest) | loki docker start prd.md |
Host wrapper: runs loki in the published image with zero config. Bind-mounts the current folder so .loki state, resume, and continuity work exactly like local. Auto-detects auth (ANTHROPIC_API_KEY, else your host Claude Code login). Needs loki + Docker on the host. See DOCKER_README.md |
| Docker (raw) | docker pull asklokesh/loki-mode:7.58.1 && docker run --rm -e ANTHROPIC_API_KEY="$ANTHROPIC_API_KEY" asklokesh/loki-mode:7.58.1 start prd.md |
Bun + Claude CLI pre-installed; needs an API key, or use docker compose with a .env file, see DOCKER_README.md |
| npm (compat) | npm install -g loki-mode |
Works without Bun (bash fallback). Migrate any time with loki self-update --to bun. |
Upgrading:
loki self-update # upgrade in place via current manager
loki self-update --to bun # switch from npm/brew to Bun
loki self-update --check # show current install path + managerloki self-update auto-detects which package manager installed loki and runs the right upgrade. If you installed via npm and want to switch to Bun (recommended for v8.0.0 forward-compat), loki self-update --to bun does the migration in one command (installs via Bun first, then uninstalls the npm copy).
See the Installation Guide for the long form.
Runtime Architecture
Loki Mode runs a dual runtime by deliberate design: the battle-tested Bash engine is the stable core (the autonomous loop, quality gates, and completion council stay on it; it receives bug fixes and hardening), and new product surfaces are built TypeScript/Bun-first as modules that wrap the engine rather than reimplement it. An earlier plan to make v8 Bun-only has been superseded by this stable-engine approach: rewriting the verified trust layer would risk the exact guarantees this product exists to provide, for no capability gain. Bash support is not going away.
What ships today:
- Commands routed to the Bun runtime when
bunis onPATH(the router lives inbin/loki):version,--version,-v,status,stats,doctor,provider(coversprovider showandprovider list),memory(coversmemory listandmemory index),rollback,kpis, andinternal. - Every other command continues to execute on the existing Bash CLI (
autonomy/loki), including the autonomousloki start/loki runloop which remains the Bash orchestrator (autonomy/run.sh). - If
bunis not onPATH, the shim falls through to Bash silently. Existing users without Bun installed see no behavior change.
Rollback flag:
Force every command to take the legacy Bash path:
LOKI_LEGACY_BASH=1 loki <cmd>This is the documented escape hatch for any user who hits a regression on the Bun route. The Bash path remains the source of truth through Phase 5.
Phase 6 (planned, calendar TBD):
The next major release sunsets the Bash runtime entirely. There is no firm calendar date. Users who need to stay on the Bash route should pin the last v7.x release.
Cost:
- Adds a Bun runtime dependency (Bun 1.3.0 or newer recommended; the shim works as long as
bunresolves). - Adds a Bun toolchain to the system (Bun itself is roughly 50 MB installed via
brew installor the official curl installer). The publishedloki-ts/dist/loki.jsbundle inside the npm tarball is approximately 152 KB. - Speedup on the ported commands is measured in
.loki/metrics/migration_bench_soak.jsonland analysed in ADR-001. Recorded soak results show roughly 3x to 5x faster execution on the ported commands (per-command range 2.9x to 5.0x); treat as indicative, not contractual.
More:
- UPGRADING.md -- per-version upgrade and rollback guidance.
- ADR-001: Runtime Migration -- design rationale and phase definitions.
Other install methods
| Method | Command |
|---|---|
| Homebrew | brew tap asklokesh/tap && brew install loki-mode |
| Docker | docker pull asklokesh/loki-mode:7.58.1 |
| Inside Claude Code | claude --dangerously-skip-permissions then type "Loki Mode" |
| Git clone | git clone https://github.com/asklokesh/loki-mode.git |
See the full Installation Guide.
Supported spec formats
A "spec" is whatever you hand loki start. Loki auto-detects the format and normalises it before the RARV loop. A Markdown PRD is one form of spec; the table below lists every input the CLI accepts.
| Format | Example | Notes |
|---|---|---|
| Markdown PRD | loki start ./prd.md |
Canonical form. Headings become section anchors. |
| JSON spec | loki start ./spec.json |
Free-form JSON; keys surfaced to agents. |
| YAML spec | loki start ./openapi.yaml |
OpenAPI / AsyncAPI / plain YAML all accepted. |
| Plain text brief | loki start ./brief.txt |
One-paragraph briefs work; complexity auto-detects to "simple". |
| GitHub issue URL | loki start https://github.com/owner/repo/issues/42 |
Title + body + labels become the spec. |
| GitHub shorthand | loki start owner/repo#42 |
Same as above, shorter. |
| Jira ticket key | loki start PROJ-456 |
Requires JIRA_BASE_URL + JIRA_TOKEN env vars. |
| GitLab / Azure DevOps URL | loki start https://gitlab.com/group/proj/-/issues/7 |
GitLab and Azure DevOps issue URLs both supported. |
| Bare issue number | loki start #123 or loki start 123 |
Resolved against the current repo's origin remote. |
| OpenSpec change directory | loki start --openspec ./openspec/change-001 |
Reads OpenSpec change manifest + delta files. |
| Auto-detect (no input) | loki start |
Picks up ./prd.md, ./spec.{json,yaml,yml}, or ./SPEC.md from cwd. |
All formats land in the same RARV pipeline and pass the same 8 quality gates (skills/quality-gates.md).
What You Can Build
| Project | Build Time | Complexity |
|---|---|---|
| Landing page with signup form | ~10 min | Simple |
| REST API with JWT auth | ~20 min | Simple |
| Portfolio with animations | ~15 min | Simple |
| SaaS dashboard with analytics | ~25 min | Standard |
| E-commerce store with Stripe | ~45 min | Standard |
| Task manager with kanban board | ~25 min | Standard |
| Chat app with WebSocket | ~30 min | Standard |
| Blog platform with MDX | ~30 min | Standard |
| Microservice architecture | ~2 hours | Complex |
| ML pipeline with monitoring | ~3 hours | Complex |
What To Expect
| Simple | Standard | Complex | |
|---|---|---|---|
| Examples | Landing page, todo app, single API | CRUD + auth, REST API + React | Microservices, real-time, ML pipelines |
| Duration | 5-30 min | 30-90 min | 2+ hours |
| Autonomy | Completes independently | May need guidance on complex parts | Use as accelerator with human review |
Architecture
RARV CycleEvery iteration: Reason (read state) - Act (execute, commit) - Reflect (update context) - Verify (run tests, check spec). Failures trigger self-correction. |
41 Agent Roles8 domains: engineering, operations, business, data, product, growth, review, orchestration. These are prompt-defined role specifications the orchestrator adopts per phase, auto-composed by PRD complexity; parallelism comes from the blind review council, the adversarial reviewer, and optional git-worktree streams on Claude Code, sequential on other providers. |
8 Quality GatesStatic analysis, test suite (pass/fail), blind 3-reviewer code review with severity blocking, anti-sycophancy Devil's Advocate, mock-integrity detection, test-mutation detection, documentation coverage, and Magic Modules debate. Backward-compatibility is a conditional healing-mode auditor (not one of the 8). Code does not ship until all gates pass. |
Memory System3-tier architecture: episodic (interaction traces), semantic (generalized patterns), procedural (learned skills). Vector search optional. |
DashboardReal-time monitoring, agent status, task queue, WebSocket streaming, and Live App Preview (embedded iframe of the running app with Refresh/Open/Restart toolbar). Auto-starts at |
Enterprise LayerTLS, OIDC/SSO, RBAC, OTEL tracing, policy engine, audit trails. Activated via env vars. |
Purple Lab
[DEPRECATED in v7.44.0] Purple Lab (loki web, port 57375) is deprecated. The local build monitor and project dashboard are now the dashboard (auto-launched by loki start, http://localhost:57374). For the hosted/commercial platform, see Autonomi Cloud.
The historical feature set (platform pages, Monaco IDE workspace, AI chat panel) lives on in the dashboard and in Autonomi Cloud. loki web still invokes the old binary for backward compatibility but will be removed in a future major version.
Loki Mode vs. Alternatives
| Feature | Loki Mode | bolt.new | Replit | Lovable |
|---|---|---|---|---|
| Self-hosted / your keys | Yes | No | No | No |
| 5 AI provider failover | Yes | No | No | No |
| 8 quality gates | Yes | No | No | No |
| Blind code review | Yes | No | No | No |
| Enterprise auth (SSO/RBAC) | Yes | No | Yes | No |
| Air-gapped deployment | Yes | No | No | No |
| Docker + CI/CD generation | Yes | No | Yes | No |
| Source-available (BUSL-1.1) | Yes | No | No | No |
| Free tier | Source-available | Yes | Yes | Yes |
Loki Mode is the only platform that is fully self-hosted, source-available (BUSL-1.1), and includes automated quality verification. Your code, your keys, your infrastructure.
Provider-Agnostic Runtime
Loki's autonomy and quality loop are the product; the underlying coding CLI is swappable. Loki runs on any of the providers below so you are never locked to one vendor.
| Provider | Status | Autonomous Flag | Parallel Agents | Install |
|---|---|---|---|---|
| Claude Code | Active (Tier 1, E2E-verified) | --dangerously-skip-permissions |
Yes (10+) | npm i -g @anthropic-ai/claude-code |
| Codex CLI | Experimental (Tier 3) | --sandbox workspace-write --skip-git-repo-check |
Sequential | npm i -g @openai/codex |
| Cline CLI | Experimental (Tier 2) | -y |
Sequential | npm i -g @anthropic-ai/cline |
| Aider | Experimental (Tier 3) | --yes-always |
Sequential | pip install aider-chat |
| Google Gemini CLI | DEPRECATED v7.5.18 | -- | -- | Upstream deprecated; runtime removed. LOKI_PROVIDER=gemini exits with migration message. |
Status legend: "E2E-verified" means we run real spec-to-code builds on it ourselves. Claude Code is the primary, fully supported provider and the one Loki Mode is built for; it gets full features (subagents, parallelization, MCP, Task tool). "Experimental" means the wiring is in place but we have not produced an end-to-end verified build ourselves; treat as community-tested. Experimental providers run sequentially. Auto-failover switches providers when rate-limited. See Provider Guide.
CLI Reference
All commands
| Command | Description |
|---|---|
loki start [PRD] |
Start with optional PRD file (also accepts an issue ref; replaces deprecated loki run). Auto-opens the dashboard in the browser for interactive runs and passes native --effort/--max-budget-usd/--fallback-model for resilience (v7.25.0) |
loki stop |
Stop execution |
loki modernize heal <path> |
Legacy system healing (archaeology, stabilize, isolate, modernize, validate -- v6.67.0; was: loki heal) |
loki pause / resume |
Pause/resume after current session |
loki status |
Show current status |
loki dashboard |
Open web dashboard |
loki preview |
Print running app URL and open in browser (Live App Preview, v7.24.0; was: loki open) |
loki web |
Launch Purple Lab web UI [DEPRECATED in v7.44.0 -- use loki start which auto-opens the dashboard at http://localhost:57374; for the hosted platform see Autonomi Cloud] |
loki doctor |
Check environment and dependencies |
loki plan [PRD] |
Pre-execution analysis: complexity, cost, iterations |
loki review [--staged|--diff] |
AI-powered code review with severity filtering |
loki test [--file|--dir|--changed] |
AI test generation (8 languages, 9 frameworks) |
loki analyze onboard [path] |
Project analysis and CLAUDE.md generation (was: loki onboard) |
loki import |
Import GitHub issues as tasks |
loki ci |
CI/CD quality gate integration |
loki failover |
Cross-provider auto-failover management |
loki memory <cmd> |
Memory system: index, timeline, search, consolidate |
loki enterprise |
Enterprise feature management |
loki version |
Show version |
Run loki --help for all options. Full reference: CLI Reference | Config: config.example.yaml
Configuration env vars (intelligent defaults, opt-out knobs)
Loki Mode's accuracy and autonomy behaviors are default-on. Each is an opt-out escape hatch, not a setting you have to discover. The most relevant knobs from the v7.41.x accuracy/autonomy hardening:
| Env var | Default | Effect |
|---|---|---|
LOKI_REVIEW_INCONCLUSIVE_BLOCK |
1 |
Blocks completion when a code-review round returns zero usable verdicts (an all-empty review proves nothing). Set 0 to record the inconclusive result without blocking. |
LOKI_COMPLETION_TEST_CAPTURE |
1 |
Captures fresh test results before the verified-completion evidence gate evaluates. Set 0 to skip the pre-gate capture. |
LOKI_AUTO_DOCS |
true |
Generates the .loki/docs/ suite before the documentation gate scores it (bounded: once per run when docs are missing, and again only when >10 commits stale). Set false to opt out. |
LOKI_CAVEMAN |
1 (on) |
Output-token compressor for free-form generation only (never trust-gate subcalls). Set 0 to opt out. |
LOKI_CAVEMAN_LEVEL |
inferred | Compression level for the compressor. Auto-inferred per invocation from the run's RARV tier; set explicitly (lite / full / ultra) to override the inference. |
This is a subset. See the wiki for the full env-var reference and the RARV-C closure knobs (LOKI_INJECT_FINDINGS, LOKI_OVERRIDE_COUNCIL, LOKI_AUTO_LEARNINGS, LOKI_HANDOFF_MD).
BMAD Method Integration
Loki Mode integrates with the BMAD Method, a structured AI-driven agile methodology. If your project uses BMAD for requirements elicitation, Loki Mode can consume those artifacts directly:
loki start --bmad-project ./my-projectThe adapter handles BMAD's frontmatter conventions, FR-format functional requirements, Given/When/Then acceptance criteria, and artifact chain validation. Non-BMAD projects are unaffected -- the integration is opt-in via --bmad-project.
Enterprise Features
Enterprise features are included but require env var activation. Self-audit: 35/45 capabilities working, 0 broken, 1,314 tests passing.
export LOKI_TLS_ENABLED=true
export LOKI_OIDC_PROVIDER=google
export LOKI_AUDIT_ENABLED=true
loki enterprise statusEnterprise Architecture | Security | Authentication | Authorization | Metrics | Audit Logging
Benchmarks
Self-reported results from the included test harness. Verification scripts included for reproduction.
| Benchmark | Result | Notes |
|---|---|---|
| HumanEval | 162/164 (98.78%) | Self-reported; harness + results JSON in benchmarks/results/humaneval-loki-results.json. Max 3 retries, RARV self-verification. |
| SWE-bench | Not yet measured | Harness exists and generates patches, but the official SWE-bench evaluator has not been run, so there is no pass-rate to report. Run it yourself: ./benchmarks/run-benchmarks.sh swebench --execute |
See benchmarks/ for methodology.
Presentation

11 slides: Problem, Solution, 41 Agents, RARV Cycle, 8 Quality Gates (HumanEval 98.78%), Multi-Provider, Enterprise Hardening (Live App Preview), Full Lifecycle
Limitations
| Area | What Works | What Doesn't (Yet) |
|---|---|---|
| Code Gen | Full-stack apps from PRDs | Complex domain logic may need human review |
| Deploy | Generates configs, Dockerfiles, CI/CD | Does not deploy -- human runs deploy commands |
| Testing | 8 automated quality gates | Test quality depends on AI assertions |
| Providers | 5 providers with auto-failover | Non-Claude providers lack parallel agents |
| Dashboard | Real-time single-machine monitoring | No multi-node clustering |
What "autonomous" means: The system runs RARV cycles without prompting. It does NOT access your cloud accounts, payment systems, or external services unless you provide credentials. Human oversight is expected for deployment, API keys, and critical decisions.
Research Foundation
Papers and sources
| Source | What We Use |
|---|---|
| Anthropic: Building Effective Agents | Evaluator-optimizer, parallelization |
| Anthropic: Constitutional AI | Self-critique against quality principles |
| DeepMind: Scalable Oversight via Debate | Debate-based verification in council review |
| DeepMind: SIMA 2 | Self-improvement loop design |
| OpenAI: Agents SDK | Guardrails, tripwires, tracing |
| NVIDIA ToolOrchestra | Efficiency metrics, reward signals |
| CONSENSAGENT (ACL 2025) | Anti-sycophancy in blind review |
| GoalAct | Hierarchical planning for complex PRDs |
Practitioner insights: Boris Cherny, Simon Willison, HN Community
Full Acknowledgements -- 50+ papers and resources
Contributing
git clone https://github.com/asklokesh/loki-mode.git && cd loki-mode
npm install && npm test # CLI + Node test suites
python3 -m pytest # Python test suiteSee CONTRIBUTING.md for guidelines.
License
Business Source License 1.1 -- Free for personal, internal, academic, and non-commercial use. Converts to Apache 2.0 on March 19, 2030. Contact founder@autonomi.dev for commercial licensing.