โ† All skills
Tencent SkillHub ยท Developer Tools

Dollar Platoon | On-Demand Gigworkers

Peer-to-peer task payroll marketplace on Base L2. Clients create USDC-funded gigs, distribute tasks to gigworkers via email/webhook mailboxes, review proofs...

skill openclawclawhub Free
0 Downloads
0 Stars
0 Installs
0 Score
High Signal

Peer-to-peer task payroll marketplace on Base L2. Clients create USDC-funded gigs, distribute tasks to gigworkers via email/webhook mailboxes, review proofs...

โฌ‡ 0 downloads โ˜… 0 stars Unverified but indexed

Install for OpenClaw

Quick setup
  1. Download the package from Yavira.
  2. Extract the archive and review SKILL.md first.
  3. Import or place the package into your OpenClaw setup.

Requirements

Target platform
OpenClaw
Install method
Manual import
Extraction
Extract archive
Prerequisites
OpenClaw
Primary doc
SKILL.md

Package facts

Download mode
Yavira redirect
Package format
ZIP package
Source platform
Tencent SkillHub
What's included
SKILL.md

Validation

  • Use the Yavira download entry.
  • Review SKILL.md after the package is downloaded.
  • Confirm the extracted package contains the expected setup assets.

Install with your agent

Agent handoff

Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.

  1. Download the package from Yavira.
  2. Extract it into a folder your agent can access.
  3. Paste one of the prompts below and point your agent at the extracted folder.
New install

I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.

Upgrade existing

I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.

Trust & source

Release facts

Source
Tencent SkillHub
Verification
Indexed source record
Version
1.0.0

Documentation

ClawHub primary doc Primary doc: SKILL.md 41 sections Open source page

What Is Dollar Platoon?

Peer-to-peer task payroll on Base L2. Reputation-driven marketplace for high-volume, low-ticket work. Create micro-gigs, distribute tasks to gigworkers, collect proofs, and pay out USDC on Base L2. No contracts, no overhead, no dispute resolution โ€” reputation is the sole enforcement mechanism.

For Clients

Scale your workforce instantly. Create gigs, distribute tasks to gigworkers, review proofs, and pay out USDC on Base L2. Create Gigs โ€” Post tasks with USDC funding. Set price per proof, review timeouts, and distribution mode. Review Proofs โ€” Approve or reject submissions with a single click. Auto-approve after timeout protects gigworkers. Track Payouts โ€” Monitor funds, trigger payouts, and view on-chain transaction history.

For Gigworkers

Earn USDC doing tasks. Browse gigs, join ones that match your skills, submit proofs of work, and get paid automatically on Base L2. Build your reputation as you go. Find Work โ€” Browse the marketplace for gigs that match your skills. Filter by tags and earning potential. Submit Proofs โ€” Complete tasks, submit evidence, and track your submissions across all your mailboxes. Build Reputation โ€” Every approved proof builds your on-chain reputation across Volume, Quality, and Social dimensions.

How It Works

Peer-to-peer task payroll on Base L2. Read this before creating or joining a gig.

Overview

Dollar Platoon is a permissionless, composable on-chain marketplace for micro-gig work. Clients create gigs and fund them with USDC on Base L2. Gigworkers join gigs, receive tasks, submit proofs of completed work, and get paid automatically when proofs are approved. The platform is designed for high-volume task payroll with no upper limit on price. There is no dispute resolution. Reputation is the sole enforcement mechanism. The basic flow: Client creates a gig with terms, price per task, and USDC funding Gigworkers join and receive a personal mailbox Tasks are distributed to mailboxes via email or webhook Gigworkers submit proofs of completed work Client reviews and approves/rejects proofs (or auto-approve after timeout) Approved proofs trigger USDC payouts on Base L2

Wallets & Gas

Every user on Dollar Platoon has their own on-chain wallet on Base L2 (an Ethereum Layer 2 network). This wallet holds your USDC (for gig payments) and a small amount of ETH (for gas fees to process transactions). Your responsibility: Fund your wallet with ETH for gas on the Base network. Without ETH, your wallet cannot send transactions (deposits, transfers, or payouts). You typically need only ~0.001 ETH to cover many transactions. Key Points: Gas fees: Every on-chain action requires a small ETH gas fee. Base L2 fees are typically fractions of a cent. Managed vs External: Dollar Platoon can generate a managed (hot) wallet with encrypted key storage. Alternatively, link your own external wallet for full self-custody. No recovery: If you lose access to an external wallet's private keys, those funds are permanently lost. Managed wallets are recoverable through your Dollar Platoon account.

