The aa-sdk
is a type-safe and performant TypeScript library built on top of viem to provide ergonomic methods for sending user operations, sponsoring gas, and deploying smart contract accounts. It handles all the complexity of ERC-4337 under the hood to make account abstraction simple.
The SDK also implements an EIP-1193 provider interface to easily plug into any popular dapp or wallet connect libraries such as RainbowKit, Wagmi, and Web3Modal. It also includes ethers.js adapters to provide full support for ethers.js apps.
The aa-sdk
is modular at every layer of the stack and can be easily extended to fit your custom needs. You can plug in any smart account implementation, Signer, gas manager API, RPC provider.
yarn add @alchemy/aa-accounts @alchemy/aa-core
The aa-sdk
is part of Alchemy's Account Kit. For more information, check out the Account Kit docs.
- clone the repo
- run
yarn
- verify tests pass
- be sure to use the node version specified in package.json, currently 18.10
- run
node -v
- run
yarn build
- run
yarn test
- make changes to packages
- reverify that all tests pass
- format code changes
- run
yarn run lint:write
- run
- confirm code passes format checks
- run
yarn run lint:check
- run
- commit code with a standardized commit message
- format:
[subject-type]: [description starting with lowercase letters] (#[issue number])
- example:
feat: add sanity check on provider connect for clearer error message (#181)
- note: run
git log
to see more examples and acceptable subject-types
- format:
- push to your github fork
- create a pull request with the original Alchemy project
- note: pull request title must pass the Enforce PR Title Format
- format:
[subject-type]: [description starting with lowercase letters]
- run
echo "[YOUR_PR_TITLE_HERE] | yarn commitlint
- passing example: run
echo "docs: add build and test documentation update (#195)" | yarn commitlint
- celebrate