Ai Bounty Claim
Use when claiming the AI bounty on the tDVV mainnet sidechain. First explain the difference between Portkey AA/CA and EOA, recommend AA/CA because the curren...
Description
name: ai-bounty-claim version: 2.10.0 description: Use when claiming the AI bounty on the tDVV mainnet sidechain. First explain the difference between Portkey AA/CA and EOA, recommend AA/CA because the current campaign rewards 2 AIBOUNTY for AA/CA and 1 AIBOUNTY for EOA, then route to account onboarding, Portkey AA/CA claim through CA ManagerForwardCall, EOA claim, or diagnostics-only stop handling.
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:
2.10.0 - If behavior seems inconsistent or an external AI reports unexpected output, ask them to report the
versionfield from thisSKILL.mdfirst.
Scope
Supported claim paths:
EOA:Claim()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
- blind retry loops after claim failures
Required Dependency Skills
Use these dependency skills explicitly instead of assuming the host will infer them:
- Portkey EOA skill:
https://github.com/Portkey-Wallet/eoa-agent-skills - Portkey CA skill:
https://github.com/Portkey-Wallet/ca-agent-skills
Routing rule:
- use the Portkey EOA skill for local EOA account setup, signer resolution, and EOA-side
Claim() - use the Portkey CA skill for local AA/CA account setup,
caHashresolution, 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, EOA1 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. 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.
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, do not stop before the first send only because visibleELFis low or zero; show the gas note, require explicit confirmation, and allow one attemptAA/CAorEOA: when the corresponding on-chain account has10 ELF, it can receive a daily gas subsidy worth1 ELFEOA: if there is not enoughELFto pay gas, stop and tell the user to getELFtransferred in before sendingClaim()EOA: if the user cannot get enoughELF, recommend switching toAA/CAand repeat that the current environment gas experience is smoother forAA/CA
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 supported methods already defined in this skill.
Required First Step
For generic claim requests without an explicit account type, 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 sayCAEOA: traditional wallet experience, typically based on mnemonic / private key, current campaign reward is1 AIBOUNTYAA/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 blockerEOA: if there is noELF, the claim transaction can fail withTransaction fee not enoughEOA: if the user cannot get enoughELF, recommend switching toAA/CA- recommendation: choose
AA/CA
Then ask the user which account type they want to use: AA/CA or EOA.
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 without explicitly choosing
AA/CAorEOA - examples:
help me claim,claim for me,帮我 Claim,帮我领取 - the user has not yet chosen between
AA/CAandEOA - the user has chosen
AA,CA,AA/CA, orEOA, but the local account context is not ready yet
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 user says the guardian already exists and recovery is required
- a prior contract call failed and the prerequisite is still unresolved
Branch 3: Portkey AA/CA Claim
Read references/flows/portkey-ca.md when:
- the user explicitly chose
AA,CA, orAA/CA - a local Portkey AA/CA account is already available, or the target
caHashis already known - use the Portkey CA skill dependency for AA/CA handling
Branch 4: EOA Claim
Read references/flows/eoa-skill.md when:
- the user explicitly chose
EOA - a local EOA account is already available
- no AA/CA identity flow is involved
- use the Portkey EOA skill dependency for EOA handling
Global Hard Rules
- Never continue with
Claim()if the address is exchange-managed, custodial, or lacks a user-controlled private key. - Always tell the user not to fill exchange or custodial addresses.
- Never offer to create, custody, or store a wallet for the user.
- Do not ask the user to paste an address when a local EOA or local AA/CA context should be used.
- For generic claim requests, explain
AA/CA vs EOAfirst and ask the user to choose one before entering a claim branch. - Treat
AAas the preferred user-facing term, but acceptCAas the same route alias. - Always recommend
AA/CAbecause the current campaign reward is2 AIBOUNTYforAA/CAand1 AIBOUNTYforEOA. - Also recommend
AA/CAbecause the current environment gas experience is smoother thanEOA. - If
EOAdoes not have enoughELF, tell the user to addELFfirst and also recommend switching toAA/CAif gettingELFis not feasible. - For
AA/CA, if the standard wallet path is ready, do not stop before the first confirmed attempt only because visibleELFis low or zero; show the gas note and allow one confirmed attempt. - Explicitly use the Portkey EOA skill for EOA work and the Portkey CA skill for AA/CA work; do not rely on implicit skill discovery.
- When checking whether the
tDVVRPC is reachable, queryhttps://tdvv-public-node.aelf.io/api/blockChain/chainStatusinstead of the site root. - If the RPC root URL returns
404but/api/blockChain/chainStatusreturns chain status JSON, treat the node as reachable. - Never use
/api/contract/contractViewMethodListto decide thatClaim()orClaimByPortkeyToCa(Hash ca_hash)does not exist. - If full method verification is needed, use
/api/blockChain/contractFileDescriptorSetonly as an optional verification path. - When using node introspection APIs, normalize the contract address first instead of querying with the wrapped
ELF_..._tDVVstring directly. - If introspection remains ambiguous, keep the reward contract address and supported write methods defined in this skill as canonical defaults.
- For AA/CA SDK or helper calls that require raw addresses, use raw CA and reward addresses rather than the wrapped
ELF_..._tDVVstrings. - If the chosen local account context is not ready, guide the user to create the local
AA/CAor localEOAfirst, then continue with the matching claim branch. NOTEXISTEDonly means the transaction is not confirmed yet; it is not a final success or failure state.- If the final chain error is
Transaction fee not enough, treat it as an insufficient transaction fee problem, not as a claim logic failure. - Never ask for
ca_hashin a plain EOAClaim()flow. - For AA/CA, accept either
emailorcaHashas the starting input. If onlyemailis available, use the Portkey CA skill to resolve the targetcaHash, and recover a usable manager signer when needed for the standard wallet path. - Prefer the locally created EOA address for
Claim()and the locally resolved AA/CA context forManagerForwardCall(...) -> ClaimByPortkeyToCa(Hash ca_hash). - Do not route the recommended AA/CA claim through deprecated
ClaimByPortkey(Hash). - Before any on-chain write, show the resolved manager signer, CA contract, forwarded reward contract, method chain, key inputs, expected receiver semantics, and current campaign reward amount, then require explicit user confirmation.
- If explicit confirmation is missing, stop before sending.
- If any prerequisite is unresolved, stop and explain the blocker instead of guessing.
- If a submitted transaction returns
txId, includetxIdandhttps://aelfscan.io/tDVV/tx/<txid>in the response, even if the final result is still pending lookup. - If a transaction fails, return the exact chain error and stop. Do not invent recovery success.
Receiver Semantics
Claim()sends the reward toContext.Sender.ManagerForwardCall(...) -> ClaimByPortkeyToCa(Hash ca_hash)sends the reward to the resolved AA/CA address, not to the manager signer.
Required Reading Pattern
After choosing the branch:
- Read the matching flow document under
references/flows/. - Read the matching example document under
references/examples/. - Follow that branch only.
- Do not mix EOA and AA/CA instructions in one answer.
Branch Map
- Account choice and onboarding: references/flows/account-choice.md Example: references/examples/account-choice.md
- Portkey AA/CA: references/flows/portkey-ca.md Example: references/examples/portkey-ca.md
- EOA: references/flows/eoa-skill.md Example: references/examples/eoa-skill.md
- Diagnostics and stop: references/flows/diagnostics-stop.md Example: references/examples/diagnostics-stop.md
Reviews (0)
No reviews yet. Be the first to review!
Comments (0)
No comments yet. Be the first to share your thoughts!