child-inscription
Child Inscription Skill
Creates parent-child Ordinals inscriptions per the Ordinals provenance spec. The inscription owner spends the parent UTXO in the reveal transaction, embedding a pointer that establishes on-chain provenance for the child.
- estimate — Read-only fee calculation, no wallet required.
- inscribe — Step 1 commit transaction, requires an unlocked wallet with BTC.
- reveal — Step 2 reveal transaction, requires the commit tx to be confirmed.
Usage
bun run child-inscription/child-inscription.ts <subcommand> [options]
Subcommands
estimate
Calculate the total cost (commit fee + reveal amount) for a child inscription without broadcasting anything.
bun run child-inscription/child-inscription.ts estimate \
--parent-id <inscription-id> \
--content-type <mime> \
--content <string>
Options:
--parent-id(required) — Parent inscription ID, e.g.abc123...i0--content-type(required) — MIME type, e.g.text/plainorimage/png--content(required) — Content as a UTF-8 string (base64-encoded internally)--fee-rate(optional) — Fee rate in sat/vB; defaults to current mempool medium fee
Output:
{
"parentId": "abc123...i0",
"contentType": "text/plain",
"contentSize": 42,
"feeRate": 12,
"fees": {
"commitFee": 1440,
"revealFee": 2100,
"revealAmount": 3394,
"totalCost": 4834
},
"breakdown": "Commit tx: 1440 sats | Reveal amount: 3394 sats (includes 2100 reveal fee) | Total: 4834 sats"
}
inscribe
Broadcast the commit transaction (Step 1). The commit locks funds into a pay-to-taproot address encoding the inscription script. After this confirms, run reveal.
bun run child-inscription/child-inscription.ts inscribe \
--parent-id <inscription-id> \
--content-type <mime> \
--content <string> \
[--fee-rate <sats-per-vbyte>]
Options:
--parent-id(required) — Parent inscription ID. Your wallet must own this inscription (verified on-chain).--content-type(required) — MIME type of the child content.--content(required) — Child content as a UTF-8 string.--fee-rate(optional) — Fee rate:fast,medium,slow, or an integer in sat/vB (default:medium).
Output:
{
"status": "commit_broadcast",
"commitTxid": "deadbeef...",
"commitExplorerUrl": "https://mempool.space/tx/deadbeef...",
"revealAddress": "bc1p...",
"revealAmount": 3394,
"commitFee": 1440,
"feeRate": 12,
"parentInscriptionId": "abc123...i0",
"contentType": "text/plain",
"contentSize": 42,
"nextStep": "After commit confirms, call reveal with commitTxid and revealAmount from this response."
}
reveal
Broadcast the reveal transaction (Step 2). This spends the commit output and the parent UTXO simultaneously, creating the child inscription and returning the parent to your address.
Wait for the commit tx to confirm before calling this.
bun run child-inscription/child-inscription.ts reveal \
--commit-txid <txid> \
--vout <num>
Options:
--commit-txid(required) — Txid of the confirmed commit transaction (from theinscribestep).--vout(required) — Output index of the commit transaction (almost always0).
Note: Content, content-type, parent-id, and reveal-amount are read from the .child-inscription-state.json file written by the inscribe subcommand.
Output:
{
"status": "success",
"inscriptionId": "revealthash...i0",
"parentInscriptionId": "abc123...i0",
"contentType": "text/plain",
"contentSize": 42,
"commit": {
"txid": "deadbeef...",
"explorerUrl": "https://mempool.space/tx/deadbeef..."
},
"reveal": {
"txid": "revealthash...",
"fee": 2100,
"explorerUrl": "https://mempool.space/tx/revealthash..."
},
"recipientAddress": "bc1p..."
}
Notes
- Always run
estimatefirst to understand total cost before committing funds. - The
inscribesubcommand writes a.child-inscription-state.jsonfile in the current working directory. Do not delete it before runningreveal. - The parent inscription must remain at your Taproot address between the
inscribeandrevealsteps. Do not transfer the parent during this window. - Content is encoded as UTF-8 and base64-encoded before being passed to the MCP tool. Binary content (images etc.) should be supplied pre-encoded.
- Wallet operations require an unlocked wallet (
bun run wallet/wallet.ts unlockfirst). - All operations target Bitcoin mainnet by default (controlled by the
NETWORKenvironment variable).
More from aibtcdev/skills
arxiv-research
Fetch and compile arXiv papers on LLMs, autonomous agents, and AI infrastructure into scored, grouped research digests. Stores digests at ~/.aibtc/arxiv-research/digests/. No API key required.
180aibtc-news
aibtc.news decentralized intelligence platform — list and claim editorial beats, file authenticated signals (news items) with BIP-322 signatures, browse signals, check weighted leaderboard, review signals as publisher, and trigger daily brief compilation.
168aibtc-news-correspondent
Correspondent for aibtc.news: claim a beat, research daily using live on-chain and market data, file quality signals, earn $25 sBTC per signal included in the daily brief
157btc
Bitcoin L1 operations — check balances, estimate fees, list UTXOs, transfer BTC, and classify UTXOs as cardinal (safe to spend), ordinal (inscriptions), or rune (rune tokens). Data sourced from mempool.space and the Unisat API.
150aibtc-news-fact-checker
Side role: find and correct bad signals, earn leaderboard points per Publisher-approved correction (max 3/day)
149defi
DeFi operations on Stacks — ALEX DEX token swaps and liquidity pool queries, plus Zest Protocol lending (supply, withdraw, borrow, repay, claim rewards). All operations are mainnet-only. Write operations require an unlocked wallet.
148