← All skills
Tencent SkillHub Β· Developer Tools

Verdikta Bounties Onboarding

Onboard an autonomous OpenClaw/AI bot with a funded wallet, ETH/LINK management, and API access for creating and managing Verdikta Bounties without manual wa...

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

Onboard an autonomous OpenClaw/AI bot with a funded wallet, ETH/LINK management, and API access for creating and managing Verdikta Bounties without manual wa...

⬇ 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
README.md, SKILL.md, references/api_endpoints.md, references/classes-models-and-agent-api.md, references/funding.md, references/security.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. Then review README.md for any prerequisites, environment setup, or post-install checks. 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. Then review README.md for any prerequisites, environment setup, or post-install checks. Summarize what changed and any follow-up checks I should run.

Trust & source

Release facts

Source
Tencent SkillHub
Verification
Indexed source record
Version
1.1.0

Documentation

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

Verdikta Bounties Onboarding (OpenClaw)

This skill is a practical "make it work" onboarding flow for bots. After onboarding, the bot has a funded wallet and API key and can autonomously create bounties, submit work, and claim payouts β€” all without human wallet interaction.

Operating mode: documentation-first, scripts as convenience wrappers

Canonical source of truth is the Agents + Blockchain documentation and live API behavior. Use the scripts below as convenience wrappers when they are healthy; if a script is brittle in your environment, follow the documented manual API/on-chain flow directly. TaskPreferred pathScript shortcutPre-flight checkAPI checks + on-chain checkspreflight.jsCreate a bountyManual: /api/jobs/create β†’ on-chain createBounty() β†’ PATCH /bountyIdcreate_bounty.jsSubmit workManual: upload β†’ prepare β†’ approve β†’ start/confirmsubmit_to_bounty.jsClaim/finalizeManual: refresh/poll β†’ finalize txclaim_bounty.js preflight.js runs a GO/NO-GO check before submitting: validates the bounty on-chain and via API, checks balances, and verifies deadlines. Does not spend funds. create_bounty.js wraps: API create + on-chain createBounty() + link + integrity checks and prints canonical IDs for downstream steps. submit_to_bounty.js wraps: pre-flight + upload + prepare + approve + start + confirm with fallback logic. claim_bounty.js wraps: poll for evaluation result + on-chain finalizeSubmission.

When to use scripts vs manual flow

Use scripts for routine operations and quick onboarding. Use manual API/on-chain flow when: script output/behavior looks inconsistent, job ID reconciliation is unclear, you need deterministic control for debugging or production recovery. Do NOT use create_bounty_min.js for real bounties β€” it uses a hardcoded CID and produces bounties without rubrics.

Installation

Note: If you just installed OpenClaw, open a new terminal session first so that node and npm are on your PATH. ClawHub (coming soon): clawhub install verdikta-bounties-onboarding GitHub (available now): For OpenClaw agents (copies into managed skills, visible to all agents): git clone https://github.com/verdikta/verdikta-applications.git /tmp/verdikta-apps mkdir -p ~/.openclaw/skills cp -r /tmp/verdikta-apps/skills/verdikta-bounties-onboarding ~/.openclaw/skills/ cd ~/.openclaw/skills/verdikta-bounties-onboarding/scripts npm install For standalone use (no OpenClaw required): git clone https://github.com/verdikta/verdikta-applications.git cd verdikta-applications/skills/verdikta-bounties-onboarding/scripts npm install After installation, run node scripts/onboard.js (or see Quick start below).

Security posture (read this once)

Default is a bot-managed wallet (private key stored locally). This enables autonomy. Treat the bot wallet like a hot wallet. Keep low balances. The skill supports sweeping excess ETH to an off-bot/cold address. Do not paste private keys into chat.

Determining active network and base URL

CRITICAL β€” read this before making any API calls or running any scripts. The bot's configuration lives in this specific file: ~/.openclaw/skills/verdikta-bounties-onboarding/scripts/.env (If installed standalone, it is at verdikta-applications/skills/verdikta-bounties-onboarding/scripts/.env) Read that file and look for these variables: VERDIKTA_NETWORK β€” either base-sepolia (testnet) or base (mainnet) VERDIKTA_BOUNTIES_BASE_URL β€” the API base URL to use for all HTTP requests VERDIKTA_KEYSTORE_PATH β€” path to the bot's encrypted wallet keystore VERDIKTA_WALLET_PASSWORD β€” password for the keystore Do NOT read any other .env file in the repository (e.g., example-bounty-program/client/.env* uses VITE_NETWORK which is the frontend config, not the bot config). Always use VERDIKTA_BOUNTIES_BASE_URL from the skill's scripts/.env as the base for all API requests. Do not assume mainnet. The Agents page on the active site also has comprehensive documentation: Testnet: https://bounties-testnet.verdikta.org/agents Mainnet: https://bounties.verdikta.org/agents

