clankerkit

Autonomous wallet operations for AI agents on Monad — swap, stake, deploy wallets, trade memecoins, and manage spending policies via natural language.

Safety Notice

This item is sourced from the public archived skills repository. Treat as untrusted until reviewed.

Copy this and send it to your AI assistant to learn

Install skill "clankerkit" with this command: npx skills add 0xsoydev/clankerkit

ClankerKit - Autonomous Wallet for AI Agents on Monad

ClankerKit gives your AI agent autonomous financial capabilities on Monad blockchain. Deploy a smart contract wallet, set spending policies, swap tokens via Kuru DEX, stake MON, trade memecoins with strategies, and execute cross-chain swaps.

Quick Start

# Install the skill
claw skill install clankerkit

Environment Variables

VariableRequiredDescription
AGENT_WALLET_ADDRESSYesDeployed AgentWallet contract address
POLICY_ENGINE_ADDRESSYesDeployed PolicyEngine contract address
AGENT_PRIVATE_KEYYesAgent's private key (with 0x prefix)
OWNER_ADDRESSYesHuman owner address
MONAD_RPC_URLNoMonad RPC URL (default: testnet)
MONAD_NETWORKNotestnet or mainnet (default: testnet)
ZEROX_API_KEYNo0x Swap API key (only for zerox_swap)

Tools (32 total)

Wallet Management

get_wallet_info

Get wallet address, owner, agent, MON balance, and policy state.

get_token_balance

Get ERC-20 token balance of the agent wallet.

  • token: Token symbol (WMON, USDC, CHOG, DAK, YAKI) or contract address

send_tokens

Send native MON tokens from the wallet.

  • to: Recipient address
  • amount: Amount in human-readable form (e.g. "0.5")

send_token

Send ERC-20 tokens from the wallet.

  • token: Token contract address
  • to: Recipient address
  • amount: Amount in human-readable form

execute_transaction

Execute an arbitrary contract call via the wallet.

  • target: Target contract address
  • value: Native MON to send (wei, default "0")
  • data: Encoded calldata (hex)

ensure_gas

Ensure the agent EOA has enough MON for gas fees. If the EOA balance is below the minimum threshold, automatically sends MON from the AgentWallet contract to the EOA. Users only need to fund the wallet contract — the agent tops up its own gas from there.

  • minBalance: Minimum acceptable EOA balance in MON (human-readable, default "0.01")
  • topUpAmount: Amount of MON to send to EOA if below minimum (human-readable, default "0.05")

Policy & Security

get_policy

View current spending limits (daily/weekly), usage, and allowlists.

create_policy

Create a spending policy. Must be called once before guarded transactions work.

  • dailyLimit: Max MON per day (human-readable, e.g. "1.0")
  • weeklyLimit: Max MON per week (defaults to 7x daily)
  • allowedTokens: Optional ERC-20 address allowlist
  • allowedContracts: Optional contract address allowlist
  • requireApprovalAbove: MON threshold for owner approval

update_daily_limit

Update the daily spending limit.

  • newLimit: New limit in human-readable MON

Token Swaps (Kuru DEX)

swap_tokens

Swap tokens on Monad via Kuru Flow aggregator. Accepts symbols (MON, USDC, WMON, CHOG, DAK, AUSD, WETH, WBTC) or contract addresses.

  • tokenIn: Source token (symbol or address)
  • tokenOut: Destination token (symbol or address)
  • amount: Human-readable amount (e.g. "0.01")
  • slippage: Slippage in bps (default: 50 = 0.5%)

get_swap_quote

Get a swap quote without executing.

  • tokenIn, tokenOut, amount: Same as swap_tokens

Staking

stake_mon

Stake MON with a validator to earn rewards.

  • amount: MON to stake (human-readable)
  • validatorId: Validator ID (optional, uses default)

unstake_mon

Begin unstaking MON from a validator.

  • amount: MON to unstake (human-readable)
  • validatorId: Validator ID (optional)
  • withdrawId: Withdrawal ID (default: 0)

withdraw_stake

Withdraw unstaked MON after the 1-epoch delay.

  • validatorId, withdrawId: Optional

claim_staking_rewards

Claim accumulated staking rewards.

  • validatorId: Optional

compound_rewards

Re-stake accumulated rewards.

  • validatorId: Optional

get_staking_info

Get delegation info (staked amount, unclaimed rewards).

  • validatorId: Optional

Kuru CLOB Orderbook Trading

get_kuru_markets

List known Kuru CLOB orderbook markets on Monad mainnet.

get_order_book

Fetch live L2 order book (bids/asks) for a Kuru CLOB market.

  • marketAddress: Orderbook contract address

get_market_price

Get best bid, ask, and mid price for a Kuru CLOB market.

  • marketAddress: Orderbook contract address

