x402-agent-api-skill

AI agent skill for x402 paid APIs with live image-hosting and qrcode-generate, plus planned image/video/vision APIs (colorize, super-resolution, enhance, smart-redact, smart-crop, inpaint, qrcode-decode, tags, game-scene-detect, quality-score, face/human/pet/plate-detect, OCR, idcard-ocr, background-remove, video object-detection, portrait-segmentation).

Safety Notice

This listing is from the official public ClawHub registry. Review SKILL.md and referenced scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "x402-agent-api-skill" with this command: npx skills add parsonssss/x402-agent-api-skill

x402 Agent API Skill

Use this skill to let your AI agent call paid endpoints on https://www.flashcode.live/ with x402.

Quick start for AI agents

  1. Place this file in your OpenClaw, Codex, or Claude project root.
  2. Tell your AI agent: "Help me convert this text into a QR code." or "Help me upload this image and return an online URL."
  3. The agent should follow x402 payment flow automatically.

Install dependencies

npm install @x402/core @x402/evm viem

Required environment variables

EVM_PRIVATE_KEY=0x_your_private_key
API_BASE_URL=https://www.flashcode.live/

Currently available features

  1. QR code generation
  2. Image hosting

Available endpoints

Live

  • GET /api/health - health check
  • GET /api/v1/capabilities - capability discovery
  • POST /api/v1/qrcode/generate - generate QR code image (x402 protected)
  • POST /api/v1/image/upload - upload image and return public URL (x402 protected, max 10MB)

Planned

  • POST /api/v1/image/colorize
  • POST /api/v1/image/super-resolution
  • POST /api/v1/image/enhance
  • POST /api/v1/image/smart-redact
  • POST /api/v1/image/smart-crop
  • POST /api/v1/image/inpaint
  • POST /api/v1/image/qrcode/decode
  • POST /api/v1/image/tags
  • POST /api/v1/image/game-scene-detect
  • POST /api/v1/image/quality-score
  • POST /api/v1/vision/face-detect
  • POST /api/v1/vision/human-detect
  • POST /api/v1/vision/pet-detect
  • POST /api/v1/vision/plate-detect
  • POST /api/v1/image/ocr
  • POST /api/v1/image/idcard-ocr
  • POST /api/v1/image/background-remove
  • POST /api/v1/video/object-detection
  • POST /api/v1/video/portrait-segmentation

How to call each live endpoint

1) QR code generation

Endpoint: POST /api/v1/qrcode/generate

JSON body:

{
  "text": "https://example.com",
  "size": 512,
  "ecc": "M",
  "format": "png",
  "margin": 2
}
  • text is required (1-2048 chars).
  • format is currently png only.
  • size range: 128-2048.
  • margin range: 0-16.
  • ecc supports: L | M | Q | H.
  • Success response contains result.image_base64 and result.mime_type.

2) Image hosting

Endpoint: POST /api/v1/image/upload

Request type: multipart/form-data

  • Use one form-data field named file.
  • File type must be image/*.
  • File size must be <= 10MB.

Success response contains result.image_url.

Payment flow

  1. Call protected endpoint and expect 402 Payment Required.
  2. Parse payment requirements from response headers.
  3. Sign payment and retry with x402 payment header.
  4. Read business result (result.image_url for upload).

Example client flow

This example follows the same pattern as scripts/buyer-quickstart-test.ts.

import { x402Client, x402HTTPClient } from "@x402/core/client";
import { ExactEvmScheme, toClientEvmSigner } from "@x402/evm";
import { createPublicClient, http } from "viem";
import { privateKeyToAccount } from "viem/accounts";
import { base } from "viem/chains";

const baseUrl =
  process.env.X402_API_BASE_URL ??
  process.env.API_BASE_URL ??
  "https://www.flashcode.live/";
const endpoint = `${baseUrl.replace(/\/$/, "")}/api/v1/qrcode/generate`;

async function main() {
  const privateKey = process.env.EVM_PRIVATE_KEY;
  if (!privateKey) throw new Error("Missing EVM_PRIVATE_KEY");
  if (!privateKey.startsWith("0x")) throw new Error("EVM_PRIVATE_KEY must start with 0x");

  const account = privateKeyToAccount(privateKey as `0x${string}`);
  const publicClient = createPublicClient({ chain: base, transport: http() });
  const signer = toClientEvmSigner(account, publicClient);
  const client = new x402Client().register("eip155:*", new ExactEvmScheme(signer));
  const httpClient = new x402HTTPClient(client);

  const payload = { text: "https://example.com", size: 512, ecc: "M" };

  const unpaid = await fetch(endpoint, {
    method: "POST",
    headers: { "content-type": "application/json" },
    body: JSON.stringify(payload),
  });

  if (unpaid.status !== 402) {
    const unpaidBody = await unpaid.text();
    throw new Error(`Expected unpaid status 402, got ${unpaid.status}. body=${unpaidBody}`);
  }

  const paymentRequired = httpClient.getPaymentRequiredResponse(
    (name) => unpaid.headers.get(name),
    {},
  );

  const paymentPayload = await httpClient.createPaymentPayload(paymentRequired);
  const response = await fetch(endpoint, {
    method: "POST",
    headers: {
      "content-type": "application/json",
      ...httpClient.encodePaymentSignatureHeader(paymentPayload),
    },
    body: JSON.stringify(payload),
  });

  const body = await response.json();
  if (!response.ok) throw new Error(`Request failed with status ${response.status}: ${JSON.stringify(body)}`);

  console.log(body);
}

void main().catch((error) => {
  console.error(error);
  process.exit(1);
});

Error handling

  • 402 Payment Required: build payment payload, sign, and retry.
  • 500 Internal Server Error: retry with backoff and log request context.

Endpoint-specific error codes

POST /api/v1/image/upload

  • image_file_required (400): file field is missing.
  • image_file_empty (400): uploaded file is empty.
  • image_file_too_large (413): image is larger than 10MB.
  • image_mime_not_supported (400): only image/* is supported.
  • invalid_image_request (400): other validation errors.

POST /api/v1/qrcode/generate

  • invalid_json_body (400): request body is not valid JSON.
  • invalid_request_body (400): body is not a JSON object.
  • qrcode_content_required (400): text is missing or empty.
  • qrcode_content_too_long (400): text exceeds 2048 characters.
  • qrcode_format_not_supported (400): only png format is supported.
  • invalid_qrcode_request (400): other validation errors.

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.

Coding

Podfetcher Tools

Search podcasts, browse episodes, and fetch podcast transcripts from Podfetcher using the bundled Node.js CLI, SDK, or MCP server.

Registry SourceRecently Updated
Coding

Code Reviewer Cn

代码审查、重构建议、安全漏洞检查、命名规范、复杂度分析、注释文档生成. Use when you need code reviewer cn capabilities. Triggers on: code reviewer cn, 圈复杂度估算, 嵌套深度检测, 命名风格一致性, 注释率计算与评级, 重复行检测.

Registry SourceRecently Updated
Coding

Encode

Encode - command-line tool for everyday use

Registry SourceRecently Updated
Coding

Melies

AI image and video generation CLI. Generate images, videos, and movie posters using 50+ models including Flux, Kling, Veo, Wan, and more. Text-to-image, text...

Registry SourceRecently Updated