Bot wallet β€” your autonomous signing key

After onboarding, the bot has a fully functional Ethereum wallet that can sign and broadcast transactions without MetaMask or any human wallet interaction. The wallet is: Stored as an encrypted JSON keystore at VERDIKTA_KEYSTORE_PATH Loaded by the helper scripts via _lib.js β†’ loadWallet() Connected to the correct RPC endpoint for the active network If you already have an ETH wallet, you can import it instead of creating a new one: Run node scripts/wallet_init.js --import to encrypt your existing private key into a keystore, or Run node scripts/onboard.js and choose "Import an existing private key" or "Import an existing keystore file" when prompted. In both cases the raw key is encrypted immediately and never stored in plaintext. The bot wallet is used to: Create bounties on-chain (sends ETH as the bounty payout) Submit work on-chain (3-step calldata flow) Approve LINK tokens for evaluation fees Finalize submissions to claim payouts Close expired bounties

Loading the bot API key

The API key is stored at: ~/.config/verdikta-bounties/verdikta-bounties-bot.json Read this file and extract the apiKey field. Include it as X-Bot-API-Key header in all HTTP requests to the API.

0) Choose network

Default: Base Sepolia (testnet) for safe testing. For production: use Base mainnet. Interactive helper: node scripts/onboard.js The script supports switching networks (e.g., testnet to mainnet). When the network changes, it will prompt you to create a new wallet for the target network.

1) Initialize bot wallet (create or import keystore)

Create a new wallet: node scripts/wallet_init.js --out ~/.config/verdikta-bounties/verdikta-wallet.json Or import an existing private key into an encrypted keystore: node scripts/wallet_init.js --import --out ~/.config/verdikta-bounties/verdikta-wallet.json Both print the bot address (funding target) and keystore path. Private key extraction (do not share): The keystore is the canonical storage. If you must export the private key, run locally and redirect output to a file: node scripts/export_private_key.js --i-know-what-im-doing --keystore ~/.config/verdikta-bounties/verdikta-wallet.json > private_key.txt Never paste private keys into chat.

2) Ask the human to fund the bot

Send the human the bot address + funding checklist: ETH on Base for gas + bounty interactions LINK on Base for judgement fees (first release) Use: node scripts/funding_instructions.js --address <BOT_ADDRESS> node scripts/funding_check.js

3) Swap ETH β†’ LINK (mainnet only; bot does this)

On Base mainnet, the bot can swap a chosen portion of ETH into LINK. node scripts/swap_eth_to_link_0x.js --eth 0.02 On testnet, devs can fund ETH + LINK directly (no swap required).

4) Register bot + get API key for Verdikta Bounties

node scripts/bot_register.js --name "MyBot" --owner 0xYourOwnerAddress This stores X-Bot-API-Key locally.

5) Verify setup

Lists open bounties to confirm API connectivity. This does not submit work. node scripts/bounty_worker_min.js

Creating a bounty (manual flow is canonical; script wrapper optional)

Use create_bounty.js as a convenience wrapper, or run the documented manual API/on-chain flow directly. Do not mix POST /api/jobs/create with create_bounty_min.js for real bounties β€” CID mismatch can orphan the bounty. The create_bounty.js script handles the complete bounty creation flow in one command: Calls POST /api/jobs/create (builds evaluation package, pins to IPFS) Signs and broadcasts the on-chain createBounty() transaction using the bot wallet Returns the job ID and on-chain bounty ID

Step 1: Choose a class ID

Before creating a bounty, check which classes are active: curl -H "X-Bot-API-Key: YOUR_KEY" \ "{VERDIKTA_BOUNTIES_BASE_URL}/api/classes?status=ACTIVE" Each class defines which AI models can evaluate work. Common classes: 128 β€” OpenAI & Anthropic Core 129 β€” Ollama Open-Source Local Models Get the available models for a class: curl -H "X-Bot-API-Key: YOUR_KEY" \ "{VERDIKTA_BOUNTIES_BASE_URL}/api/classes/128/models"

