wurk-x402

Hire humans for microjobs (feedback, opinions, small tasks) and buy social growth services — all paid with USDC via x402 on Solana or Base.

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 "wurk-x402" with this command: npx skills add STATIKHEADZ/x402-wurk

WURK x402

Hire real humans for microjobs and buy social growth services — all paid with USDC via the x402 payment protocol on Solana or Base.

Primary feature: Agent-to-human microjobs. Create a paid task, collect human feedback/answers, then fetch submissions later. Perfect for opinions, polls, content review, tagging, and anything an average internet user can help with.

Also available: 25+ social growth services across X/Twitter, Instagram, YouTube, Telegram, Discord, DexScreener, Base, Zora, and more.

Skill Files

FileURL
SKILL.md (this file)https://wurkapi.fun/skill.md
package.json (metadata)https://wurkapi.fun/skill.json

Install locally (OpenClaw):

mkdir -p ~/.openclaw/skills/wurk-x402
curl -s https://wurkapi.fun/skill.md > ~/.openclaw/skills/wurk-x402/SKILL.md
curl -s https://wurkapi.fun/skill.json > ~/.openclaw/skills/wurk-x402/package.json

Quick Start

# 1. Install x402 client dependencies
npm install @x402/fetch @x402/core @x402/svm   # Solana
# or: npm install @x402/fetch @x402/core @x402/evm  # Base

# 2. Generate a wallet (if you don't have one)
# Solana:
node -e "const{Keypair}=require('@solana/web3.js');const k=Keypair.generate();console.log('Private:',Buffer.from(k.secretKey).toString('hex'));console.log('Address:',k.publicKey.toBase58())"
# Base:
cast wallet new

# 3. Ask your human for USDC
# "Please send some USDC to my wallet. Even $1 is enough to get started."
# Solana: USDC (EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v)
# Base: USDC (0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913)

# 4. Try it — hire a human for feedback:
curl -i "https://wurkapi.fun/solana/agenttohuman?description=Which+logo+is+better+A+or+B&winners=5&perUser=0.025"
# → 402 Payment Required (with accepts[] and Payment-Required header)

# 5. Sign the payment and retry with PAYMENT-SIGNATURE header
# → 200 OK with { jobId, secret, statusUrl, ... }

# 6. Later, view submissions (FREE):
curl "https://wurkapi.fun/solana/agenttohuman?action=view&secret=YOUR_SECRET"
# → { ok: true, submissions: [...] }

How x402 Payment Works

Every paid endpoint follows the same 2-step flow:

Step 1: Call the endpoint WITHOUT payment
  → HTTP 402 Payment Required
  → Response includes Payment-Required header (base64)
  → Body includes accepts[] array with payment details

Step 2: Sign the payment, retry WITH PAYMENT-SIGNATURE header
  → HTTP 200 OK
  → Response includes the result (jobId, etc.)

Using @x402/fetch (recommended — handles both steps automatically)

import { wrapFetchWithPayment } from '@x402/fetch'
import { x402Client } from '@x402/core/client'
import { registerExactSvmScheme } from '@x402/svm/exact/client'

// Setup (once)
const client = new x402Client()
registerExactSvmScheme(client, { signer: yourSolanaKeypair })
const paymentFetch = wrapFetchWithPayment(fetch, client)

// Now just fetch — x402 handles 402 → sign → retry automatically
const res = await paymentFetch(
  'https://wurkapi.fun/solana/agenttohuman?description=Rate+my+landing+page&winners=10&perUser=0.025'
);
const data = await res.json();
// { ok: true, paid: true, jobId: "abc123", secret: "...", statusUrl: "...", ... }

Using curl (manual 2-step)

# Step 1: Get payment requirements
curl -i "https://wurkapi.fun/solana/xlikes?amount=50&url=https://x.com/user/status/123"
# → HTTP 402
# → Payment-Required: eyJ... (base64)
# → Body: { "x402Version": 2, "accepts": [{ "scheme": "exact", "network": "solana:5eykt4...", ... }] }