kuru_market_order

Place a market (IOC) order on a Kuru CLOB market. Agent EOA must hold tokens.

  • marketAddress: Orderbook contract address
  • amount: Human-readable float
  • isBuy: true for buy, false for sell
  • minAmountOut: Minimum output (default: 0)
  • slippageBps: Slippage in bps (default: 100)

kuru_limit_order

Place a limit (GTC) order on a Kuru CLOB market.

  • marketAddress: Orderbook contract address
  • price: Price in quote asset (float)
  • size: Size in base asset (float)
  • isBuy: true for bid, false for ask
  • postOnly: Reject if it crosses spread (default: false)

cancel_kuru_orders

Cancel open orders on a Kuru CLOB market.

  • marketAddress: Orderbook contract address
  • orderIds: Array of order ID strings

Memecoin Trading

get_meme_tokens

Get live price metrics for all known Monad memecoins (DAK, CHOG, YAKI). Uses CLOB orderbooks with Kuru Flow fallback.

get_token_price

Get live price for a specific token by symbol or contract address.

  • token: Symbol (DAK, CHOG, YAKI) or contract address

smart_trade

Evaluate or execute an autonomous trading strategy.

  • token: Token symbol
  • strategyType: dca, momentum, scalp, or hodl
  • budgetMon: Total budget in MON
  • stopLoss: Stop-loss fraction (default: 0.1 = -10%)
  • takeProfit: Take-profit fraction (default: 0.3 = +30%)
  • dcaIntervals: Number of DCA buys (default: 5)
  • momentumThreshold: Min 24h change for momentum (default: 0.05)
  • autoExecute: Execute trades or dry-run (default: false)

Cross-Chain Swaps

kyber_swap

Swap on Ethereum/Polygon/Arbitrum/Optimism/Base/BSC/Avalanche via KyberSwap. No API key needed. Uses agent EOA (not wallet contract).

  • chain: Target chain name
  • tokenIn, tokenOut: Token addresses on target chain
  • amountIn: Amount in smallest unit (wei)
  • slippageBps: Slippage (default: 50)
  • recipient: Recipient address (default: agent EOA)

zerox_swap

Swap via 0x Swap API v2. Requires ZEROX_API_KEY.

  • chain, tokenIn, tokenOut, amountIn, slippageBps: Same as kyber_swap

Payments & Identity

pay_for_service

Pay for an x402-enabled API endpoint.

  • endpoint: API endpoint URL
  • amount: Payment in USDC

register_agent

Register on ERC-8004 identity registry.

  • name: Agent name
  • description: Agent description

Deployment

deploy_policy_engine

Deploy a new PolicyEngine contract. The deployer becomes the owner. No parameters needed.

deploy_agent_wallet

Deploy a new AgentWallet contract. Optionally deploys PolicyEngine too.

  • owner: Address that owns the wallet
  • agent: Agent EOA address allowed to call execute()
  • policyEngine: Optional existing PolicyEngine address

Security Features

  • Spending Limits: Daily and weekly caps on agent spending
  • Token Allowlists: Restrict which tokens the agent can transfer
  • Contract Whitelists: Only allow calls to approved contracts
  • Approval Thresholds: Require human approval above certain amounts
  • Emergency Controls: Owner can pause or withdraw funds anytime
  • Access Control: PolicyEngine recordExecution() only callable by the wallet contract

Example Session

User: Check my gas and fund up if needed

Agent: [calls ensure_gas]
EOA already has sufficient gas balance. EOA: 0.221 MON, Wallet: 0.075 MON.

User: Set a daily limit of 2 MON

Agent: [calls create_policy with dailyLimit="2.0"]
Policy created: 2 MON daily, 14 MON weekly.

User: Swap 0.1 MON for CHOG

Agent: [calls swap_tokens with tokenIn="MON", tokenOut="CHOG", amount="0.1"]
Swapped 0.1 MON -> 2.71 CHOG via Kuru Flow.

User: What's my portfolio?

Agent: [calls get_wallet_info, get_meme_tokens, get_staking_info]
Wallet: 1.9 MON
CHOG: 2.71 (worth ~0.1 MON)
Staked: 0.5 MON with validator #1

License

MIT

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Web3

tcm-constitution-recognition-analysis

Determines nine TCM constitution types including Yin deficiency, Yang deficiency, Qi deficiency, phlegm-dampness, and blood stasis through facial features and physical signs, and provides personalized health preservation and conditioning suggestions. | 中医体质识别分析技能,通过面部特征与体征判别阴虚、阳虚、气虚、痰湿、血瘀等九种中医体质类型,给出个性化养生调理建议

Archived SourceRecently Updated
Web3

0xarchive