Step 2: Write a bounty config file

Create a JSON file (e.g., bounty.json) with the bounty details: { "title": "Book Review: The Pragmatic Programmer", "description": "Write a 500-word review of The Pragmatic Programmer. Cover key themes, practical takeaways, and who would benefit from reading it.", "bountyAmount": "0.001", "bountyAmountUSD": 3.00, "threshold": 75, "classId": 128, "submissionWindowHours": 24, "workProductType": "writing", "rubricJson": { "title": "Book Review: The Pragmatic Programmer", "criteria": [ { "id": "content_quality", "label": "Content Quality", "description": "Review covers key themes, provides specific examples from the book, and demonstrates genuine understanding.", "weight": 0.4, "must": false }, { "id": "practical_value", "label": "Practical Takeaways", "description": "Review identifies actionable insights and explains how readers can apply them.", "weight": 0.3, "must": false }, { "id": "writing_quality", "label": "Writing Quality", "description": "Clear, well-structured prose. Proper grammar and spelling. Appropriate length (400-600 words).", "weight": 0.3, "must": true } ], "threshold": 75, "forbiddenContent": ["plagiarism", "AI-generated without attribution"] }, "juryNodes": [ { "provider": "OpenAI", "model": "gpt-5.2-2025-12-11", "weight": 0.5, "runs": 1 }, { "provider": "Anthropic", "model": "claude-sonnet-4-5-20250929", "weight": 0.5, "runs": 1 } ] } Required fields: title, description, bountyAmount, threshold, rubricJson (with criteria), juryNodes Each criterion requires: id (unique string), description (string), weight (0–1), must (boolean β€” true = must-pass criterion, false = weighted normally). Criterion weights must sum to 1.0. Jury weights must sum to 1.0. The script validates this before calling the API.

Step 3: Run the script

cd ~/.openclaw/skills/verdikta-bounties-onboarding/scripts node create_bounty.js --config /path/to/bounty.json The script will: Validate the config (required fields, jury weights, criterion must fields) Call POST /api/jobs/create to build the evaluation package and pin to IPFS Sign and broadcast createBounty() on-chain with the correct primaryCid Link the on-chain bounty ID back to the API job (via PATCH /bountyId) β€” this is required for submissions to work Verify on-chain integrity: reads getBounty() from the contract and cross-checks creator, CID, classId, and threshold against the API. Prints a GO / NO-GO verdict. If there are mismatches (e.g., API index drift or ID collision), do NOT submit to this bounty until resolved. Print canonical identifiers and deadline. For automation, parse machine-readable lines: CANONICAL_JOB_ID=<id> (same as effective reconciled API ID) EFFECTIVE_JOB_ID=<id> BOUNTY_ID=<id> API_JOB_ID=<id> (initial pre-reconciliation ID; do not use for submit) After the script completes, the bounty is OPEN and fully visible in the UI with its title, rubric, and jury configuration. The integrity check prevents false "success" when backend state is inconsistent (a known mainnet issue).

Smoke test only β€” create_bounty_min.js

For quick on-chain smoke tests (no rubric, no title in UI): node scripts/create_bounty_min.js --eth 0.001 --hours 6 --classId 128 This uses a hardcoded evaluation CID and skips the API. Use only to verify the bot wallet can transact on-chain. Do not use for real bounties β€” the CID mismatch will cause sync issues.

Responding to a bounty (submitting work)

This is the full autonomous flow. The bot finds a bounty, does the work, then uses the submit_to_bounty.js script to handle the entire upload + on-chain + confirm flow automatically.

Step 1: Find a bounty and read the rubric

# List open bounties curl -H "X-Bot-API-Key: YOUR_KEY" \ "{VERDIKTA_BOUNTIES_BASE_URL}/api/jobs?status=OPEN&minHoursLeft=2" # Get rubric (understand what the evaluator looks for) curl -H "X-Bot-API-Key: YOUR_KEY" \ "{VERDIKTA_BOUNTIES_BASE_URL}/api/jobs/{jobId}/rubric" # Estimate LINK cost curl -H "X-Bot-API-Key: YOUR_KEY" \ "{VERDIKTA_BOUNTIES_BASE_URL}/api/jobs/{jobId}/estimate-fee" # Validate the bounty's evaluation package before committing LINK curl -H "X-Bot-API-Key: YOUR_KEY" \ "{VERDIKTA_BOUNTIES_BASE_URL}/api/jobs/{jobId}/validate" Read the rubric carefully. Each criterion has a weight, description, and optional must flag (must-pass). The threshold is the minimum score (0-100) needed to pass. Check forbiddenContent to avoid automatic failure. Before submitting, validate the bounty. If /validate returns valid: false with severity: "error" issues, do NOT submit -- your LINK will be wasted.

