Bankr x402 SDK - Project Templates
SKILL.md
x402 SDK Project Templates
Directory structures and templates for Bankr SDK projects using x402 micropayments.
Available Templates
| Template | Use Case | Key Features |
|---|---|---|
| bot | Automated tasks | Polling loop, scheduler, transaction execution |
| web-service | HTTP APIs | REST endpoints, async handling, webhook support |
| dashboard | Web UIs | Frontend + backend, portfolio display |
| cli | Command-line tools | Subcommands, interactive prompts |
Bot Template
For automated trading bots, price monitors, portfolio rebalancers, and scheduled tasks.
Directory Structure
{project-name}/
├── package.json
├── tsconfig.json
├── .env.example
├── .gitignore
├── README.md
├── src/
│ ├── index.ts # Main entry point with scheduler
│ ├── bankr-client.ts # Bankr SDK client (from x402-client-patterns skill)
│ ├── executor.ts # Transaction execution with viem/ethers
│ ├── types.ts # TypeScript interfaces
│ └── config.ts # Configuration loading
└── scripts/
└── run.sh # Convenience script
Key Features
- Polling loop: Configurable interval for recurring operations
- Transaction execution: Built-in viem integration for sending txs
- Status streaming: Real-time job progress updates
- Error handling: Automatic retries with backoff
- Graceful shutdown: Handles SIGINT/SIGTERM
Use Cases
- Price monitoring and alerts
- Automated swap strategies
- Portfolio rebalancing
- Scheduled market analysis
- DCA-like automation
Entry Point Pattern (index.ts)
import { bankrClient } from "./bankr-client";
import { executeTransaction } from "./executor";
const INTERVAL = 60000; // 1 minute
async function runBot() {
console.log("Starting Bankr SDK bot...");
while (true) {
try {
const result = await bankrClient.promptAndWait({
prompt: "Check ETH price",
onStatusUpdate: (msg) => console.log("Status:", msg),
});
if (result.status === "completed") {
console.log("Result:", result.response);
// Execute transactions if returned
if (result.transactions?.length) {
for (const tx of result.transactions) {
await executeTransaction(tx);
}
}
}
} catch (error) {
console.error("Error:", error);
}
await new Promise((r) => setTimeout(r, INTERVAL));
}
}
runBot();
Web Service Template
For HTTP APIs that wrap Bankr SDK for mobile apps or integrations.
Directory Structure
{project-name}/
├── package.json
├── tsconfig.json
├── .env.example
├── .gitignore
├── README.md
├── src/
│ ├── index.ts # Server entry point
│ ├── server.ts # Express/Fastify server setup
│ ├── routes/
│ │ ├── health.ts # Health check endpoint
│ │ ├── swap.ts # Swap endpoints
│ │ └── portfolio.ts # Portfolio endpoints
│ ├── bankr-client.ts # Bankr SDK client
│ ├── types.ts # TypeScript interfaces
│ └── config.ts # Configuration loading
└── scripts/
└── run.sh
Key Features
- REST API endpoints: Clean API design
- Request validation: Input sanitization
- Async handling: Non-blocking SDK operations
- Rate limiting: Prevent abuse
- CORS: Cross-origin support
Use Cases
- API gateway for Bankr SDK
- Mobile app backend
- Trading API for integrations
- Webhook-driven automation
Additional Dependencies
{
"dependencies": {
"express": "^4.18.0"
}
}
Dashboard Template
For web UIs with portfolio tracking, swap interfaces, or monitoring.
Directory Structure
{project-name}/
├── package.json
├── tsconfig.json
├── .env.example
├── .gitignore
├── README.md
├── server/
│ ├── index.ts # Backend server
│ ├── bankr-client.ts # Bankr SDK client
│ ├── routes/
│ │ └── api.ts # API routes for frontend
│ └── types.ts
├── public/
│ ├── index.html # Main HTML page
│ ├── styles.css # Basic styles
│ └── app.js # Frontend JavaScript
└── scripts/
└── run.sh
Key Features
- Simple frontend: HTML/CSS/JS (no build step required)
- Backend API: Express server for SDK operations
- Portfolio display: Token balances and values
- Swap interface: Execute swaps through UI
Use Cases
- Portfolio tracking dashboard
- Personal trading interface
- Market monitoring
- Position management
CLI Template
For command-line tools with subcommands and interactive features.
Directory Structure
{project-name}/
├── package.json
├── tsconfig.json
├── .env.example
├── .gitignore
├── README.md
├── src/
│ ├── index.ts # CLI entry with commander.js
│ ├── commands/
│ │ ├── swap.ts # Swap commands
│ │ ├── balance.ts # Balance query commands
│ │ └── send.ts # Transfer commands
│ ├── bankr-client.ts # Bankr SDK client
│ ├── executor.ts # Transaction execution
│ └── types.ts
└── scripts/
└── run.sh
Key Features
- Commander.js: CLI framework with subcommands
- Interactive prompts: User input when needed
- Progress indicators: Status during SDK calls
- Colored output: Better UX
- Transaction confirmation: Review before execute
Use Cases
- Personal trading tool
- Scripting and automation
- Quick balance checks
- Batch swap operations
Additional Dependencies
{
"dependencies": {
"commander": "^12.0.0"
}
}
CLI Pattern (index.ts)
import { program } from "commander";
import { swap } from "./commands/swap";
import { balance } from "./commands/balance";
program
.name("bankr-cli")
.description("CLI for Bankr SDK operations")
.version("1.0.0");
program
.command("balance")
.description("Get wallet balances")
.action(balance);
program
.command("swap <amount> <from> <to>")
.description("Swap tokens")
.option("-c, --chain <chain>", "Target chain", "base")
.option("-y, --yes", "Skip confirmation")
.action(swap);
program.parse();
Choosing a Template
| Need | Recommended Template |
|---|---|
| Automated recurring tasks | bot |
| HTTP API for mobile/web | web-service |
| Visual interface | dashboard |
| Terminal-based tool | cli |
| Price alerts | bot |
| Portfolio viewer | dashboard |
| Quick trades | cli |
Common Files
All templates share common files. Load the x402-client-patterns skill for:
bankr-client.ts- SDK client setupexecutor.ts- Transaction executionpackage.json- Base dependenciestsconfig.json- TypeScript config.env.example- Environment template.gitignore- Standard ignores
Next Steps After Scaffolding
- Install dependencies:
bun installornpm install - Configure wallet: Copy
.env.exampleto.envand addBANKR_PRIVATE_KEY - Fund wallet: Add USDC on Base ($1-2 recommended for API costs)
- Customize: Modify the template for your use case
- Run:
bun devornpm run devfor development - Build:
bun run buildornpm run buildfor production