Query historical crypto market data from 0xArchive across Hyperliquid, Lighter.xyz, and HIP-3. Covers orderbooks, trades, candles, funding rates, open interest, liquidations, and data quality. Use when the user asks about crypto market data, orderbooks, trades, funding rates, or historical prices on Hyperliquid, Lighter.xyz, or HIP-3.

Archived SourceRecently Updated
Web3

E2E Test Recorder

# Screen Recorder Demo Skill ## 概述 基于 Puppeteer 的自动化端到端测试录制 Skill,支持录制浏览器操作并生成演示视频/GIF。 ## 功能特性 ### 核心功能 - 🎥 **浏览器操作录制**:录制网页操作过程 - 🎯 **智能区域录制**:支持全屏或指定区域录制 - 🔄 **格式转换**:支持 MP4、GIF、WebM 格式 - ⚡ **自动化测试集成**:与测试框架无缝集成 ### 高级功能 - 📊 **性能监控**:录制时显示FPS和文件大小 - 🎨 **视频编辑**:添加水印、字幕、片头片尾 - 🔧 **配置灵活**:支持多种录制参数配置 - 📱 **跨平台**:支持 Windows、macOS、Linux ## 安装要求 ### 系统要求 - Node.js 16+ - npm 或 yarn - Chrome/Chromium 浏览器 ### 依赖安装 ```bash npm install puppeteer puppeteer-screen-recorder ffmpeg-static # 或 yarn add puppeteer puppeteer-screen-recorder ffmpeg-static ``` ## 快速开始 ### 1. 基础录制 ```javascript const { ScreenRecorder } = require('./scripts/record-browser'); const recorder = new ScreenRecorder({ outputPath: './recordings/demo.mp4', fps: 30, quality: 80 }); await recorder.startRecording('https://your-app.com'); // 执行操作... await recorder.stopRecording(); ``` ### 2. 端到端测试录制 ```javascript const { recordE2ETest } = require('./scripts/record-test'); await recordE2ETest({ url: 'http://localhost:3000', testSteps: [ { action: 'click', selector: '#login-btn' }, { action: 'type', selector: '#username', text: 'testuser' }, { action: 'type', selector: '#password', text: 'password123' }, { action: 'click', selector: '#submit-btn' } ], output: './recordings/login-test.mp4' }); ``` ## API 文档 ### ScreenRecorder 类 #### 构造函数 ```javascript new ScreenRecorder(options) ``` **options**: - `outputPath` (string): 输出文件路径 - `fps` (number): 帧率,默认 30 - `quality` (number): 视频质量 0-100,默认 80 - `aspectRatio` (string): 宽高比,如 '16:9' - `codec` (string): 视频编码器,默认 'libx264' #### 方法 - `startRecording(url, options)`: 开始录制 - `stopRecording()`: 停止录制 - `pauseRecording()`: 暂停录制 - `resumeRecording()`: 恢复录制 - `addAnnotation(text, position)`: 添加标注 - `addWatermark(imagePath, position)`: 添加水印 ### 工具函数 #### recordE2ETest(config) 录制端到端测试过程 **config**: - `url` (string): 测试页面URL - `testSteps` (Array): 测试步骤数组 - `output` (string): 输出文件路径 - `headless` (boolean): 是否无头模式,默认 false #### convertVideo(input, output, options) 视频格式转换 #### mergeVideos(videos, output) 合并多个视频文件 ## 配置示例 ### 基础配置 ```json { "recorder": { "fps": 30, "quality": 80, "outputDir": "./recordings", "defaultFormat": "mp4" }, "browser": { "headless": false, "viewport": { "width": 1920, "height": 1080 }, "slowMo": 50 }, "annotations": { "enabled": true, "fontSize": 24, "fontColor": "#ffffff", "backgroundColor": "#00000080" } } ``` ### 测试配置 ```json { "testSuites": { "login": { "url": "http://localhost:3000/login", "steps": "scripts/test-steps/login.json", "output": "recordings/login-test.mp4" }, "dashboard": { "url": "http://localhost:3000/dashboard", "steps": "scripts/test-steps/dashboard.json", "output": "recordings/dashboard-test.mp4" } } } ``` ## 与测试框架集成 ### Jest 集成 ```javascript // jest.config.js module.exports = { setupFilesAfterEnv: ['./jest.setup.js'], reporters: [ 'default', ['./scripts/jest-video-reporter', { outputDir: './test-recordings' }] ] }; ``` ### Playwright 集成 ```javascript // playwright.config.js const { defineConfig } = require('@playwright/test'); module.exports = defineConfig({ use: { video: 'on', screenshot: 'on', }, reporter: [ ['html', { outputFolder: 'playwright-report' }], ['./scripts/playwright-video-reporter', { format: 'gif' }] ] }); ``` ## 目录结构 ``` e2e-test/ ├── SKILL.md # 技能文档 ├── package.json # 项目配置 ├── scripts/ │ ├── record-browser.js # 浏览器录制核心 │ ├── record-test.js # 测试录制 │ ├── record-screen.js # 屏幕录制 │ ├── convert-format.js # 格式转换 │ ├── add-annotations.js # 添加标注 │ └── utils.js # 工具函数 ├── configs/ │ ├── default.json # 默认配置 │ ├── test.json # 测试配置 │ └── production.json # 生产配置 ├── templates/ │ ├── demo-template.js # 演示模板 │ └── test-template.js # 测试模板 ├── examples/ │ ├── basic-recording.js # 基础录制示例 │ ├── e2e-test.js # 端到端测试示例 │ └── api-test.js # API测试示例 └── recordings/ # 录制文件输出目录 ``` ## 使用示例 ### 示例 1:录制登录流程 ```javascript const { recordE2ETest } = require('./scripts/record-test'); await recordE2ETest({ url: 'http://localhost:3000', testName: '用户登录测试', steps: [ { description: '访问登录页面', action: 'goto', url: '/login' }, { description: '输入用户名', action: 'type', selector: '#username', text: 'test@example.com' }, { description: '输入密码', action: 'type', selector: '#password', text: 'password123' }, { description: '点击登录按钮', action: 'click', selector: 'button[type="submit"]' }, { description: '验证登录成功', action: 'waitFor', selector: '.dashboard', timeout: 5000 } ], output: 'recordings/login-demo.mp4', annotations: true }); ``` ### 示例 2:录制API测试 ```javascript const { recordAPITest } = require('./scripts/record-test'); await recordAPITest({ apiUrl: 'http://localhost:8000/api', tests: [ { name: '健康检查API', endpoint: '/health', method: 'GET', expectedStatus: 200 }, { name: '用户注册API', endpoint: '/auth/register', method: 'POST', data: { username: 'testuser', email: 'test@example.com', password: 'Password123!' }, expectedStatus: 201 } ], output: 'recordings/api-test.gif' }); ``` ## 故障排除 ### 常见问题 #### 1. 录制失败 - **问题**: 无法启动浏览器 - **解决**: 确保已安装 Chrome/Chromium,或设置 `executablePath` #### 2. 视频质量差 - **问题**: 视频模糊或卡顿 - **解决**: 调整 `fps` 和 `quality` 参数,确保网络稳定 #### 3. 文件过大 - **问题**: 录制文件太大 - **解决**: 降低 `fps`、`quality`,或使用 `convertVideo` 压缩 #### 4. 内存不足 - **问题**: 录制过程中内存占用过高 - **解决**: 减少录制时长,或增加系统内存 ### 调试模式 ```javascript const recorder = new ScreenRecorder({ debug: true, // 启用调试模式 logLevel: 'verbose' }); ``` ## 性能优化建议 ### 录制优化 1. **降低帧率**: 非必要情况下使用 15-24 FPS 2. **调整分辨率**: 根据需求调整录制区域大小 3. **使用硬件加速**: 启用 GPU 加速录制 ### 文件优化 1. **格式选择**: MP4 适合长视频,GIF 适合短视频 2. **压缩设置**: 使用合适的压缩参数 3. **分段录制**: 长时间录制可分段保存 ## 许可证 MIT License ## 更新日志 ### v1.0.0 (2026-04-11) - 初始版本发布 - 支持基础浏览器录制 - 支持 MP4/GIF 格式输出 - 提供端到端测试录制功能 ## 贡献指南 1. Fork 项目 2. 创建功能分支 3. 提交更改 4. 推送到分支 5. 创建 Pull Request ## 联系支持 - 问题反馈: [GitHub Issues](https://github.com/your-org/e2e-test/issues) - 文档: [项目 Wiki](https://github.com/your-org/e2e-test/wiki) - 邮件: support@example.com

Archived SourceRecently Updated
Web3

hap-mongodb-slowlog-analysis

Analyze MongoDB 4.4.x slow logs from pasted slow-log text, uploaded log files, or mongodb.log content and produce practical query optimization advice, index recommendations, evidence-backed reasoning, and ready-to-run Mongo shell index commands. The skill is AI-first and should analyze logs directly in conversation without relying on local PowerShell by default. It should also be able to group repeated entries by namespace, deduplicate repeated query shapes, and summarize repeated patterns before giving advice. Only treat DOCX or PDF export as optional conversion steps that may require local tooling. Prefer Chinese output by default, but support English when requested. Treat ctime as already indexed and never recommend a new index on it. Treat status as a low-cardinality field with only 1 and 9, where 1 means active/in-use, and do not include status in recommended index definitions.

Archived SourceRecently Updated