AI Bounty Claim
Use this skill for AI bounty claiming on tDVV through RewardClaimContract.
For AA/CA, the standard wallet path in this skill is manager signer -> CA.ManagerForwardCall -> reward.ClaimByPortkeyToCa(Hash ca_hash).
This skill is intentionally split into one routing file plus focused branch references so weaker agents can follow one path at a time.
Skill Version
- Current skill version:
3.0.0 - If behavior seems inconsistent or an external AI reports unexpected output, ask them to report the
versionfield from thisSKILL.mdfirst.
Compatibility
- AA/CA dependency:
@portkey/ca-agent-skills >= 2.3.0 - AA/CA required dependency interfaces:
- CLI:
manager-sync-status - MCP:
portkey_manager_sync_status
- CLI:
Scope
Supported claim path:
AA/CA:ManagerForwardCall(...) -> ClaimByPortkeyToCa(Hash ca_hash)
This skill does not implement:
- wallet custody or wallet creation on behalf of the user
- private key generation, storage, or import on behalf of the user
- Portkey recovery flows on behalf of the user
- blind retry loops after claim failures
- legacy public EOA claim routing
Required Dependency Skills
Use these dependency skills explicitly instead of assuming the host will infer them:
- Portkey CA skill:
https://github.com/Portkey-Wallet/ca-agent-skills(minimum required version2.3.0for the AA/CA route)
Routing rule:
- use the Portkey CA skill for local AA/CA account setup,
caHashresolution,manager-sync-status, holder lookup ontDVV, and recovery/login only when needed to recover local context, resolve the target AA/CA ontDVV, or recover a usable manager signer
Current Environment Defaults
Use these defaults only when the user is clearly operating in the current AI bounty environment:
- Chain:
tDVV - Environment meaning: current AI bounty mainnet sidechain environment
- Reward contract:
ELF_2fc5uPpboX9K9e9NTiDHxhCcgP8T9nV28BLyK8rDu8JmDpn472_tDVV - Reward contract raw address:
2fc5uPpboX9K9e9NTiDHxhCcgP8T9nV28BLyK8rDu8JmDpn472 - Public RPC:
https://tdvv-public-node.aelf.io - RPC validation endpoint:
https://tdvv-public-node.aelf.io/api/blockChain/chainStatus - Portkey CA contract:
ELF_2UthYi7AHRdfrqc1YCfeQnjdChDLaas65bW4WxESMGMojFiXj9_tDVV - Portkey CA contract raw address:
2UthYi7AHRdfrqc1YCfeQnjdChDLaas65bW4WxESMGMojFiXj9 - Current campaign default reward: Portkey AA/CA
2 AIBOUNTY
Treat reward amounts and addresses as campaign defaults, not permanent protocol constants.
Canonical AA/CA Claim Path
- Always use
manager signer -> Portkey CA contract ManagerForwardCall -> reward contract ClaimByPortkeyToCa(Hash ca_hash)as the standard AA/CA wallet operation. - Always apply this fixed read-only gate before any AA/CA write, and do not skip or reorder it:
- resolve the local AA/CA context and
caHash - call
manager-sync-statusorportkey_manager_sync_status - call
GetHolderInfo(caHash)ontDVV - only continue when
isManagerSynced=trueand the holder can be resolved ontDVV
- resolve the local AA/CA context and
ClaimByPortkeyToCa(Hash ca_hash)is permissionless at the reward method layer, but this skill still models AA/CA claiming through the standard CA wallet forwarding path.- The forwarded reward still goes to the resolved
holderInfo.CaAddress, not to the manager signer. - The forwarded reward method input is
.aelf.Hash; passcaHashbytes asHash.value. - For SDK or helper calls, use raw CA and reward addresses rather than the wrapped
ELF_..._tDVVstrings. - Prefer the high-level helper
managerForwardCallWithKey(...)in the dependency implementation. Keep lower-level protobuf and descriptor details in the AA/CA branch reference. - If the selected CA dependency does not expose
manager-sync-statusorportkey_manager_sync_status, stop and tell the user to upgrade to@portkey/ca-agent-skills >= 2.3.0before attempting AA/CA claim.
Gas Rules
Use these gas rules as current environment defaults:
AA/CA: when the selected signer appears to have little or noELF, explain that the current environment may still provide a daily gas subsidy worth1 ELFAA/CA: if the standard wallet path is ready after the fixed read-only gate passes, do not stop before the first send only because visibleELFis low or zero; show the gas note, require explicit confirmation, and allow one attemptAA/CA: never infer a fee problem fromHolder is not found,CA holder not found, or any failed holder lookup; only the final chain errorTransaction fee not enoughmay trigger fee guidance
Treat these gas rules as current environment defaults, not permanent protocol constants.
RPC validation note:
- the RPC root URL may return
404 - do not treat root-path
404as proof that the node is down - validate node availability through
/api/blockChain/chainStatus
Contract Introspection Guardrail
- Do not use
/api/contract/contractViewMethodListto conclude that the reward contract lacks write methods. - Treat
/api/contract/contractViewMethodListas view-only discovery. If it only showsGetConfig,HasAddressClaimed,HasCaClaimed, or other read methods, that only proves those view methods are visible. - If full method verification is needed, use
/api/blockChain/contractFileDescriptorSetonly as an optional verification path, not as the default claim flow. - When using node introspection APIs, normalize the reward contract address into the format accepted by the endpoint. Do not send the wrapped
ELF_..._tDVVaddress string directly. - If introspection is ambiguous, incomplete, or returns
Not foundbecause of query format issues, keep using the canonical reward contract address and the supported public AA/CA method already defined in this skill.
Required First Step
For generic claim requests, do not jump directly to an on-chain method.
Examples:
help me claimclaim for me帮我 Claim帮我领取
The agent must first explain:
AA/CA: account-style experience, typically based on email / guardian / recovery flows, current campaign reward is2 AIBOUNTYAA: this is the preferred user-facing term in this skillCA: this is still accepted as an alias because some users still sayCAAA/CA: this route requires@portkey/ca-agent-skills >= 2.3.0because claim preflight depends onmanager-sync-statusand holder lookup ontDVVAA/CA: current environment gas experience is smoother because daily subsidy rules may apply automatically, and the first confirmed AA/CA attempt can usually be tried before fee is treated as the blockerAA/CA: before any claim write, we must first confirm manager sync and holder readiness ontDVVEOA: this public bounty skill no longer exposes the legacy EOA route, even if older contract source snapshots still show legacy methods
Then ask the user whether the local Portkey AA/CA context is already ready, or whether they want to recover/login first with email.
Routing Rules
Choose one branch before asking for extra claim inputs.
Branch 1: Account Choice And Onboarding
Read references/flows/account-choice.md when:
- the user makes a generic claim request
- examples:
help me claim,claim for me,帮我 Claim,帮我领取 - the local AA/CA account context is not ready yet
- the user only has an
emailand needs onboarding, recovery, or login first
Branch 2: Diagnostics And Stop
Read references/flows/diagnostics-stop.md first when any of the following is true:
- the user tries to fill an exchange address, custodial address, or any address without a user-controlled private key
- the user wants the agent to create or hold a wallet for them
- the user says Portkey AA/CA already exists on mainnet but cannot be resolved on
tDVV - the selected Portkey CA dependency is below
2.3.0or does not exposemanager-sync-status/portkey_manager_sync_status manager-sync-statusret