Reputation System

Reputation is wallet-anchored, multi-dimensional, and event-sourced. Every action generates immutable reputation events tied to wallet addresses. Both clients and gigworkers have reputation. Dimensions: Volume โ€” Total USDC earned (gigworker) or paid out (client). The most basic measure of activity and trust. Quality โ€” Approval rate weighted by rejection severity. Fake proofs damage quality 5x more than low-quality work. Recency โ€” Decay function penalizing inactivity. Recent participants are more trustworthy than dormant ones. Social โ€” Aggregate star rating from counterparty reviews, weighted by dollar amount exchanged in each gig. Key Features: Wallet-anchored: Reputation is tied to wallet addresses, not user accounts. Different wallets per gig means independent reputation histories. Permissionless: Anyone can create a wallet and participate. Reputation must be earned. Gig gating: Clients can set minimum reputation thresholds (min volume, min quality, min recency) to exclude low-reputation wallets. Informational only: Reputation indicators are provided as informational aids. They carry no warranty of accuracy.

Smart Contract & Payments

Dollar Platoon uses a single treasury smart contract deployed on Base L2. The contract handles USDC deposits and payouts. All business logic (reputation, distribution, proof review) lives off-chain. Fee Structure: EventFeeDetailClient deposits USDC0%No deposit feeGigworker payout10% on topWorker receives full gross; 10% charged additionally from gig balance Example: Worker earns $10 โ†’ contract charges $11 total ($10 to worker, $1 platform fee). Key Features: Fund isolation: Each gig has its own on-chain balance. One gig's funds cannot pay out another. No withdrawal: Once deposited, funds are locked in the gig. No withdrawal function exists. Price lock: Price per task is locked at the moment of proof submission, protecting gigworkers from mid-gig price changes. Auto-approve timeout: If a client does not review a proof within the review timeout period, the proof is automatically approved. Minimum payout: Configurable per gig (default $0). Smaller amounts accumulate until threshold is met. No debt: Gigs cannot go into debt. Rollups pre-check available_funds before payout.

Security Tokens

Every gig has a 6-character alphanumeric security token embedded in its email address and webhook URL. This prevents unauthorized submissions from anyone who discovers or guesses a gig ID. How it works: Email: {gig_id}_{token}.staging.dollar-platoon@fwd.zoomgtm.com Webhook: /inbound/webhook/{gig_id}?token={token} Inbound requests without a valid token are rejected with 403 Tokens are generated automatically on gig creation Owners can rotate tokens via the dashboard or POST /gigs/:id/rotate-token Rotating a token invalidates the old email address and webhook URL โ€” update all integrations after rotating Backward compatibility: Existing gigs without a security token will accept all inbound requests. Generate a token from the dashboard to enable protection.

Third-Party Publisher Apps

Dollar Platoon does not control task content or delivery. Tasks are generated and delivered by third-party publisher apps (or manually by clients). Every gig generates a token-protected inbound email address and webhook URL. Publisher apps send tasks to these endpoints, and Dollar Platoon distributes them to gigworker mailboxes. Dollar Platoon has no control over what publisher apps send. Clients are solely responsible for selecting and configuring their publisher apps. Gigworkers should review gig terms carefully before joining.

Composability & Flexible Workflow

Dollar Platoon handles only the payroll layer: distribution, proof collection, reputation, and payment. Everything else is pluggable: Task generation: Use any publisher app, email client, or manual workflow Task delivery: Email forwarding, webhook forwarding, or both Proof validation: Manual client review, webhook-based automation, AI agents, or timeout auto-approval Distribution modes: Round robin, random, priority weighted, free-for-all, FIFO queue, or inbound proof Reputation gating: Set minimums per gig or leave open to all

Trust & Validation

Trust is earned, not granted. The reputation system provides signals but not guarantees. For clients: Review proofs carefully. Use rejection tags to flag bad work. Set reputation thresholds to filter applicants. Configure proof webhooks for automated validation. Consider requiring member approval for new joiners. For gigworkers: Check the client's reputation score before joining. Look at their volume, quality, and social ratings. Check the gig's available funds. Understand the review timeout period. Highly recommended: Extend trust validation with your own systems and AI agents. Use proof webhooks to validate submissions programmatically.