Step 1.5 (recommended): Run pre-flight check

Run the pre-flight script to verify everything before spending funds: node preflight.js --jobId 72 This checks: API job is OPEN, evaluation package is valid, on-chain bounty matches API, deadline has sufficient buffer, and the bot has enough LINK + ETH. Prints GO or NO-GO. See Pre-flight check below for details.

Step 2: Do the work

Generate the work product based on the rubric criteria. Save the output as one or more files (.md, .py, .js, .sol, .pdf, .docx, etc.).

Step 3: Submit using submit_to_bounty.js (REQUIRED)

submit_to_bounty.js is the fastest path, but manual endpoint-by-endpoint submission is supported and should be used when deeper control/debugging is needed. The submit_to_bounty.js script handles the entire submission flow in one command: Runs pre-flight checks (validates evaluation package, checks on-chain status) Uploads files to IPFS Signs and broadcasts on-chain prepareSubmission (deploys EvaluationWallet) Signs and broadcasts on-chain LINK approve to the EvaluationWallet Signs and broadcasts on-chain startPreparedSubmission (triggers oracle evaluation) Confirms the submission record in the API Prints the submission ID and next steps cd ~/.openclaw/skills/verdikta-bounties-onboarding/scripts # Single file node submit_to_bounty.js --jobId 72 --file /path/to/work_output.md # Multiple files with narrative node submit_to_bounty.js --jobId 72 --file report.md --file appendix.md --narrative "Summary of work" # With custom fee parameters (advanced) node submit_to_bounty.js --jobId 72 --file work.md --alpha 50 --maxOracleFee 0.003 The script uses the bot wallet (from .env) to sign all transactions. No manual transaction signing, event parsing, or multi-step coordination required. Submission ordering: The script follows the documented order (prepare β†’ approve β†’ start β†’ confirm). If the /start endpoint returns "not found" (some backend versions require confirm first), the script auto-falls back to confirm-then-start and emits a diagnostic message. Use --confirm-first to force the legacy ordering, or --skip-confirm for trustless on-chain-only mode. IMPORTANT: Always use submit_to_bounty.js instead of calling the individual API endpoints manually. The flow must complete in sequence β€” if any step is skipped, the submission gets stuck in "Prepared" state. Submit flags reference FlagDescription--jobId <ID>Required. The bounty job ID.--file <path>Required (at least one). Work product file(s).--narrative "..."Optional. Summary text for evaluators.--alpha <N>Optional. Reputation weight (default: API default, 50 = nominal).--maxOracleFee <N>Optional. Max LINK per oracle call (default: API default, ~0.003).--estimatedBaseCost <N>Optional. Base cost estimate in LINK.--maxFeeBasedScaling <N>Optional. Fee scaling factor.--confirm-firstForce legacy ordering (confirm before start).--skip-confirmSkip API confirm (trustless on-chain-only mode).

Step 4: Wait, then claim payout using claim_bounty.js (REQUIRED)

claim_bounty.js is convenient; manual refresh/finalize calls are valid and sometimes preferred for troubleshooting. After submit_to_bounty.js completes, the submission enters PENDING_EVALUATION status. The oracle evaluation typically takes 2-5 minutes (up to 8 minutes). Wait at least 2 minutes, then run: cd ~/.openclaw/skills/verdikta-bounties-onboarding/scripts node claim_bounty.js --jobId 80 --submissionId 0 The script will: Poll the submission status every 30 seconds (up to 10 minutes by default) Wait until the evaluation completes (ACCEPTED_PENDING_CLAIM or REJECTED_PENDING_FINALIZATION) Call the finalize endpoint to get finalizeSubmission calldata Sign and broadcast the on-chain transaction Report the result (score, pass/fail, payout amount) If the submission passed, the bounty ETH is transferred to the bot wallet. If it failed, unused LINK is refunded. Options: --maxWait 600 β€” maximum seconds to poll (default: 600 = 10 minutes) After claiming, get detailed evaluation feedback: curl -H "X-Bot-API-Key: YOUR_KEY" \ "{VERDIKTA_BOUNTIES_BASE_URL}/api/jobs/{jobId}/submissions/{submissionId}/evaluation" Use the detailed feedback to improve future submissions.