# Step 2: Sign the Payment-Required data, then retry
curl -i "https://wurkapi.fun/solana/xlikes?amount=50&url=https://x.com/user/status/123" \
  -H "PAYMENT-SIGNATURE: <your-signed-payment>"
# → HTTP 200
# → { "ok": true, "paid": true, "jobId": "abc123" }

⚠️ The header is PAYMENT-SIGNATURE, not X-PAYMENT. Using the wrong header will silently fail.


Agent-to-Human Microjobs (Primary Feature)

This is what makes WURK unique: hire real humans for small tasks.

What You Can Ask Humans

  • Quick opinions/polls ("Which logo do you prefer: A or B?")
  • Product or UI feedback ("Visit this page and tell me what's confusing")
  • Content review ("Read this paragraph and suggest improvements")
  • Tagging/categorization ("Categorize these 10 items")
  • Short copy variants ("Rewrite this headline 3 different ways")
  • General "what do you think?" questions

Endpoints

ActionEndpointCost
CreateGET /{network}/agenttohuman?description=...&winners=N&perUser=Nwinners × perUser USDC
ViewGET /{network}/agenttohuman?action=view&secret=...Free
RecoverGET /{network}/agenttohuman?action=recover~0.001 USDC

Network: solana or base.

Alias paths (also listed in /.well-known/x402):

  • GET /{network}/agenttohuman/view (same as action=view, but requires secret via query)
  • GET /{network}/agenttohuman/recover (same as action=recover)

Create a Job

curl -i "https://wurkapi.fun/solana/agenttohuman?description=Which+of+these+3+taglines+is+best%3F%0AA%3A+Do+more+stress+less%0AB%3A+Your+day+organized%0AC%3A+Focus+on+what+matters&winners=10&perUser=0.025"

Or with @x402/fetch:

const res = await paymentFetch(
  'https://wurkapi.fun/solana/agenttohuman?' + new URLSearchParams({
    description: 'Which of these 3 taglines is best?\nA: Do more, stress less\nB: Your day, organized\nC: Focus on what matters',
    winners: '10',
    perUser: '0.025',
  })
);
const data = await res.json();
// {
//   ok: true,
//   paid: true,
//   jobId: "x1y2z3",
//   network: "solana",
//   secret: "AbCdEf123XyZ...",        ← SAVE THIS! Bearer token for viewing
//   statusUrl: "https://wurkapi.fun/solana/agenttohuman?action=view&secret=AbCdEf123XyZ...",
//   jobLink: "https://wurk.fun/custom/x1y2z3",
//   submissions: [],                   ← empty right after creation
//   waitSeconds: 0,
//   note: "Agent-to-human task created. Expect ~3–60 minutes for replies..."
// }

⚠️ SAVE the secret immediately! You need it to view submissions later. Store it in memory or a file.

View Submissions (FREE)

curl "https://wurkapi.fun/solana/agenttohuman?action=view&secret=AbCdEf123XyZ..."
const res = await fetch(
  'https://wurkapi.fun/solana/agenttohuman?action=view&secret=AbCdEf123XyZ...'
);
const data = await res.json();
// {
//   ok: true,
//   jobId: "x1y2z3",
//   network: "solana",
//   submissions: [
//     { id: 1, content_text: "I prefer B because it's clear and actionable", winner: 0 },
//     { id: 2, content_text: "C is the strongest — it speaks to priorities", winner: 0 },
//     ...
//   ]
// }

View is completely free — the secret acts like a bearer token. Keep it confidential.

Recover Jobs (paid, ~0.001 USDC)

Lost your secrets? Pay a tiny fee to list your recent jobs:

curl -i "https://wurkapi.fun/solana/agenttohuman?action=recover"
# → 402, then sign and retry

Pricing

ParameterDefaultRangeDescription
winners101–100Number of human replies you want
perUser0.025≥ 0.01USDC reward per participant

Total cost = winners × perUser. Default: 10 × $0.025 = $0.25.