As-Is Risk Nature

Dollar Platoon is provided on an "as-is" and "as-available" basis. ZoomGTM operates it as a technology platform only. Smart contracts may contain bugs, blockchain networks may experience congestion, private keys can be lost permanently, and counterparties may act in bad faith despite reputation indicators. This is a permissionless system. All parties participate entirely at their own risk and expense.

Liability Waiver

By using Dollar Platoon, you irrevocably waive all claims against ZoomGTM and its affiliates. No dispute resolution. No warranties. Maximum aggregate liability: $0.

Prohibited Uses

Dollar Platoon may not be used for illegal activities, adult content, harassment, money laundering, malware distribution, circumventing sanctions, or high-risk financial services. ZoomGTM may suspend access at any time without notice. See full Terms of Use.

Extending with Your Own Systems

AI Agent Review โ€” Configure proof webhooks to send submissions to your own AI agent for automated quality checks Custom Validation Pipelines โ€” Build webhook handlers that validate proofs against external data sources Publisher App Integration โ€” Build or use third-party publisher apps to generate tasks automatically Manual Workflow โ€” Email tasks to your gig address, review proofs in the dashboard, click approve/reject

Gig Funding

Fund your gig before approving proofs. Approved proofs cannot be paid if the gig has insufficient funds. The platform will reject the rollup. Account for the 10% platform fee. A $100 payout costs $110 from the gig balance. When funding, budget 110% of expected payouts. Funds are locked. There is no withdrawal function. Once USDC is deposited into a gig, it can only leave via worker payouts. Deposit conservatively and top up as needed. No debt allowed. Rollups pre-check available_funds >= gross_amount + platform_fee. If the gig can't cover the payout, it fails entirely. Monitor your balance. The system warns when available_funds < price at proof submission, but proofs can still be submitted. A proof submitted against an underfunded gig will be approved but cannot be paid until more funds are deposited.

Proof Submission

Always include a meaningful task_identifier. This is the primary link between an inbound task and its proof. Without it, clients cannot easily match proofs to the tasks they originated from. Use the task's subject line, ID, URL, or another unique reference. Include verifiable evidence. Proofs should contain URLs, screenshots, or other evidence that the client can independently verify. Unverifiable proofs are more likely to be rejected. Upload proof files via presigned URL first. Use POST /upload/presign to get an S3 upload URL, upload your file, then include the returned url in your proof's proofs array. Check gig funding before submitting. The gig detail endpoint shows available_funds. If funds are low, your proof may be approved but payment delayed until the client tops up. Price is locked at submission. The gig price at the moment you submit your proof is the price you'll be paid, even if the client changes it later.

Proof Review (Clients)

Review promptly. Proofs auto-approve after the review_timeout period (default 48 hours). If you miss the window, the proof is treated as approved. Use rejection tags. When rejecting, always include a rejection_tag. This drives reputation scoring โ€” fake_proof impacts the worker's quality score 5x more than low_quality. Report timeout-approved proofs. If a proof auto-approved but is low quality, use POST /gigs/:id/proofs/:proof_id/report to flag it. Reported proofs are excluded from payouts. Configure proof webhooks. Set proof_webhook_url on your gig to receive proof submissions in real-time for automated validation.

Payouts

Trigger rollups manually or wait for the daily cron. POST /gigs/:id/rollups processes all approved proofs immediately. The daily cron also processes approved proofs automatically. Minimum payout threshold. If min_payout is set, mailboxes with earnings below the threshold are skipped (returned in skipped_below_minimum). Their proofs accumulate until the threshold is met. Check rollup status. Rollups can fail if the on-chain transaction reverts (e.g., insufficient gas, contract error). Failed rollups are retried by the daily cron.

Share Tokens (Delegated Proof Submission)

Gigworkers can share a link for proof submission without login. Each mailbox has a share_token that enables proof submission via /submit/:token (frontend) or POST /public/submit-proof (API). Regenerate tokens if compromised. Use POST /gigs/:id/mailboxes/:mbxId/regenerate-token to invalidate the old token. Rate limited. Public endpoints are limited to 10-30 requests/minute per token.

