Install
openclaw skills install xpr-network-devComprehensive knowledge for XPR Network blockchain development - smart contracts, CLI, web SDK, DeFi, NFTs, and infrastructure
openclaw skills install xpr-network-devThis skill provides comprehensive knowledge for developing on XPR Network, a fast, gas-free blockchain with WebAuthn wallet support.
IMPORTANT DISCLAIMER: AI-Generated Smart Contract Code
Smart contracts handle real assets and are immutable once deployed. AI-generated code, including code produced with this skill, should always be reviewed by an experienced developer before deployment to mainnet.
- Test thoroughly on testnet before any mainnet deployment
- Have code reviewed by someone familiar with XPR Network/EOSIO smart contracts
- Audit critical contracts - consider professional security audits for contracts handling significant value
- Understand the code - don't deploy code you don't fully understand
Claude can accelerate development and help with patterns, but it does not replace proper code review, testing, and auditing practices.
XPR Network is an EOS-based blockchain optimized for payments and identity:
| Feature | Description |
|---|---|
| Speed | 0.5 second block times, 4000+ TPS |
| Fees | Zero gas fees for end users |
| Accounts | Human-readable names (1-12 chars, a-z, 1-5) |
| Wallets | WebAuthn support (Face ID, fingerprint, security keys) |
| Contracts | AssemblyScript/TypeScript with @proton/ts-contracts |
| Storage | On-chain tables with RAM-based pricing |
The blockchain was rebranded from Proton to XPR Network in 2024. You may see legacy references to "Proton" in:
@proton/cli, @proton/web-sdk, proton-tsc)XPRNetwork, formerly ProtonProtocol)explorer.xprnetwork.org, formerly protonscan.io and proton.bloks.io)The token symbol remains XPR and all functionality is unchanged.
| Network | Chain ID |
|---|---|
| Mainnet | 384da888112027f0321850a169f737c33e53b388aad48b5adace4bab97f437e0 |
| Testnet | 71ee83bcf52142d61019d95f9cc5427ba6a0d7ff8accd9e2088ae2abeaf3d3dd |
Load specialized modules based on your task:
| Module | Read When | Key Topics |
|---|---|---|
smart-contracts.md | Building contracts | Tables, actions, auth, build/deploy |
cli-reference.md | Using CLI tools | Network, keys, deploy, queries, transfers |
web-sdk.md | Building dApps | Wallet connect, transactions, sessions, transfers |
backend-patterns.md | Server-side dev | proton CLI keychain signing (v0.3.0+), bots, key isolation |
rpc-queries.md | Reading chain data | RPC, Hyperion API, Light API, pagination, token balances |
testing-debugging.md | Testing contracts | Unit tests, testnet, debugging, logs |
accounts-permissions.md | Account management | Create accounts, permissions, multisig |
staking-governance.md | Staking & voting | XPR staking, BPs, DPoS, resource model |
| Module | Read When | Key Topics |
|---|---|---|
token-creation.md | Creating tokens | Fungible tokens, issuance, vesting |
webauth-identity.md | User identity | WebAuth wallets, KYC, profiles, trust |
nfts-atomicassets.md | NFT development | Collections, schemas, minting, marketplace |
| Module | Read When | Key Topics |
|---|---|---|
metalx-dex.md | DEX integration | MetalX DEX API reference, order format, error codes |
defi-trading.md | Trading bots/DeFi | Trading bot patterns, swap pools, DeFi strategies |
simpledex.md | Token launch & AMM | SimpleDEX swaps, bonding curves, token creation, graduation |
loan-protocol.md | Lending protocol | LOAN protocol, supply, borrow, liquidations |
oracles-randomness.md | Price feeds & RNG | Oracle prices, verifiable random numbers |
| Module | Read When | Key Topics |
|---|---|---|
real-time-events.md | Live updates | Hyperion streaming, WebSockets, notifications |
payment-patterns.md | Commerce/payments | Payment links, invoicing, POS, subscriptions |
| Module | Read When | Key Topics |
|---|---|---|
node-operation.md | Running nodes | API nodes, Block Producers, validators |
| Module | Read When | Key Topics |
|---|---|---|
safety-guidelines.md | BEFORE modifying contracts | Table rules, deployment safety, recovery |
troubleshooting.md | Debugging errors | Common errors, solutions, diagnostics |
examples.md | Learning patterns | PriceBattle, ProtonWall, ProtonRating |
resources.md | Finding endpoints | RPC URLs, docs, explorers, community |
Read: safety-guidelines.md
# Install CLI
npm i -g @proton/cli
# Set network
proton chain:set proton # Mainnet
proton chain:set proton-test # Testnet
# Account info
proton account myaccount -t # With token balances
# Query table
proton table CONTRACT TABLE
# Execute action
proton action CONTRACT ACTION 'JSON_DATA' AUTHORIZATION
# Deploy contract
proton contract:set ACCOUNT ./assembly/target
import { JsonRpc } from '@proton/js';
const rpc = new JsonRpc('https://proton.eosusa.io');
const { rows } = await rpc.get_table_rows({
code: 'CONTRACT',
scope: 'CONTRACT',
table: 'TABLE',
limit: 100
});
import { Contract, Table, TableStore, Name, requireAuth } from 'proton-tsc';
@table("mydata")
class MyData extends Table {
constructor(
public id: u64 = 0,
public owner: Name = new Name(),
public value: string = ""
) { super(); }
@primary
get primary(): u64 { return this.id; }
}
@contract
class MyContract extends Contract {
dataTable: TableStore<MyData> = new TableStore<MyData>(this.receiver);
@action("store")
store(owner: Name, value: string): void {
requireAuth(owner);
const row = new MyData(this.dataTable.availablePrimaryKey, owner, value);
this.dataTable.store(row, this.receiver);
}
}
import '@proton/link'; // Required for mobile wallet support
import ProtonWebSDK from '@proton/web-sdk';
const { link, session } = await ProtonWebSDK({
linkOptions: {
chainId: '384da888112027f0321850a169f737c33e53b388aad48b5adace4bab97f437e0',
endpoints: ['https://proton.eosusa.io']
},
selectorOptions: { appName: 'My App' }
});
// session.auth contains { actor, permission }
// Use session.transact() for transactions
| Package | Purpose | Install |
|---|---|---|
@proton/cli | Command-line tools | npm i -g @proton/cli |
proton-tsc | Contract development | npm i proton-tsc |
@proton/web-sdk | Frontend wallet integration | npm i @proton/web-sdk |
@proton/link | Mobile wallet transport (required with web-sdk) | npm i @proton/link |
@proton/js | RPC queries | npm i @proton/js |
"") — any other memo (e.g. "deposit") causes permanent, irrecoverable fund loss. See metalx-dex.md.333555) cause silent data loss in get_table_rows — see rpc-queries.md for workarounds.