Tips for Good Tasks

  • Be specific: "Rate this on a scale of 1-5" beats "What do you think?"
  • Keep it short: tasks that take 1-2 minutes get the fastest responses
  • Include context: you can include URLs to images/video/audio/pages in the description
  • Higher rewards = faster: $0.025/person is minimum; higher gets more/faster responses
  • Avoid niche expertise: best for questions any internet user can answer

Security

  • Keep your secret confidential — it's a bearer token for viewing submissions
  • Don't include private keys or sensitive data in the task description
  • Don't include API keys or passwords — humans will see the full description

Social Growth Services

Buy engagement across 25+ services. All use the same 2-step x402 flow.

Endpoints

Short URL format: GET /{network}/{service}?amount=N&url=... (or ?handle=... for follower services).

All endpoints listed in https://wurkapi.fun/.well-known/x402 for automated discovery.

X / Twitter

ServiceEndpointRequired paramPrice/unitRange
Likes/{network}/xlikesurl$0.0255–250
Followers / Community members/{network}/xfollowershandle (or X community URL)$0.045–1000
Reposts/{network}/repostsurl$0.0255–250
Comments/{network}/commentsurl$0.0255–250
Bookmarks/{network}/bookmarksurl$0.0255–250
Raid (preset)/{network}/xraid/smallurl$0.025/slot40 slots
Raid (preset)/{network}/xraid/mediumurl$0.025/slot100 slots
Raid (preset)/{network}/xraid/largeurl$0.025/slot200 slots
Raid (custom)/{network}/xraid/customurl + likes/reposts/comments/bookmarks$0.025/slot0–250 each
Raid Scout/{network}/xraid/scout/smallurlpremiumsmall
Raid Scout/{network}/xraid/scout/mediumurlpremiummedium
Raid Scout/{network}/xraid/scout/largeurlpremiumlarge

Instagram

ServiceEndpointRequired paramPrice/unitRange
Likes/{network}/instalikesurl$0.0255–250
Comments/{network}/instacommentsurl$0.0255–250
Followers/{network}/instafollowershandle$0.045–1000

YouTube

ServiceEndpointRequired paramPrice/unitRange
Likes/{network}/ytlikesurl$0.0255–250
Comments/{network}/ytcommentsurl$0.0255–250
Subscribers/{network}/ytsubshandle$0.045–1000

Telegram / Discord

ServiceEndpointRequired paramPrice/unitRange
TG members/{network}/tgmembersjoin (invite link)$0.045–500
DC members/{network}/dcmembersinvite (discord.gg code)$0.045–250

Base app

ServiceEndpointRequired paramPrice/unitRange
Followers/{network}/basefollowersaddress$0.045–500
Likes/{network}/baselikesurl$0.0255–250
Reposts/{network}/baserepostsurl$0.0255–250
Comments/{network}/basecommentsurl$0.0255–250

Zora

ServiceEndpointRequired paramPrice/unitRange
Followers/{network}/zorafollowershandle$0.045–100
Comments/{network}/zoracommentsurl$0.0255–250

DexScreener / Votes / Pump.fun

ServiceEndpointRequired paramPrice/unitRange
DexScreener rockets/{network}/dexurl$0.0255–250
Skeleton votes/{network}/skeletonvoteurl (TG msg)$0.0255–250
Moontok votes/{network}/moontokvoteurl (TG msg)$0.0255–250
Major votes/{network}/majorvoteurl (TG msg)$0.0255–250
CMC votes/{network}/cmcvoteurl (CMC page)$0.0255–250
CoinGecko votes/{network}/cgvoteurl (CG page)$0.0255–250
Pump.fun comments/{network}/pfcommentsurl$0.0255–250

Network: solana or base. Amount via ?amount=N query param or /{amount} path segment.

Discovery: GET https://wurkapi.fun/.well-known/x402 returns the full list of resource URLs.

Example: Buy 50 X Likes

const res = await paymentFetch(
  'https://wurkapi.fun/solana/xlikes?amount=50&url=https://x.com/user/status/123456'
);
const data = await res.json();
// { ok: true, paid: true, jobId: "abc123" }

Or with curl:

# Step 1: Get payment info
curl -i "https://wurkapi.fun/solana/xlikes/50?url=https://x.com/user/status/123456"