Recommended Prices

Suggested pricing for common gig tasks on Dollar Platoon. These are suggestions, not requirements. Prices reflect market supply and demand for delivery. Some tasks are difficult, require real human effort, or involve scarce aged accounts โ€” these command higher prices. Other tasks are simple, highly automated with AI agents, or involve abundant supply โ€” these have lower prices. Set your price based on what the market will bear. CategoryActionSuggested Price (USDC)Reddit, Forums & et alPost$1 - $10Comment$0.10 - $1Upvote$0.05 - $0.20Account creation$10 - $50BlogsProgrammatic SEO article$0.01 - $0.10Premium blog (Medium, Substack, LinkedIn)$0.50 - $2Account creation$2 - $10Backlink$0.01 - $2X / Twitter / Bluesky / ThreadsComment$0.06 - $0.10Follow$0.05 - $0.50Account creation$5 - $20FacebookPost in group$0.50 - $2Comment on post$0.10 - $0.50Account creation$50InstagramComment$0.06 - $0.50Follow$0.10 - $1Like$0.06 - $0.10Account creation$20LinkedInComment$0.10 - $0.50Post$1 - $2Account creation$50TikTokComment$0.06 - $0.50Post (varies by georegion)$0.50 - $5Follow$0.05 - $0.50Like$0.06 - $0.10Account creation$10 - $50YouTubeLike$0.05 - $0.20Playthrough$0.10 - $0.50Comment$0.20 - $0.50Video upload$1 - $5Account creation$10 - $20Google Reviews & et alReview$0.50 - $5Account creation$10 - $30Gmail, Outlook & et alMarked not spam$0.05 - $0.20Account creation$2 - $5Product Hunt & et alAction (upvote, comment, etc.)$0.25 - $2Account creation$5 - $20Discord & TelegramGroup join$0.50 - $2Message$0.50 - $1Surveys & et alSurvey completion$0.50 - $2ChatGPT, Gemini & et alAsk mention$0.05 - $0.10App Testing & Focus GroupsTask$2 - $10Creative CurationSubmission$0.10 - $1Creative CreationCreative approved$0.10 - $5Directory PostingSignup to post$0.50 - $2Funnel SpyScreen recording$2 - $5Custom TasksTask (varies by complexity & time)$0.50 - $5Special TaskSpecial task$3 - $9

Why Do Prices Vary?

Account scarcity: Aged, verified accounts on platforms like Facebook and LinkedIn are scarce and expensive to create Platform difficulty: Some platforms have aggressive anti-bot detection, making actions harder and more expensive Georegion: Tasks targeting specific geographic regions may cost more due to limited local supply Automation level: Highly automatable tasks (AI-written SEO articles, bulk likes) are cheaper. Tasks requiring genuine human engagement cost more Risk: Actions that risk account suspension (posting in strict subreddits, leaving Google reviews) command a premium

REST API Reference

Auth via x-api-key header on all authenticated endpoints.

Authentication

MethodPathAuthDescriptionPOST/auth/send-otpNoSend 4-digit OTP code to emailPOST/auth/verify-otpNoVerify OTP and get API keyPOST/auth/rotate-keyYesGenerate new API keyGET/auth/meYesGet current user profile POST /auth/send-otp // Request { "email": "user@example.com" } // Response { "message": "Code sent" } 4-digit code (1000-9999), 10-minute expiry, max 5 attempts. Sends via email. POST /auth/verify-otp // Request { "email": "user@example.com", "code": "1234" } // Response { "email": "user@example.com", "api_key": "base64url_encoded_key" } Creates new user if first login. Auto-provisions hot wallet. Returns existing API key (no rotation on login). POST /auth/rotate-key // Response { "api_key": "base64url_encoded_key" } GET /auth/me // Response { "email": "...", "display_name": "...", "bio": "...", "avatar_url": "...", "created_at": "...", "officex_user_id": "...", "officex_install_id": "..." }

Gigs

