AgentSkillsCN

Bankr x402 SDK - Project Templates

当用户询问“搭建 Bankr SDK 项目”“创建新的 SDK 机器人”“构建 Bankr Web 服务”“创建 Bankr 控制面板”“构建 Bankr CLI 工具”“SDK 项目的目录结构”“x402 项目类型”或需要不同类型的 Bankr SDK 集成的目录结构与模板指导时,应使用此技能。

SKILL.md
--- frontmatter
name: Bankr x402 SDK - Project Templates
description: This skill should be used when the user asks to "scaffold a Bankr SDK project", "create new SDK bot", "build a Bankr web service", "create Bankr dashboard", "build Bankr CLI tool", "project structure for SDK", "x402 project types", or needs guidance on directory structures and templates for different types of Bankr SDK integrations.
version: 1.0.0

x402 SDK Project Templates

Directory structures and templates for Bankr SDK projects using x402 micropayments.

Available Templates

TemplateUse CaseKey Features
botAutomated tasksPolling loop, scheduler, transaction execution
web-serviceHTTP APIsREST endpoints, async handling, webhook support
dashboardWeb UIsFrontend + backend, portfolio display
cliCommand-line toolsSubcommands, interactive prompts

Bot Template

For automated trading bots, price monitors, portfolio rebalancers, and scheduled tasks.

Directory Structure

code
{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)

typescript
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

code
{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

json
{
  "dependencies": {
    "express": "^4.18.0"
  }
}

Dashboard Template

For web UIs with portfolio tracking, swap interfaces, or monitoring.

Directory Structure

code
{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

code
{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

json
{
  "dependencies": {
    "commander": "^12.0.0"
  }
}

CLI Pattern (index.ts)

typescript
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

NeedRecommended Template
Automated recurring tasksbot
HTTP API for mobile/webweb-service
Visual interfacedashboard
Terminal-based toolcli
Price alertsbot
Portfolio viewerdashboard
Quick tradescli

Common Files

All templates share common files. Load the x402-client-patterns skill for:

  • bankr-client.ts - SDK client setup
  • executor.ts - Transaction execution
  • package.json - Base dependencies
  • tsconfig.json - TypeScript config
  • .env.example - Environment template
  • .gitignore - Standard ignores

Next Steps After Scaffolding

  1. Install dependencies: bun install or npm install
  2. Configure wallet: Copy .env.example to .env and add BANKR_PRIVATE_KEY
  3. Fund wallet: Add USDC on Base ($1-2 recommended for API costs)
  4. Customize: Modify the template for your use case
  5. Run: bun dev or npm run dev for development
  6. Build: bun run build or npm run build for production