Learn-skills.dev reputation
ERC-8004 on-chain agent reputation management — submit and revoke feedback, append responses, approve clients, and query reputation summaries, feedback entries, and client lists.
git clone https://github.com/NeverSight/learn-skills.dev
T=$(mktemp -d) && git clone --depth=1 https://github.com/NeverSight/learn-skills.dev "$T" && mkdir -p ~/.claude/skills && cp -r "$T/data/skills-md/aibtcdev/skills/reputation" ~/.claude/skills/neversight-learn-skills-dev-reputation && rm -rf "$T"
data/skills-md/aibtcdev/skills/reputation/SKILL.mdReputation Skill
Provides ERC-8004 on-chain agent reputation operations using the reputation-registry contract. Read operations (get-summary, read-feedback, read-all-feedback, get-clients, get-feedback-count, get-approved-limit, get-last-index) work without a wallet. Write operations (give-feedback, revoke-feedback, append-response, approve-client) require an unlocked wallet.
Usage
bun run reputation/reputation.ts <subcommand> [options]
Subcommands
give-feedback
Submit feedback for an agent in the ERC-8004 reputation registry. Requires an unlocked wallet.
bun run reputation/reputation.ts give-feedback --agent-id <id> --value <value> [--value-decimals <decimals>] [--tag1 <tag>] [--tag2 <tag>] [--endpoint <endpoint>] [--feedback-uri <uri>] [--feedback-hash <hex>] [--fee <fee>] [--sponsored]
Options:
(required) — Agent ID to give feedback for (non-negative integer)--agent-id
(required) — Feedback value (signed integer, e.g., 5 for positive, -2 for negative)--value
(optional, default 0) — Decimal precision for the value (non-negative integer)--value-decimals
(optional) — Primary classification tag (e.g., "helpful", "accuracy")--tag1
(optional) — Secondary classification tag--tag2
(optional) — Endpoint or context identifier for the feedback--endpoint
(optional) — URI pointing to detailed feedback data--feedback-uri
(optional) — 32-byte SHA-256 hash of the feedback data as a hex string--feedback-hash
(optional) — Fee preset (--fee
,low
,medium
) or micro-STX amounthigh
(flag) — Submit as a sponsored transaction--sponsored
Output:
{ "success": true, "txid": "0xabc...", "message": "Feedback submitted for agent 42.", "agentId": 42, "value": 5, "valueDecimals": 0, "network": "mainnet", "explorerUrl": "https://explorer.hiro.so/txid/0xabc..." }
revoke-feedback
Revoke previously submitted feedback. Only the original feedback submitter (tx-sender) can revoke their own feedback. Requires an unlocked wallet.
bun run reputation/reputation.ts revoke-feedback --agent-id <id> --index <index> [--fee <fee>] [--sponsored]
Options:
(required) — Agent ID whose feedback you want to revoke (non-negative integer)--agent-id
(required) — Feedback index to revoke (non-negative integer)--index
(optional) — Fee preset (--fee
,low
,medium
) or micro-STX amounthigh
(flag) — Submit as a sponsored transaction--sponsored
Output:
{ "success": true, "txid": "0xdef...", "message": "Feedback index 0 revoked for agent 42.", "agentId": 42, "index": 0, "network": "mainnet", "explorerUrl": "https://explorer.hiro.so/txid/0xdef..." }
append-response
Append a response to a feedback entry. Any principal can append a response; the contract tracks unique responders per feedback entry. Requires an unlocked wallet.
bun run reputation/reputation.ts append-response --agent-id <id> --client <address> --index <index> --response-uri <uri> --response-hash <hex> [--fee <fee>] [--sponsored]
Options:
(required) — Agent ID associated with the feedback (non-negative integer)--agent-id
(required) — Stacks address of the original feedback submitter--client
(required) — Feedback index to respond to (non-negative integer)--index
(required) — URI pointing to the response data--response-uri
(required) — 32-byte SHA-256 hash of the response data as a hex string--response-hash
(optional) — Fee preset (--fee
,low
,medium
) or micro-STX amounthigh
(flag) — Submit as a sponsored transaction--sponsored
Output:
{ "success": true, "txid": "0xghi...", "message": "Response appended to feedback index 0 for agent 42.", "agentId": 42, "client": "SP2...", "index": 0, "responseUri": "ipfs://response...", "network": "mainnet", "explorerUrl": "https://explorer.hiro.so/txid/0xghi..." }
approve-client
Approve a client address to submit feedback for an agent up to a specified index limit. Caller must be the agent owner or an approved operator. Requires an unlocked wallet.
bun run reputation/reputation.ts approve-client --agent-id <id> --client <address> --index-limit <limit> [--fee <fee>] [--sponsored]
Options:
(required) — Agent ID to configure approval for (non-negative integer)--agent-id
(required) — Stacks address of the client to approve--client
(required) — Maximum number of feedback entries the client may submit (non-negative integer)--index-limit
(optional) — Fee preset (--fee
,low
,medium
) or micro-STX amounthigh
(flag) — Submit as a sponsored transaction--sponsored
Output:
{ "success": true, "txid": "0xjkl...", "message": "Client SP3... approved for agent 42 up to index limit 10.", "agentId": 42, "client": "SP3...", "indexLimit": 10, "network": "mainnet", "explorerUrl": "https://explorer.hiro.so/txid/0xjkl..." }
get-summary
Get the aggregated reputation summary for an agent. Returns total feedback count and WAD-averaged summary value. Does not require a wallet.
bun run reputation/reputation.ts get-summary --agent-id <id>
Options:
(required) — Agent ID to query (non-negative integer)--agent-id
Output:
{ "success": true, "agentId": 42, "totalFeedback": 7, "summaryValue": "5000000000000000000", "summaryValueDecimals": 18, "network": "mainnet" }
read-feedback
Read a specific feedback entry by agent ID, client address, and feedback index. Does not require a wallet.
bun run reputation/reputation.ts read-feedback --agent-id <id> --client <address> --index <index>
Options:
(required) — Agent ID to query (non-negative integer)--agent-id
(required) — Stacks address of the feedback submitter--client
(required) — Feedback index to read (non-negative integer)--index
Output:
{ "success": true, "agentId": 42, "client": "SP2...", "index": 0, "value": 5, "valueDecimals": 0, "wadValue": "5000000000000000000", "tag1": "helpful", "tag2": "", "isRevoked": false, "network": "mainnet" }
read-all-feedback
Get a paginated list of all feedback entries for an agent. Supports optional tag filtering and cursor-based pagination (page size: 14). Does not require a wallet.
bun run reputation/reputation.ts read-all-feedback --agent-id <id> [--tag1 <tag>] [--tag2 <tag>] [--include-revoked] [--cursor <cursor>]
Options:
(required) — Agent ID to query (non-negative integer)--agent-id
(optional) — Filter by primary tag--tag1
(optional) — Filter by secondary tag--tag2
(flag) — Include revoked feedback entries in results--include-revoked
(optional) — Pagination cursor from a previous response--cursor
Output:
{ "success": true, "agentId": 42, "items": [ { "client": "SP2...", "index": 0, "value": 5, "valueDecimals": 0, "wadValue": "5000000000000000000", "tag1": "helpful", "tag2": "", "isRevoked": false } ], "cursor": null, "network": "mainnet" }
get-clients
Get a paginated list of client addresses that have given feedback for an agent. Cursor-based pagination with page size 14. Does not require a wallet.
bun run reputation/reputation.ts get-clients --agent-id <id> [--cursor <cursor>]
Options:
(required) — Agent ID to query (non-negative integer)--agent-id
(optional) — Pagination cursor from a previous response--cursor
Output:
{ "success": true, "agentId": 42, "clients": ["SP2...", "SP3..."], "cursor": null, "network": "mainnet" }
get-feedback-count
Get the total feedback count for an agent. Does not require a wallet.
bun run reputation/reputation.ts get-feedback-count --agent-id <id>
Options:
(required) — Agent ID to query (non-negative integer)--agent-id
Output:
{ "success": true, "agentId": 42, "feedbackCount": 7, "network": "mainnet" }
get-approved-limit
Check the approved feedback index limit for a client on an agent. Returns 0 if the client has no explicit approval. Does not require a wallet.
bun run reputation/reputation.ts get-approved-limit --agent-id <id> --client <address>
Options:
(required) — Agent ID to query (non-negative integer)--agent-id
(required) — Stacks address of the client to check--client
Output:
{ "success": true, "agentId": 42, "client": "SP3...", "approvedLimit": 10, "network": "mainnet" }
get-last-index
Get the last feedback index for a client on an agent. Returns 0 if the client has not given any feedback. Does not require a wallet.
bun run reputation/reputation.ts get-last-index --agent-id <id> --client <address>
Options:
(required) — Agent ID to query (non-negative integer)--agent-id
(required) — Stacks address of the client to check--client
Output:
{ "success": true, "agentId": 42, "client": "SP3...", "lastIndex": 2, "network": "mainnet" }
Notes
- Read operations (get-summary, read-feedback, read-all-feedback, get-clients, get-feedback-count, get-approved-limit, get-last-index) work without a wallet
- Write operations require an unlocked wallet (
)bun run wallet/wallet.ts unlock - Feedback values are signed integers; use
to express fractional precision--value-decimals
and--feedback-hash
must be exactly 32 bytes (64 hex characters)--response-hash
can only be called by the original feedback submitter (tx-sender must match the client who submitted)revoke-feedback
can only be called by the agent owner or an approved identity operatorapprove-client- Pagination uses cursor-based navigation; pass the
from one response into the next callcursor