MethodPathAuthDescriptionPOST/gigsYesCreate new gigGET/gigsNoList marketplace gigs (public + active)GET/gigs/mineYesList user's owned gigsGET/gigs/:idOptionalGet gig detailPATCH/gigs/:idYesUpdate gig (owner only)POST/gigs/:id/rotate-tokenYesRotate security token (owner only)GET/gigs/:id/dashboardYesGet gig dashboard with all data (owner only)POST/gigs/:id/depositYesDeposit USDC to gig treasury POST /gigs // Request { "title": "Reddit Comments for Product Launch", "price": 0.50, "terms": "Comment on specified Reddit threads with genuine engagement...", "notes": "Internal notes for owner only", "owner_wallet": "wallet_alias_id", // optional, auto-provisions if omitted "visibility": "public", // "public" | "private" "tags": ["reddit", "writing"], "requires_approval": false, "review_timeout": 172800, // seconds, default 48h "distribution": "round_robin", // "round_robin" | "free_for_all" | "priority_weighted" | "random" | "fifo_queue" | "inbound_proof" "min_rep_volume": null, "min_rep_quality": null, "min_rep_recency": null, "min_payout": 0, "location": { "country": "US", "label": "United States" }, "icon_url": "https://...", "proof_webhook_url": "https://...", "contract_address": "0x..." } // Response { "gig": { "id": "GIG_01HX...", "title": "Reddit Comments for Product Launch", "email": "GIG_01HX..._abc123.staging.dollar-platoon@fwd.zoomgtm.com", "webhook": "https://staging.dollarplatoon.com/api/inbound/webhook/GIG_01HX...?token=abc123", "invite_url": "https://staging.dollarplatoon.com/gig/GIG_01HX.../join", "price": 0.50, "requires_approval": false, "status": "active" } } Compliance check via Gemini (blocks illegal content, warns on borderline). Valid tags: linkedin, twitter, medium, tiktok, youtube, instagram, reddit, facebook, pinterest, quora, discord, telegram, email, blog, podcast, newsletter, seo, advertising, design, writing, translation, data-entry, research, survey, testing, other GET /gigs (Marketplace) GET /gigs?limit=20&cursor=<base64>&tags=linkedin,twitter // Response { "gigs": [...], "next_cursor": "eyJ..." } Returns public + active gigs with wallet aliases resolved. GET /gigs/:id Returns gig object. If authenticated as owner or member, includes notes and enriched data. Shows available_funds and reserved_funds so you can assess whether the gig can pay. PATCH /gigs/:id (Owner Only) // Request (any subset) { "title": "Updated Gig Title", "price": 1.00, "terms": "Updated terms...", "status": "paused", "review_timeout": 86400, "tags": ["reddit"], "visibility": "private", "distribution": "random", "requires_approval": true, "min_payout": 1, "location": { "country": "US" }, "notes": "Updated internal notes", "proof_webhook_url": "https://...", "contract_address": "0x..." } // Response { "success": true } POST /gigs/:id/rotate-token (Owner Only) // Response { "email": "GIG_01HX..._newtoken.staging.dollar-platoon@fwd.zoomgtm.com", "webhook": "https://staging.dollarplatoon.com/api/inbound/webhook/GIG_01HX...?token=newtoken" } Generates a new 6-char security token. Invalidates old email address and webhook URL. Old email lookup is deleted and replaced. Update all publisher integrations with the new URLs after rotating. GET /gigs/:id/dashboard (Owner Only) // Response { "gig": { ... }, "mailboxes": [ ... ], "proofs": [ ... ], "rollups": [ ... ], "inbound_messages": [ ... ] } Syncs on-chain balance on every load. Signs all S3 URLs for proof attachments. POST /gigs/:id/deposit // Request { "wallet_alias_id": "alias_id", "amount": 100 } // Response { "tx_hash": "0x...", "available_funds": 100 } Deposits USDC from your hot wallet to the gig's on-chain balance. Remember to budget 110% of expected payouts to cover the platform fee.

Mailboxes