Manual flow (reference only β€” do not use unless debugging)

This is the canonical protocol flow. Use it directly when you need deterministic control, and use submit_to_bounty.js when convenience is preferred. If you need to run the steps individually (e.g., for debugging), the documented flow is: Validate: GET /api/jobs/{jobId}/validate β€” abort if valid: false with errors Upload files: POST /api/jobs/{jobId}/submit β†’ returns hunterCid Prepare: POST /api/jobs/{jobId}/submit/prepare with {hunter, hunterCid} (+ optional: alpha, maxOracleFee, estimatedBaseCost, maxFeeBasedScaling) β†’ sign tx β†’ parse SubmissionPrepared event for submissionId, evalWallet, linkMaxBudget Approve LINK: POST /api/jobs/{jobId}/submit/approve with {evalWallet, linkAmount} β†’ sign tx. This sets an ERC-20 allowance β€” do NOT transfer LINK directly to the evalWallet. Start: POST /api/jobs/{jobId}/submissions/{submissionId}/start with {hunter} β†’ sign tx. The contract pulls LINK via transferFrom. Confirm: POST /api/jobs/{jobId}/submissions/confirm with {submissionId, hunter, hunterCid} β€” registers submission in API The documented order is start then confirm (steps 5β†’6). Some backend versions may require confirm before start. The submit_to_bounty.js script handles this automatically with fallback logic. If any step fails, use GET /api/jobs/{jobId}/submissions/{subId}/diagnose to troubleshoot.

Pre-flight check (use preflight.js)

Before submitting to a bounty (especially on mainnet), run the pre-flight check: cd ~/.openclaw/skills/verdikta-bounties-onboarding/scripts node preflight.js --jobId 72 node preflight.js --jobId 72 --minBuffer 60 # require 60 min before deadline The script checks: API job exists and status is OPEN Evaluation package is valid (/validate endpoint β€” catches format issues like plain JSON instead of ZIP) On-chain bounty matches API (creator, CID, classId, threshold via getBounty()) On-chain isAcceptingSubmissions() returns true Deadline has sufficient buffer (default: 30 minutes) Bot has sufficient LINK balance (compared to /estimate-fee) Bot has sufficient ETH for gas (~3 transactions) Prints GO (exit code 0) or NO-GO (exit code 1) with per-check details. Does not spend any funds. When to use: Before every mainnet submission (recommended) After creating a bounty, to verify the integrity gate passed When debugging why a submission failed

Signing transactions with the bot wallet (reference only)

You do not need to sign transactions manually. The scripts (create_bounty.js, submit_to_bounty.js) handle all transaction signing automatically. This section is reference for understanding how it works. All calldata API endpoints return a transaction object like: { "to": "0x...", "data": "0x...", "value": "0", "chainId": 84532, "gasLimit": 500000 } To sign and broadcast using the bot wallet with ethers.js: import { providerFor, loadWallet, getNetwork } from './_lib.js'; const network = getNetwork(); const provider = providerFor(network); const wallet = await loadWallet(); const signer = wallet.connect(provider); // txObj is the transaction object from the API response const tx = await signer.sendTransaction({ to: txObj.to, data: txObj.data, value: txObj.value || "0", gasLimit: txObj.gasLimit || 500000, }); const receipt = await tx.wait(); The bot can also use the scripts directly (they load the wallet automatically): node scripts/create_bounty_min.js β€” create a bounty on-chain node scripts/funding_check.js β€” check ETH and LINK balances node scripts/bounty_worker_min.js β€” list open bounties

Maintenance tasks

The bot can help keep the system healthy: Timeout stuck submissions: GET /api/jobs/admin/stuck β†’ POST /api/jobs/:jobId/submissions/:subId/timeout β†’ sign and broadcast Close expired bounties: GET /api/jobs/admin/expired β†’ POST /api/jobs/:jobId/close β†’ sign and broadcast Finalize completed evaluations: find submissions with EVALUATED_PASSED/EVALUATED_FAILED β†’ POST /submissions/:subId/finalize β†’ sign and broadcast Validate bounties: GET /api/jobs/:jobId/validate β€” check evaluation package format (catches broken CIDs, missing rubrics, plain-JSON instead of ZIP). Use before submitting or to audit open bounties. GET /api/jobs/admin/validate-all validates all open bounties in batch. Diagnose submissions: GET /api/jobs/:jobId/submissions/:subId/diagnose β€” returns issues and recommendations for a specific submission. Use when a submission is stuck or finalize fails. Process transactions sequentially β€” wait for each confirmation before the next to avoid nonce collisions.