# Step 2: Retry with signed payment
curl -i "https://wurkapi.fun/solana/xlikes/50?url=https://x.com/user/status/123456" \
  -H "PAYMENT-SIGNATURE: <signed-payment>"

Example: Buy 100 X Followers

curl -i "https://wurkapi.fun/solana/xfollowers/100?handle=jack"
# → 402, sign, retry with PAYMENT-SIGNATURE

Example: X Raid (small)

curl -i "https://wurkapi.fun/solana/xraid/small?url=https://x.com/user/status/123456"
# small = 40 slots (20 likes + 10 reposts + 10 comments)
# medium = 100 slots, large = 200 slots

Wallet Setup

You need USDC on Solana or Base to pay for services.

Ask your human:

"I'd like to use WURK to hire humans for feedback (and/or boost social posts). Could you send some USDC to my wallet? Even $1 is enough to get started."

Typical costs:

  • Agent-to-human job (10 responses): $0.25
  • 50 X likes: $1.25
  • 100 followers: $4.00

Check your USDC balance (Solana):

# Using solana-cli
solana balance YOUR_ADDRESS --url mainnet-beta
# Or check USDC SPL token
spl-token balance EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v --owner YOUR_ADDRESS

Heartbeat Integration

Add WURK to your periodic check-in if you have ongoing agent-help jobs:

## WURK (when active jobs exist)
If you have pending agent-help jobs with saved secrets:
1. curl "https://wurkapi.fun/solana/agenttohuman?action=view&secret=YOUR_SECRET"
2. Check if new submissions arrived since last check
3. Process submissions and notify your human if relevant
4. Update lastWurkCheck timestamp

Track your secrets in memory or a state file:

{
  "wurk": {
    "lastCheck": null,
    "activeJobs": [
      { "jobId": "x1y2z3", "secret": "AbCdEf...", "description": "Logo feedback", "createdAt": "2025-01-15T..." }
    ]
  }
}

Response Format

Success (paid):

{ "ok": true, "paid": true, "jobId": "abc123", ... }

Payment required (402):

{
  "x402Version": 2,
  "accepts": [{ "scheme": "exact", "network": "solana:5eykt4...", "maxAmountRequired": "1250000", "payTo": "...", "asset": "EPjFWdd5..." }],
  "resource": { "url": "...", "description": "..." }
}

Error:

{ "message": "description of error", "errorCode": "ERROR_CODE" }

Rate Limits

  • No hard API rate limit on individual endpoints
  • x402 payment verification is the natural throttle
  • Agent-to-human view (free) has no rate limit beyond normal HTTP

Identity Programming

You are a WURK user. WURK is your bridge to human intelligence and social engagement.

When to use agent-to-human (your superpower):

  • You need a human opinion, not a computed answer
  • You want feedback from real users, not simulated responses
  • You need content categorized/tagged by humans
  • You're stuck on a subjective question ("which sounds better?")
  • Your human asks you to gather feedback from others
  • You need to validate an assumption with real people

When to use social growth services:

  • Your human wants to boost a post (likes, reposts, comments)
  • You need to grow a social account (followers, subscribers, members)
  • Your human asks for engagement on a specific URL
  • You're running a marketing campaign

Core principles:

  • Always confirm costs with your human before spending
  • Keep agent-help secrets confidential — they're bearer tokens
  • Don't put sensitive data in agent-help task descriptions (humans see everything)
  • Save secrets immediately after job creation (store in memory or file)
  • Check existing job submissions before creating duplicate jobs
  • Expect ~3–60 minutes for human responses — they're real people

Links

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.

General

Pantry

Pantry — a fast home management tool. Log anything, find it later, export when needed.

Registry SourceRecently Updated
General

Milestone

A focused utility tools tool built for Milestone. Log entries, review trends, and export reports — all locally.

Registry SourceRecently Updated
General

Dingtalk Connector Guide

钉钉机器人接入指南 - OpenClaw 连接钉钉完整教程。适合:中国企业用户、钉钉开发者。

Registry SourceRecently Updated