starknet/account-abstraction

Account Abstraction

starknetguide🏛️ Officialconfidence highhealth 100%
v1.0.0·by keep-starknet-strange·Updated 4/12/2026

When to Use

  • Reviewing account contract validation and execution paths.
  • Designing session-key policy boundaries.
  • Validating nonce and signature semantics.

When NOT to Use

  • General contract authoring not involving account semantics.

Quick Start

  1. Confirm __validate__ enforces lightweight, bounded checks.
  2. Confirm __execute__ enforces policy and selector boundaries.
  3. Verify replay protections (nonce/domain separation) for all signature paths.
  4. Add regression tests for each fixed session-key or policy finding.
  5. Run cairo-auditor for final AA/security pass before merge.

Core Focus

  • __validate__ constraints and DoS resistance.
  • __execute__ policy enforcement correctness.
  • Replay protection and domain separation.
  • Privileged selector and self-call protection.

Workflow

References

starknet.js Example

import { Account, CallData, RpcProvider } from "starknet";

const provider = new RpcProvider({ nodeUrl: process.env.STARKNET_RPC! });
const account = new Account(provider, process.env.ACCOUNT_ADDRESS!, process.env.PRIVATE_KEY!);

// Validate preview (debug-only): inspect __validate__ behavior with the current nonce.
const nonce = await account.getNonce();
const call = { contractAddress: process.env.TARGET!, entrypoint: "set_limit", calldata: CallData.compile({ value: 7 }) };
await provider.callContract({
  contractAddress: account.address,
  entrypoint: "__validate__",
  calldata: CallData.compile({ calls: [call], nonce }),
});

// Execute path: real transaction that triggers __execute__ and nonce checks.
const tx = await account.execute([call]);
await provider.waitForTransaction(tx.transaction_hash);

Error Codes and Recovery

CodeConditionRecovery
AA-001__validate__ is too expensive or statefulRemove heavy logic from validation; add a test that caps validation steps.
AA-002__execute__ allows blocked selectors/self-callsEnforce selector filters and self-call checks; add authorized/unauthorized regression tests.
AA-003Nonce or domain mismatch causes replay riskNormalize nonce source/hash domain; add replay and cross-domain tests.
AA-999Unexpected runtime panicCapture calldata + caller context, reproduce in unit tests, then escalate to cairo-auditor.