Documentation Index
Fetch the complete documentation index at: https://docs.chipipay.com/llms.txt
Use this file to discover all available pages before exploring further.
Available without advertisement until external audit closes. The on-chain
threshold logic shipped with V8.4 (class hash
0x075dfb39…fa58a) and has a mainnet smoke (task
#46).When to use threshold
Three concrete use cases:- Vela autonomous agent treasury — a Vela agent spends up to $X/day on its own, anything bigger requires a co-sign from the user’s passkey. The wallet is 2-of-2 (agent owner + user passkey owner) above the spend threshold, 1-of-2 below.
- AI-API service-account wallets — a service-account-rooted Starknet wallet (JWT_ES256 owner) shares custody with a human operator (passkey owner). Routine API spend doesn’t prompt; settlement transfers do.
- Co-signed gift-card treasuries — an org’s Chipi credits balance is N-of-M with key roles distributed across finance + ops + the founder.
Compared to single-owner
Single-owner SHHH wallets sign via one V2_SNIP12 envelope:verified_count ≥ threshold. The set of owners and the threshold N live on-chain.
Owner kinds within a threshold
Anything that works as a single-owner signer kind works as a threshold owner. You can mix:- An EOA on MetaMask (
EIP191_SECP256K1) co-signs with a passkey (WEBAUTHN_P256) - A JWT_ES256 service account co-signs with a STARK key held server-side
- A guardian (
role: "GUARDIAN") does NOT count toward the threshold for normal transactions — guardians only initiate recovery, never co-sign
Configuring N and M
The wallet is created with N initial owners (M=N at start). Add or remove owners post-creation via the recovery flows in recovery:propose_add_owner→execute_add_ownerafter 48hpropose_remove_owner→execute_remove_ownerafter 24hpropose_set_threshold→execute_set_thresholdafter 48h
cancel_pending_op.
SDK status
| Surface | Status | Notes |
|---|---|---|
Backend builders (buildThresholdEnvelope, buildProposeSetThresholdCall, buildExecuteSetThresholdCall) | Shipped | See @chipi-stack/backend exports |
| Python builders | Shipped | Mirrors TS — see chipi_sdk.shhh.threshold |
| React hook | useGuardianRecovery().buildProposeSetThreshold / .buildExecuteSetThreshold cover the governance side | The N-of-M signature assembly hook (useThresholdSign) ships next |
| Mainnet smoke | Shipped (view-shape + parser) | Real-money smoke deferred until external audit closes |
Gas
The paymaster sums the per-kind gas overhead across each inner envelope. A 2-of-2 STARK + EIP-191 OE budgets 2M + 10M = 12M l2_gas for verification on top of the call’s own cost. See signer kinds for per-kind numbers. This composes — you don’t budget gas yourself. The paymaster reserves it automatically based on the envelope shape.Threshold + recovery together
The headline product story for SHHH V8.4 is threshold combined with guardian recovery:- Day-to-day operations require N-of-M signatures
- Lost-key recovery still works because a guardian can initiate
initiate_recoveryeven if N-1 owners have lost their keys
Related
- Signer kinds — what each owner can be
- Recovery — add/remove owners + guardian recovery
- Migration — getting from CHIPI v29 to SHHH first
