XRPL training workbook — learn by doing, prove by artifact
Project description
日本語 | 中文 | Español | Français | हिन्दी | Italiano | Português (BR)
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.
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 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.jsonas 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-runfor 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
06d33a8aad83bccd55b24e94429df57ee51eefcf63499166709c6175dc491d1b
|
|
| MD5 |
3ae9028fec861d1c55ca8ea788a3135e
|
|
| BLAKE2b-256 |
969e3628c3f15ce77942496d0788ba23306601d444af9cc4345d241d1a2dd7ca
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xrpl_lab-1.6.0.tar.gz -
Subject digest:
06d33a8aad83bccd55b24e94429df57ee51eefcf63499166709c6175dc491d1b - Sigstore transparency entry: 1417276853
- Sigstore integration time:
-
Permalink:
mcp-tool-shop-org/xrpl-lab@29ce2c6109441f53325cd6fb5a5414b4457587d4 -
Branch / Tag:
refs/tags/v1.6.0 - Owner: https://github.com/mcp-tool-shop-org
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29ce2c6109441f53325cd6fb5a5414b4457587d4 -
Trigger Event:
release
-
Statement type:
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bcc020ca225c464284020efe86b7052beee894aef7a4bf475f9e35bf9db9d473
|
|
| MD5 |
cad0e61975b56c08b460d81d38fb0b53
|
|
| BLAKE2b-256 |
5e4fde296a2f2ef33a57e615cfb33383ed52bda204217bc3ba4cbe8a91a27df9
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xrpl_lab-1.6.0-py3-none-any.whl -
Subject digest:
bcc020ca225c464284020efe86b7052beee894aef7a4bf475f9e35bf9db9d473 - Sigstore transparency entry: 1417276876
- Sigstore integration time:
-
Permalink:
mcp-tool-shop-org/xrpl-lab@29ce2c6109441f53325cd6fb5a5414b4457587d4 -
Branch / Tag:
refs/tags/v1.6.0 - Owner: https://github.com/mcp-tool-shop-org
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29ce2c6109441f53325cd6fb5a5414b4457587d4 -
Trigger Event:
release
-
Statement type: