Qrcoin

v1.0.0

Interact with QR Coin auctions on Base. Use when the user wants to participate in qrcoin.fun QR code auctions — check auction status, view current bids, create new bids, or contribute to existing bids. QR Coin lets you bid to display URLs on QR codes; the highest bidder's URL gets encoded.

0· 942·7 current·7 all-time
Security Scan
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Benign
high confidence
Purpose & Capability
The name/description, required binaries (curl, jq), and SKILL.md all focus on querying a Base RPC and producing transaction prompts for Bankr. Nothing requested (no env vars, no installs) is unrelated to interacting with the auction contract.
Instruction Scope
SKILL.md contains concrete eth_call examples against mainnet.base.org and sample prompts to hand off transactions to Bankr (which handles signing/submission). It does not instruct reading local files, environment secrets, or exfiltrating unrelated data. The instructions are scoped to auction queries and constructing transactions.
Install Mechanism
No install spec or code files are present; the skill is instruction-only and relies on existing curl/jq binaries. This is the lowest-risk install footprint.
Credentials
No environment variables, credentials, or config paths are requested. The SKILL.md references an external RPC and Bankr for signing, which is appropriate for the task and does not demand additional secrets from the agent.
Persistence & Privilege
always is false and the skill does not request persistent system modifications. The default ability for the agent to invoke the skill autonomously is set, which is normal for skills and not a red flag here.
Assessment
This skill appears to be a straightforward, instruction-only helper for QR Coin auctions. Before using it: (1) verify the contract and site addresses independently (don’t trust a single source), (2) never paste your private key into an agent or a prompt — use a trusted wallet/relay (Bankr or your own signer) to sign transactions, (3) confirm you trust the external service Bankr if you plan to send it transaction instructions (it will see the destination, amounts, and URLs), (4) consider using a small test amount before committing larger funds, and (5) use your preferred RPC endpoint if you don’t want to rely on the public mainnet.base.org endpoint.

Like a lobster shell, security has layers — review code before you run it.

Runtime requirements

📱 Clawdis
Binscurl, jq
latestvk972jw5gskp0dq3aczz82wrmrd80zh3s
942downloads
0stars
1versions
Updated 1mo ago
v1.0.0
MIT-0

QR Coin Auction

Participate in QR Coin auctions on Base blockchain. QR Coin lets you bid to display URLs on QR codes — the highest bidder's URL gets encoded when the auction ends.

Contracts (Base Mainnet)

ContractAddress
QR Auction0x7309779122069EFa06ef71a45AE0DB55A259A176
USDC0x833589fCD6eDb6E08f4c7c32D4f71b54bdA02913

How It Works

  1. Each auction runs for a fixed period (~24h)
  2. Bidders submit URLs with USDC (6 decimals — 1 USDC = 1000000 units)
  3. Creating a new bid costs ~11.11 USDC (createBidReserve)
  4. Contributing to an existing bid costs ~1.00 USDC (contributeReserve)
  5. Highest bid wins; winner's URL is encoded in the QR code
  6. Losers get refunded; winners receive QR tokens

Auction Status Queries

Note: The examples below use https://mainnet.base.org (public RPC). You can substitute your own RPC endpoint if preferred.

Get Current Token ID

Always query this first to get the active auction ID before bidding.

curl -s -X POST https://mainnet.base.org \
  -H "Content-Type: application/json" \
  -d '{"jsonrpc":"2.0","method":"eth_call","params":[{"to":"0x7309779122069EFa06ef71a45AE0DB55A259A176","data":"0x7d9f6db5"},"latest"],"id":1}' \
  | jq -r '.result' | xargs printf "%d\n"

Get Auction End Time

# First get the current token ID, then use it here
TOKEN_ID=329  # Replace with result from currentTokenId()
TOKEN_ID_HEX=$(printf '%064x' $TOKEN_ID)

curl -s -X POST https://mainnet.base.org \
  -H "Content-Type: application/json" \
  -d '{"jsonrpc":"2.0","method":"eth_call","params":[{"to":"0x7309779122069EFa06ef71a45AE0DB55A259A176","data":"0xa4d0a17e'"$TOKEN_ID_HEX"'"},"latest"],"id":1}' \
  | jq -r '.result' | xargs printf "%d\n"

Get Reserve Prices

# Create bid reserve (~11.11 USDC)
curl -s -X POST https://mainnet.base.org \
  -H "Content-Type: application/json" \
  -d '{"jsonrpc":"2.0","method":"eth_call","params":[{"to":"0x7309779122069EFa06ef71a45AE0DB55A259A176","data":"0x5b3bec22"},"latest"],"id":1}' \
  | jq -r '.result' | xargs printf "%d\n" | awk '{print $1/1000000 " USDC"}'

# Contribute reserve (~1.00 USDC)
curl -s -X POST https://mainnet.base.org \
  -H "Content-Type: application/json" \
  -d '{"jsonrpc":"2.0","method":"eth_call","params":[{"to":"0x7309779122069EFa06ef71a45AE0DB55A259A176","data":"0xda5a5cf3"},"latest"],"id":1}' \
  | jq -r '.result' | xargs printf "%d\n" | awk '{print $1/1000000 " USDC"}'

Transactions via Bankr

QR Coin auctions require USDC transactions on Base. Use Bankr to execute these — Bankr handles:

  • Function signature parsing and parameter encoding
  • Gas estimation
  • Transaction signing and submission
  • Confirmation monitoring

Step 1: Approve USDC (One-Time)

Before bidding, approve the auction contract to spend USDC:

Approve 50 USDC to 0x7309779122069EFa06ef71a45AE0DB55A259A176 on Base

Step 2: Create a New Bid

To start a new bid for your URL:

Function: createBid(uint256 tokenId, string url, string name) Contract: 0x7309779122069EFa06ef71a45AE0DB55A259A176 Cost: ~11.11 USDC

Important: Always query currentTokenId() first to get the active auction ID.

Example prompt for Bankr:

Send transaction to 0x7309779122069EFa06ef71a45AE0DB55A259A176 on Base
calling createBid(329, "https://example.com", "MyName")

Step 3: Contribute to Existing Bid

To add funds to an existing URL's bid:

Function: contributeToBid(uint256 tokenId, string url, string name) Contract: 0x7309779122069EFa06ef71a45AE0DB55A259A176 Cost: ~1.00 USDC per contribution

Example prompt for Bankr:

Send transaction to 0x7309779122069EFa06ef71a45AE0DB55A259A176 on Base
calling contributeToBid(329, "https://grokipedia.com/page/debtreliefbot", "MerkleMoltBot")

Function Selectors

FunctionSelectorParameters
currentTokenId()0x7d9f6db5
auctionEndTime(uint256)0xa4d0a17etokenId
createBidReserve()0x5b3bec22
contributeReserve()0xda5a5cf3
createBid(uint256,string,string)0xf7842286tokenId, url, name
contributeToBid(uint256,string,string)0x7ce28d02tokenId, url, name
approve(address,uint256)0x095ea7b3spender, amount

Error Codes

ErrorMeaningSolution
RESERVE_PRICE_NOT_METBid amount below minimumCheck reserve prices
URL_ALREADY_HAS_BIDURL already has a bidUse contributeToBid instead
BID_NOT_FOUNDURL doesn't have existing bidUse createBid instead
AUCTION_OVERCurrent auction has endedWait for next auction
AUCTION_NOT_STARTEDAuction hasn't begunWait for auction to start
INSUFFICIENT_ALLOWANCEUSDC not approvedApprove USDC first

Typical Workflow

  1. Query currentTokenId() — Get the active auction ID
  2. Check auction status — Verify time remaining
  3. Approve USDC — One-time approval for the auction contract
  4. Decide action:
    • New URL: Use createBid (~11.11 USDC)
    • Support existing URL: Use contributeToBid (~1.00 USDC)
  5. Monitor — Watch for outbids and contribute more if needed
  6. Claim — Winners receive QR tokens; losers get refunds

Links

Tips

  • Start small: Contribute to existing bids (~1 USDC) to learn the flow
  • Check timing: Auctions have fixed end times; plan accordingly
  • Monitor bids: Others can outbid you; watch the auction
  • Use Bankr: Let Bankr handle transaction signing and execution
  • Specify Base: Always include "on Base" when using Bankr

💡 Pro Tip: Contributing to an existing bid is cheaper than creating a new one. Check if someone already bid for your URL before creating a new bid.

Comments

Loading comments...