The official CLI for the AGLedger API — accountability infrastructure for AI agents. The Layer 3 accountability layer of the agent stack.
A thin cover over the API. The CLI passes your request straight through to the API and forwards the response — no hand-coded per-endpoint wrappers, no flag-to-body translation, no drift. Every AGLedger API route is reachable via agledger api <METHOD> <path>.
Learn more
- agledger.ai — what AGLedger is and why Layer 3 accountability matters
- How it works — the four-endpoint lifecycle: record, completion, verdict, fulfill
- Glossary — canonical definitions of Record, Completion, SCITT Receipt, Verdict, Settlement Signal
- API reference — every endpoint the CLI covers
- Documentation — installation and integration guides
npm install -g @agledger/cliexport AGLEDGER_API_KEY=agl_adm_...
export AGLEDGER_API_URL=https://your-agledger-instance
# Check health, identity, scopes, and get the quickstart workflow
agledger discover
# List Record types
agledger api GET /v1/schemas
# Create a record (raw JSON body). Types are customer-registered; a fresh org
# is seeded with `notarize-generic-v1` (and 3 other editable samples).
# `criteria` is validated against the JSON Schema you registered for the type.
agledger api POST /v1/records --data '{
"type": "notarize-generic-v1",
"criteria": { "task_description": "summarize Q3 filings" }
}'
# Or build the body with typed fields
agledger api POST /v1/records \
-F type=notarize-generic-v1 \
-F criteria.task_description='summarize Q3 filings'
# Submit a completion. On a gated record the principal then renders a Verdict
# (accept / reject) on the Completion — use the route documented in the API
# (see `agledger api GET /openapi.json`).
agledger api POST /v1/records/<record-id>/completions \
--data '{"evidence":{"summary":"delivered 500x copper wire","evidenceUrl":"https://orders.example.com/CW-500"}}'- Zero drift. When the API adds, renames, or removes a route, the CLI keeps working — no code change required.
- One mental model. The API docs are the CLI docs. What you read in the OpenAPI spec is what you type.
- All 250+ routes on day one. You get full parity, not a hand-picked subset.
| Flag | When to use |
|---|---|
--data '{...}' |
Agent-friendly: one JSON string |
--input file.json |
Complex payloads; reuse files |
--input - |
Pipe JSON from stdin |
-F key=value (repeatable) |
Shell-friendly; typed (true/false/null/numbers); nested via a.b=v; arrays via arr[]=v; JSON literals via k={...} / k=[...] |
Merging order (low → high): --data → --input → -F → --query. Later sources override earlier keys.
--jsonon every command (auto when stdout is piped)--quietsuppresses output (exit code only)--dry-runonagledger apishows the request without sending--paginateon GET follows cursor pagination and streams NDJSON- Structured errors on stderr:
{error: true, code, message, suggestion, ...}— API errors pass through verbatim - Semantic exit codes: 0 (OK), 2 (usage), 3 (auth), 4 (forbidden), 5 (not found), 6 (conflict), 7 (rate limit), 8 (server), 9 (network), 10 (timeout)
NO_COLORsupported per no-color.org
agledger list-commands --json # 10 CLI-local commands
agledger help-json api --json # Schema for `api` (args + flags)
agledger discover # Health + identity + quickstart
agledger api GET /openapi.json # Full API route catalog| Command | Purpose |
|---|---|
api |
Call any API endpoint |
discover |
Health + identity + scopes + quickstart |
login |
Verify API key, store in ~/.agledger/config.json (0600) |
logout |
Remove profile(s) |
auth |
Check current login state (exit 0 either way) |
config |
list / get / use <profile> / path |
verify |
Offline audit export verification (COSE_Sign1 + Ed25519, RFC 9052, no network) |
docs |
Fetch the API's agent-oriented narrative (llms.txt / --full) |
list-commands |
Inventory (this list) |
help-json |
Per-command schema |
# Verifies the key against the API, then stores it under ~/.agledger/config.json (0600)
agledger login --api-key agl_adm_... --profile prod
# Switch the active profile — subsequent commands use its key automatically
agledger config use prod
# Run a one-off against a specific stored profile
agledger api GET /v1/records --profile prod
# Or pass credentials per-invocation via env or flags (no stored profile needed)
AGLEDGER_API_KEY=... AGLEDGER_API_URL=... agledger api GET /v1/recordsCredential precedence (highest first) — applied per command:
- API key:
--api-keyflag →AGLEDGER_API_KEYenv → stored profile (--profile <name>, else the active profile). - API URL:
--api-urlflag →AGLEDGER_API_URLenv → stored profile URL → default.
So once you agledger login, plain agledger api ... calls authenticate from the stored profile with no flags or env. --dry-run echoes the resolved auth (URL, source, masked key) so you can confirm which credentials a call would use without sending it.
Agent keys (agl_agt_*) and admin keys (agl_adm_*) are both accepted — the API routes them appropriately.
- Node.js >= 24.0.0
- A running AGLedger API instance
Proprietary. Copyright (c) 2026 AGLedger LLC. All rights reserved. See LICENSE.