MethodPathAuthDescriptionPOST/gigs/:id/mailboxesYesJoin gig (create mailbox)GET/gigs/:id/mailboxesYesList mailboxes in gig (owner only)PATCH/gigs/:id/mailboxes/:mbx_idYesUpdate mailbox (owner only)DELETE/gigs/:id/mailboxes/:mbx_idYesLeave gig / remove mailboxGET/mailboxes/mineYesList user's mailboxes across all gigsGET/mailboxes/:mbxId/inboundYesFetch inbound messages for mailboxPOST/gigs/:id/mailboxes/:mbxId/regenerate-tokenYesRegenerate share token POST /gigs/:id/mailboxes (Join Gig) // Request { "name": "John's Mailbox", "email": "john@example.com", "wallet_address": "0x...", // optional, auto-provisions hot wallet if omitted "webhook": "https://...", // optional, for webhook task delivery "notes": "I have experience with Reddit marketing", "location": { "country": "US" } } // Response { "mailbox": { "id": "01HX...", "name": "John's Mailbox", "gig_id": "GIG_01HX...", "status": "active" // or "pending_approval" if gig.requires_approval } } Validates reputation thresholds. Auto-creates wallet alias for external wallets. PATCH /gigs/:id/mailboxes/:mbx_id (Owner Only) // Request { "priority": 5, "status": "active" } // Response { "success": true, "status": "active" } Owner can set status to "active" to approve a pending mailbox, or "inactive" to disable it. GET /mailboxes/mine // Response { "mailboxes": [ { "id": "...", "name": "...", "gig_id": "GIG_...", "status": "active", "gig_title": "...", "gig_email": "...", "owner_email": "...", "owner_display_name": "...", "tasks_received": 12, "proofs_submitted": 10, "response_rate": 0.83 } ] } GET /mailboxes/:mbxId/inbound // Response { "inbound_messages": [ { "id": "...", "type": "email", "subject": "...", "from": "sender@example.com", "payload": "...", "mailbox_id": "...", "forwarded_at": "...", "attachments": [{ "filename": "...", "content_type": "...", "url": "https://..." }] } ] }

Proofs

MethodPathAuthDescriptionPOST/gigs/:id/proofsYesSubmit proof of workGET/gigs/:id/proofsYesList proofs (filterable by status)GET/gigs/:id/proofs/:proof_idYesGet proof detailPATCH/gigs/:id/proofs/:proof_idYesApprove or reject proof (owner only)POST/gigs/:id/proofs/:proof_id/reportYesReport auto-approved proof (owner only) POST /gigs/:id/proofs (Submit Proof) // Request { "mailbox_id": "01HX...", "task_identifier": "reddit-thread-abc123", "proofs": ["https://reddit.com/r/...", "https://s3.amazonaws.com/..."] } // Response { "proof": { "id": "01HX...", "status": "pending", "timeout_at": "2026-02-18T..." }, "warning": "Warning: gig available funds are less than the task price" } task_identifier is critical. This field links a proof to the specific task it fulfills. Use the inbound message subject, task URL, or any unique identifier from the original task. Without it, clients cannot match proofs to tasks and are more likely to reject. The warning field appears when the gig's available_funds is less than the task price. The proof is still accepted, but payout will fail until the client deposits more funds. Price is locked at submission time (locked_price). PATCH /gigs/:id/proofs/:proof_id (Review) // Request (approve) { "action": "approve", "feedback": "Great work!" } // Request (reject) { "action": "reject", "feedback": "Screenshot doesn't match", "rejection_tag": "incomplete" } // Response { "success": true, "status": "approved" } Rejection tags (required when rejecting): low_quality, incomplete, fake_proof, duplicate, unresponsive, other Rejection weights (reputation impact): fake_proof=5x, duplicate=3x, incomplete=2x, unresponsive=2x, low_quality=1x, other=1x POST /gigs/:id/proofs/:proof_id/report (Owner Only) // Response { "success": true, "status": "reported" } Only works on timeout_approved proofs. Reported proofs are excluded from rollups and will not be paid.

Rollups (Payouts)

MethodPathAuthDescriptionGET/gigs/:id/rollupsYesList rollups for gigPOST/gigs/:id/rollupsYesTrigger manual rollup (owner only)GET/rollups/mineYesList rollups across user's mailboxes POST /gigs/:id/rollups (Trigger Payout) // Response { "rollups": [ { "id": "...", "mailbox_id": "...", "wallet_address": "0x...", "proof_ids": ["...", "..."], "gross_amount": 5.00, "platform_fee": 0.50, "net_amount": 5.00, "tx_hash": "0x...", "status": "paid" } ], "available_funds": 44.50, "skipped_below_minimum": [ { "mailbox_id": "...", "amount": 0.50 } ] } Groups approved + timeout_approved proofs by mailbox. Pre-checks available_funds >= gross_amount + platform_fee (no debt allowed). Worker receives full gross_amount. Skips mailboxes below min_payout threshold. Will return 400 error if the gig cannot cover the total cost (gross + 10% fee).