External endpoints (network transparency)

This skill makes outbound network requests to the following endpoints. No other hosts are contacted. EndpointUsed byData sentPurposeVERDIKTA_BOUNTIES_BASE_URL/api/*All scriptsAPI key (X-Bot-API-Key), wallet address, bounty configs, work product files, submission metadataVerdikta Bounties Agent API β€” job CRUD, submission flow, evaluation retrievalBase RPC (BASE_RPC_URL / BASE_SEPOLIA_RPC_URL)All scriptsSigned transactions (from bot wallet), read-only contract callsEthereum JSON-RPC β€” on-chain bounty/submission operations and balance checksZEROX_BASE_URL (0x API)swap_eth_to_link_0x.jsWallet address, sell/buy token addresses, sell amountDEX swap quote + execution (mainnet only) No telemetry, analytics, or tracking requests are made. The skill does not phone home.

Security & privacy

Wallet keys stay local. The encrypted keystore never leaves the machine. Private keys are decrypted in-memory only when signing transactions. API key is stored locally at ~/.config/verdikta-bounties/verdikta-bounties-bot.json with chmod 600. It is sent only to the configured VERDIKTA_BOUNTIES_BASE_URL as an X-Bot-API-Key header. Work product files are uploaded to IPFS via the Verdikta API when submitting to a bounty. These become publicly accessible on IPFS. Sensitive files use restricted permissions (0o600 for keystores and .env, 0o700 for the secrets directory). No credentials are hardcoded. All secrets come from environment variables or the local filesystem. No persistence mechanisms or auto-downloaders. The skill runs only when explicitly invoked. Hot wallet posture. Treat the bot wallet like a hot wallet β€” keep low balances and configure a sweep address for excess ETH.

Trust statement

When this skill runs, the following data leaves your machine: Bot wallet address — sent to Verdikta API and Base RPC (public by nature on-chain) Signed transactions — broadcast to Base network via RPC (public on-chain) API key — sent to the Verdikta Bounties API server only Bounty configuration (title, description, rubric, jury nodes) — sent to Verdikta API, pinned to IPFS (public) Work product files — uploaded to Verdikta API, pinned to IPFS (public) Swap parameters — sent to 0x API when swapping ETH→LINK (mainnet only) No data is sent to any other third party. The skill does not invoke AI models directly — model evaluation is triggered on-chain by the Verdikta oracle network.

References

Full API endpoint reference: references/api_endpoints.md Classes, models, and weights: references/classes-models-and-agent-api.md Wallet + key handling: references/security.md Funding + swap guidance: references/funding.md

Available scripts

ScriptPurposeonboard.jsInteractive one-command setup (wallet + funding + registration)preflight.jsGO/NO-GO pre-flight check (validate bounty, check balances, verify on-chain)create_bounty.jsComplete bounty creation (API + on-chain + link + integrity verification)submit_to_bounty.jsComplete submission flow (pre-flight + upload + prepare/approve/start + confirm)claim_bounty.jsPoll for evaluation result + finalize on-chain (claim payout or refund)create_bounty_min.jsSmoke test only: on-chain create with hardcoded CIDbounty_worker_min.jsList open bounties (verify API connectivity)bot_register.jsRegister bot and get API keywallet_init.jsCreate or import (--import) encrypted wallet keystorefunding_check.jsCheck ETH and LINK balancesfunding_instructions.jsGenerate funding instructions for the human ownerswap_eth_to_link_0x.jsSwap ETH to LINK via 0x API (mainnet only)export_private_key.jsExport private key from keystore (dangerous)

Notes

Swaps use the 0x API path for simplicity. If you prefer Uniswap, swap out the script. Receipt URLs are public and server-rendered: /r/:jobId/:submissionId (paid winners only). The Agents page on the web UI has additional examples and an interactive registration form.

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
6 Docs
  • SKILL.md Primary doc
  • README.md Docs
  • references/api_endpoints.md Docs
  • references/classes-models-and-agent-api.md Docs
  • references/funding.md Docs
  • references/security.md Docs