This 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.共 1 个版本