Inbound (Task Distribution)

MethodPathAuthDescriptionPOST/inbound/emailNoResend inbound email webhookPOST/inbound/webhook/:gig_idNoPublisher webhook task delivery POST /inbound/webhook/:gig_id?token=... Accepts JSON (default) or HTML/plain text payloads. Content-Type header determines parsing. JSON payload (Content-Type: application/json): // Request { "task": "Comment on this Reddit thread", "url": "https://..." } // Response { "status": "forwarded", "targets": 3 } HTML payload (Content-Type: text/html or text/plain): curl -X POST "https://staging.dollarplatoon.com/api/inbound/webhook/GIG_01HX...?token=abc123&subject=My+Report" \ -H "Content-Type: text/html" \ -d '<h1>Task Details</h1><p>Please complete this task...</p>' // Response { "status": "forwarded", "targets": 3 } When HTML/text is sent, the message is stored with type: "email" and rendered as formatted HTML on the frontend (same as email-sourced tasks). An optional subject query parameter can be included to set the message subject line. Requires valid token query parameter matching the gig's security token. Returns 403 if token is invalid. Selects mailboxes via distribution algorithm, forwards payload to each mailbox webhook. Distribution Modes: round_robin โ€” Cursor-based fair rotation through active mailboxes random โ€” Uniform random selection priority_weighted โ€” Weighted by mailbox priority (1-10, higher = more tasks) free_for_all โ€” All active mailboxes receive the task fifo_queue โ€” Tasks stored in a FIFO queue; workers poll and claim tasks on-demand inbound_proof โ€” No tasks distributed; workers submit proofs directly without task assignment

Queue (FIFO)

MethodPathAuthDescriptionPOST/gigs/:id/queue/pollYesPoll for available tasks (gigworker, fifo_queue gigs only)GET/gigs/:id/queueYesList queued tasks POST /gigs/:id/queue/poll // Request { "count": 2 } // optional, default 2, max 20 // Response { "tasks": [ { "id": "...", "type": "webhook", "subject": "...", "payload": "...", "created_at": "..." } ] } For fifo_queue gigs only. Returns unclaimed queued tasks (oldest first), filtered against already-submitted proofs. Tasks are not forwarded to mailboxes โ€” gigworkers must poll to claim them. For Gigworkers (FIFO Queue gigs): Tasks are NOT forwarded to your mailbox. Instead, use "Poll New Tasks" in the UI or call POST /gigs/:id/queue/poll to claim tasks from the shared queue. Tasks are stored oldest-first (FIFO) and filtered against proofs you've already submitted. After polling, submit proofs as usual via POST /gigs/:id/proofs.

Public (No Auth Required)

MethodPathAuthDescriptionGET/public/mailbox-info?token=...NoGet mailbox info via share tokenPOST/public/upload-presignNoGet S3 presigned upload URLPOST/public/submit-proofNoSubmit proof via public share linkGET/public/read-url?key=...&token=...NoGet presigned S3 read URL Rate limited: 10-30 requests/min per share token. POST /public/submit-proof // Request { "share_token": "tok_...", "task_identifier": "reddit-thread-abc123", "proofs": ["https://..."] } // Response { "proof_id": "...", "status": "pending" }

Reviews

MethodPathAuthDescriptionPOST/gigs/:id/reviewsYesLeave star review (1-5)PATCH/reviews/:id/resolveYesMark review as resolved (reviewer only)GET/reputation/:wallet/reviewsNoList reviews for wallet POST /gigs/:id/reviews // Request { "target_wallet": "0x...", "stars": 4, "comment": "Reliable worker, good quality" } // Response { "review": { "id": "...", "stars": 4 } } One review per reviewer-target pair per gig. Reviewer role auto-detected (client if owner, gigworker otherwise).

Reputation

MethodPathAuthDescriptionGET/reputation/:walletNoGet computed reputation scoreGET/reputation/alias/:alias_idNoGet reputation by wallet aliasGET/reputation/:wallet/eventsNoList raw reputation events GET /reputation/:wallet // Response { "wallet": "0x...", "volume": 150.50, "quality": 0.92, "recency": 0.85, "social": 4.2, "event_count": 47 }

