Skip to main content

XRPL training workbook — learn by doing, prove by artifact

Project description

日本語 | 中文 | Español | Français | हिन्दी | Italiano | Português (BR)

XRPL Lab

CI MIT License Landing Page

XRPL training workbook — learn by doing, prove by artifact.

Each module teaches one XRPL skill and produces a verifiable artifact: a transaction ID, a signed receipt, or a diagnostic report. No accounts, no fluff, no cloud — just competence and receipts.

XRPL Lab dashboard showing 11/12 modules completed with quick actions and status panels

Install

pipx install xrpl-lab

Or with pip:

pip install xrpl-lab

Requires Python 3.11+.

Quickstart

xrpl-lab start

The guided launcher walks you through wallet setup, funding, and your first module.

Offline mode

xrpl-lab start --dry-run

No network required. Simulated transactions for learning the workflow.

Modules

12 modules across five tracks: Foundations, DEX, Reserves, Audit, and AMM. Prerequisites are explicit — the CLI and linter enforce them.

# Module Track Mode What you learn What you prove
1 Receipt Literacy foundations testnet Finality is a receipt, not a "sent" status — send a payment, read every receipt field txid + verification report
2 Failure Literacy foundations testnet XRPL errors have semantics (tec/tef/tem/ter) — break a tx on purpose, diagnose, fix, resubmit failed + fixed txid trail
3 Trust Lines 101 foundations testnet Tokens are opt-in and directional — create issuer, set trust line, issue tokens trust line + token balance
4 Debugging Trust Lines foundations testnet Decode trust line error codes — intentional failure, error decode, fix error → fix txid trail
5 DEX Literacy dex testnet Order books pair makers with takers — create offers, read order books, cancel offer create + cancel txids
6 Reserves 101 reserves testnet Every owned object locks XRP — snapshots, owner count, reserve math before/after snapshot delta
7 Account Hygiene reserves testnet Cleanup is a first-class skill — cancel offers, remove trust lines, free reserves cleanup verification report
8 Receipt Audit audit testnet Audits encode intent (txid + expectation + verdict) — batch verify with expectations audit pack (MD + CSV + JSON)
9 AMM Liquidity 101 amm dry-run Constant product (x*y=k) prices passively — create pool, deposit, earn LP, withdraw AMM lifecycle txids
10 DEX Market Making 101 dex testnet Bid/ask spreads track inventory — quote both sides, snapshot positions, clean up strategy txids + hygiene report
11 Inventory Guardrails dex testnet Quote only the safe side when inventory tilts — threshold-based, guarded placement inventory check + guarded txids
12 DEX vs AMM Risk Literacy amm dry-run Impermanent loss is a property of the AMM model — DEX and AMM lifecycle side by side comparison report + audit trail

Tracks

  • foundations — wallet, payments, trust lines, error handling
  • dex — offers, order books, market making, inventory management
  • reserves — account reserves, owner count, cleanup
  • audit — batch verification, audit reports
  • amm — automated market maker liquidity, DEX vs AMM comparison

Modes

  • testnet — real transactions on the XRPL Testnet
  • dry-run — offline sandbox with simulated transactions (no network required)

Commands

xrpl-lab start              Guided launcher
xrpl-lab list               Show all modules with status and progression
xrpl-lab run <module_id>    Run a specific module
xrpl-lab status [--json]    Progress, curriculum position, blockers, track progress
xrpl-lab cohort-status [--dir DIR] [--format FORMAT]  Aggregate per-learner status across a cohort directory (facilitator)
xrpl-lab session-export [--dir DIR] [--format FORMAT] [--outfile FILE]  Archive all learner artifacts with a SHA-256 manifest
xrpl-lab tracks             Track-level completion summaries
xrpl-lab recovery           Diagnose stuck states, show recovery commands
xrpl-lab lint [glob] [--json] [--no-curriculum]  Validate module files and curriculum
xrpl-lab proof-pack         Export shareable proof pack
xrpl-lab certificate        Export completion certificate
xrpl-lab doctor             Run diagnostic checks
xrpl-lab self-check         Alias for doctor
xrpl-lab feedback           Generate support bundle (markdown)
xrpl-lab support-bundle [--json] [--verify FILE]  Generate or verify support bundles
xrpl-lab audit              Batch verify transactions
xrpl-lab last-run           Show last module run + audit command
xrpl-lab serve [--port N] [--host H] [--dry-run]  Start web dashboard and API server
xrpl-lab reset [--module MODULE_ID]  Wipe local state OR reset a single module (requires confirmation)
xrpl-lab module init --id ID --track TRACK --title TITLE --time TIME  Scaffold a lint-passing module skeleton

xrpl-lab wallet create      Create a new wallet
xrpl-lab wallet show        Show wallet info (no secrets)
xrpl-lab fund               Fund wallet from testnet faucet
xrpl-lab send --to <address> --amount <xrp> [--memo <text>]  Send a payment
xrpl-lab verify --tx <id>   Verify a transaction on-ledger

All commands support --dry-run for offline mode where applicable.

Workshop Use

XRPL Lab is designed for real teaching settings. No accounts, no telemetry, no cloud. Everything runs locally.