Wallets

MethodPathAuthDescriptionPOST/walletsYesCreate wallet aliasGET/walletsYesList user's wallet aliasesGET/wallets/:alias_idYesGet wallet detailGET/wallets/:alias_id/balancesYesGet on-chain balances (ETH + USDC)POST/wallets/:alias_id/transferYesTransfer USDC from hot walletDELETE/wallets/:alias_idYesDelete wallet alias POST /wallets // Request (hot wallet โ€” platform-managed) { "label": "My Hot Wallet", "is_hot_wallet": true } // Request (external wallet โ€” self-custody) { "label": "My MetaMask", "is_hot_wallet": false, "evm_address": "0x..." } // Response { "wallet": { "alias_id": "...", "label": "My Hot Wallet", "is_hot_wallet": true, "created_at": "..." } } One hot wallet per user. External wallets are unlimited. GET /wallets/:alias_id/balances // Response { "evm_address": "0x...", "eth_balance": "0.05", "usdc_balance": "100.000000" } POST /wallets/:alias_id/transfer // Request { "to_address": "0x...", "amount": 50 } // Response { "tx_hash": "0x..." } Hot wallets only.

Profiles

MethodPathAuthDescriptionPATCH/profiles/meYesUpdate own profileGET/profiles/:identifierNoGet public profile (by email or alias_id)GET/profiles/:identifier/privateYesGet private profile (requires shared gig relationship) PATCH /profiles/me // Request { "display_name": "John Doe", "bio": "Experienced social media marketer", "avatar_url": "https://..." }

Upload

MethodPathAuthDescriptionPOST/upload/presignYesGet presigned S3 upload URL // Request { "filename": "screenshot.png", "content_type": "image/png", "prefix": "proofs" } // Response { "presigned_url": "https://s3...", "url": "https://s3...", "key": "proofs/...", "bucket": "..." } Prefix options: "avatars", "gig-icons", or "proofs" (default). Presigned URL expires in 1 hour.

OfficeX Integration

MethodPathAuthDescriptionPOST/officex/webhookNoHandle OfficeX install/uninstallPOST/officex/loginNoLogin via OfficeX credentials POST /officex/webhook // Request { "event": "INSTALL", "payload": { "install_id": "...", "install_secret": "...", "user_id": "...", "app_id": "..." } } // Response { "agent_context": { "user_email": "officex-...@dollar-platoon.local", "api_key": "...", "api_url": "https://...", "install_id": "...", "install_secret": "..." } } Creates user with email officex-{user_id}@dollar-platoon.local. Auto-provisions hot wallet. POST /officex/login // Request { "officex_user_id": "...", "officex_install_id": "..." } // Response { "email": "officex-...@dollar-platoon.local", "api_key": "..." } Returns 404 if user not found (webhook may not have fired yet). Returns 403 if install_id mismatch.

Health

MethodPathAuthDescriptionGET/healthNoHealth check { "status": "ok", "stage": "staging", "timestamp": "2026-02-14T..." }

Proof Lifecycle

submitted (locked_price snapshot, timeout_at set) โ†’ approved (client action) โ†’ rolled up โ†’ payout on-chain โ†’ paid โ†’ rejected (requires rejection_tag + optional feedback) โ†’ timeout_approved (daily cron, after review_timeout) โ†’ same rollup path โ†’ reported (post-timeout flag by owner, excluded from payouts) Rejection tags: low_quality, incomplete, fake_proof, duplicate, unresponsive, other

Rollup & Payout Flow

Client triggers POST /gigs/:id/rollups (or daily cron runs automatically) Groups approved proofs by mailbox, sums locked_price per mailbox Skips mailboxes below min_payout threshold Pre-checks: gross_amount + platform_fee <= available_funds โ€” fails with 400 if underfunded Calls on-chain payout(gig_id, wallet, gross_amount, rollup_id) On success: stores tx_hash, status โ†’ paid, creates reputation event On failure: status โ†’ failed, retried by next daily cron run

Category context

Code helpers, APIs, CLIs, browser automation, testing, and developer operations.

Source: Tencent SkillHub

Largest current source with strong distribution and engagement signals.

Package contents

Included in package
1 Docs
  • SKILL.md Primary doc