Facilitator dashboard listing active learner runs with module IDs, dry-run badges, status, queue depth, and run IDs

Facilitator status

xrpl-lab status             # Where is this learner? What's blocked? What's next?
xrpl-lab status --json      # Machine-readable for scripting
xrpl-lab tracks             # Track-level completion: what was actually practiced
xrpl-lab recovery           # Stuck? See exactly what to run next

Support handoff

xrpl-lab support-bundle              # Human-readable markdown bundle
xrpl-lab support-bundle --json       # Machine-parseable JSON
xrpl-lab support-bundle --verify bundle.json  # Verify a received bundle

A facilitator can diagnose any learner's issue from a support bundle without reproducing the whole session. No secrets are included.

Workshop flows

All-offline sandbox — no network required:

xrpl-lab wallet create
xrpl-lab start --dry-run

Mixed offline + testnet — real transactions for basics, sandbox for advanced:

xrpl-lab wallet create
xrpl-lab fund
xrpl-lab start

Camp → Lab progression — continue from xrpl-camp:

xrpl-lab start    # auto-detects camp wallet and certificate

Artifacts

Proof pack (xrpl_lab_proof_pack.json): Shareable record of completed modules, transaction IDs, and explorer links. Includes a SHA-256 integrity hash. No secrets.

Certificate (xrpl_lab_certificate.json): Slim completion record.

Reports (reports/*.md): Human-readable summaries of what you did and proved.

Audit packs (audit_pack_*.json): Batch verification results with SHA-256 integrity hash.

Security and Trust Model

Data XRPL Lab touches:

  • Wallet seed (stored locally in ~/.xrpl-lab/wallet.json as plaintext JSON, protected by 0o600 file permissions and a 0o700 parent directory — not encrypted)
  • Module progress and transaction IDs (stored in ~/.xrpl-lab/state.json, atomic writes via tmp + rename)
  • XRPL Testnet RPC (public endpoint, transactions signed locally before submission)
  • Testnet faucet (public HTTP, only your address is sent)

Data XRPL Lab does NOT touch:

  • No mainnet. Testnet only
  • No telemetry, analytics, or phone-home of any kind
  • No cloud accounts, no registration, no third-party APIs
  • No secrets in proof packs, certificates, reports, or support bundles — ever

Permissions and storage tiers:

  • Home ~/.xrpl-lab/ — private secrets tier, 0o700 directory + 0o600 wallet file. Stores wallet seed, doctor log, audit packs.
  • Workspace ./.xrpl-lab/ — designed-shareable tier, 0o755 directory. Stores module reports, proof packs, certificates. Facilitators can review without permission elevation.
  • Filesystem: reads/writes only the two locations above
  • Network: XRPL Testnet RPC + faucet only (both overridable via env vars, both optional with --dry-run)
  • No elevated permissions required

Dashboard surface (when xrpl-lab serve is running):

  • WebSocket runner endpoint enforces an Origin allow-list (closes non-allow-listed connections with code 4003)
  • All error frames emit a structured envelope (code, message, hint, severity, icon_hint) — no path leakage, no internal-state leakage
  • Bounded per-connection message queue with documented back-pressure behavior

See SECURITY.md for the full security policy and workshop-setup guidance.

Requirements

  • Python 3.11+
  • Internet connection for testnet (or use --dry-run for fully offline mode)

License

MIT

Built by MCP Tool Shop

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

xrpl_lab-1.6.0.tar.gz (867.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xrpl_lab-1.6.0-py3-none-any.whl (147.5 kB view details)

Uploaded Python 3

File details

Details for the file xrpl_lab-1.6.0.tar.gz.

File metadata

  • Download URL: xrpl_lab-1.6.0.tar.gz
  • Upload date:
  • Size: 867.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for xrpl_lab-1.6.0.tar.gz
Algorithm Hash digest
SHA256 06d33a8aad83bccd55b24e94429df57ee51eefcf63499166709c6175dc491d1b
MD5 3ae9028fec861d1c55ca8ea788a3135e
BLAKE2b-256 969e3628c3f15ce77942496d0788ba23306601d444af9cc4345d241d1a2dd7ca

See more details on using hashes here.

Provenance

The following attestation bundles were made for xrpl_lab-1.6.0.tar.gz:

Publisher: publish-pypi.yml on mcp-tool-shop-org/xrpl-lab

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file xrpl_lab-1.6.0-py3-none-any.whl.

File metadata

  • Download URL: xrpl_lab-1.6.0-py3-none-any.whl
  • Upload date:
  • Size: 147.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for xrpl_lab-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bcc020ca225c464284020efe86b7052beee894aef7a4bf475f9e35bf9db9d473
MD5 cad0e61975b56c08b460d81d38fb0b53
BLAKE2b-256 5e4fde296a2f2ef33a57e615cfb33383ed52bda204217bc3ba4cbe8a91a27df9

See more details on using hashes here.

Provenance

The following attestation bundles were made for xrpl_lab-1.6.0-py3-none-any.whl:

Publisher: publish-pypi.yml on mcp-tool-shop-org/xrpl-lab

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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