@aastar/sdk 0.14.0 → 0.14.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +28 -0
- package/.gitmodules +9 -0
- package/README.md +170 -0
- package/aastar-sdk.code-workspace +14 -0
- package/abis/BLSAggregator.json +572 -0
- package/abis/BLSValidator.json +26 -0
- package/abis/DVTValidator.json +370 -0
- package/abis/Eip7702Support.json +24 -0
- package/abis/EntryPoint.json +1379 -0
- package/abis/GToken.json +479 -0
- package/abis/GTokenStaking.json +944 -0
- package/abis/LegacyAccount.json +625 -0
- package/abis/MySBT.json +1586 -0
- package/abis/Paymaster.json +1205 -0
- package/abis/PaymasterFactory.json +650 -0
- package/abis/PaymasterV4_2.json +1183 -0
- package/abis/Registry.json +1636 -0
- package/abis/ReputationSystem.json +477 -0
- package/abis/SenderCreator.json +99 -0
- package/abis/Simple7702Account.json +395 -0
- package/abis/SimpleAccount.json +625 -0
- package/abis/SimpleAccountFactory.json +108 -0
- package/abis/SimpleAccountFactoryV08.json +87 -0
- package/abis/SimpleAccountV08.json +557 -0
- package/abis/SuperPaymaster.json +1399 -0
- package/abis/UserOperationLib.json +57 -0
- package/abis/aPNTs.json +1173 -0
- package/abis/xPNTsFactory.json +728 -0
- package/abis/xPNTsToken.json +1173 -0
- package/config/networks/README.md +54 -0
- package/config/networks/mainnet.env.example +39 -0
- package/config/networks/optimism-sepolia.env.example +35 -0
- package/config/networks/optimism.env.example +36 -0
- package/config/networks/sepolia.env.example +36 -0
- package/data/experiment_data.csv +36 -0
- package/data/industry_baseline_2025-12-23.json +154 -0
- package/data/industry_baseline_latest.json +154 -0
- package/docs/API_REFERENCE.md +796 -0
- package/docs/DAO_Mining_Distribution_Plan.md +522 -0
- package/docs/DOCUMENTATION_PLAN.md +455 -0
- package/docs/Plan.md +266 -0
- package/docs/Regression_Testing_Guide.md +70 -0
- package/docs/SDK_Optimization_Evaluation_Plan.md +51 -0
- package/docs/SEPOLIA_ENV_REFERENCE.md +51 -0
- package/docs/STAGE_3_SCENARIO_EXP_PLAN.md +77 -0
- package/docs/Script_Comparison_Report.md +91 -0
- package/docs/Sepolia_Latest_Deployment.md +117 -0
- package/docs/TEST_COVERAGE_MATRIX.md +72 -0
- package/docs/TODO_SDK_COVERAGE.md +55 -0
- package/docs/USER_CASE_DESIGN.md +110 -0
- package/docs/api/@aastar/account/README.md +15 -0
- package/docs/api/@aastar/account/classes/UserOpClient.md +87 -0
- package/docs/api/@aastar/account/functions/createEOAWalletClient.md +21 -0
- package/docs/api/@aastar/account/functions/getUserOpHash.md +23 -0
- package/docs/api/@aastar/account/functions/packUserOpLimits.md +19 -0
- package/docs/api/@aastar/account/functions/toSimpleSmartAccount.md +83 -0
- package/docs/api/@aastar/account/type-aliases/EOAWalletClient.md +37 -0
- package/docs/api/@aastar/account/type-aliases/SimpleSmartAccount.md +39 -0
- package/docs/api/@aastar/core/README.md +136 -0
- package/docs/api/@aastar/core/classes/BLSSigner.md +147 -0
- package/docs/api/@aastar/core/enumerations/NodeType.md +33 -0
- package/docs/api/@aastar/core/functions/aggregatorActions.md +2714 -0
- package/docs/api/@aastar/core/functions/createAAStarPublicClient.md +3105 -0
- package/docs/api/@aastar/core/functions/dvtActions.md +2714 -0
- package/docs/api/@aastar/core/functions/factoryActions.md +2714 -0
- package/docs/api/@aastar/core/functions/getAddressUrl.md +32 -0
- package/docs/api/@aastar/core/functions/getAllCommunityConfigs.md +9 -0
- package/docs/api/@aastar/core/functions/getAllV2Contracts.md +20 -0
- package/docs/api/@aastar/core/functions/getBlockExplorer.md +26 -0
- package/docs/api/@aastar/core/functions/getChainId.md +26 -0
- package/docs/api/@aastar/core/functions/getCommunities.md +76 -0
- package/docs/api/@aastar/core/functions/getCommunity.md +32 -0
- package/docs/api/@aastar/core/functions/getCommunityConfig.md +15 -0
- package/docs/api/@aastar/core/functions/getContract.md +37 -0
- package/docs/api/@aastar/core/functions/getContractNetworks.md +18 -0
- package/docs/api/@aastar/core/functions/getContracts.md +178 -0
- package/docs/api/@aastar/core/functions/getCoreContracts.md +55 -0
- package/docs/api/@aastar/core/functions/getDeploymentDate.md +32 -0
- package/docs/api/@aastar/core/functions/getEntryPoint.md +25 -0
- package/docs/api/@aastar/core/functions/getNetwork.md +26 -0
- package/docs/api/@aastar/core/functions/getPaymasterV4_1.md +25 -0
- package/docs/api/@aastar/core/functions/getRpcUrl.md +25 -0
- package/docs/api/@aastar/core/functions/getSimpleAccountFactory.md +25 -0
- package/docs/api/@aastar/core/functions/getSuperPaymasterV2.md +25 -0
- package/docs/api/@aastar/core/functions/getTestAccounts.md +30 -0
- package/docs/api/@aastar/core/functions/getTestTokenContracts.md +38 -0
- package/docs/api/@aastar/core/functions/getTokenContracts.md +31 -0
- package/docs/api/@aastar/core/functions/getTxUrl.md +32 -0
- package/docs/api/@aastar/core/functions/getV2ContractByAddress.md +28 -0
- package/docs/api/@aastar/core/functions/getV2ContractByName.md +28 -0
- package/docs/api/@aastar/core/functions/getV2ContractsByDate.md +26 -0
- package/docs/api/@aastar/core/functions/isContractNetworkSupported.md +27 -0
- package/docs/api/@aastar/core/functions/isRegisteredCommunity.md +15 -0
- package/docs/api/@aastar/core/functions/isV2Contract.md +27 -0
- package/docs/api/@aastar/core/functions/paymasterV4Actions.md +2719 -0
- package/docs/api/@aastar/core/functions/registryActions.md +2720 -0
- package/docs/api/@aastar/core/functions/reputationActions.md +2720 -0
- package/docs/api/@aastar/core/functions/sbtActions.md +2720 -0
- package/docs/api/@aastar/core/functions/stakingActions.md +2720 -0
- package/docs/api/@aastar/core/functions/superPaymasterActions.md +2720 -0
- package/docs/api/@aastar/core/functions/tokenActions.md +2714 -0
- package/docs/api/@aastar/core/interfaces/CommunityConfig.md +81 -0
- package/docs/api/@aastar/core/interfaces/ContractVersion.md +63 -0
- package/docs/api/@aastar/core/type-aliases/AggregatorActions.md +79 -0
- package/docs/api/@aastar/core/type-aliases/ContractCategory.md +5 -0
- package/docs/api/@aastar/core/type-aliases/ContractNetwork.md +5 -0
- package/docs/api/@aastar/core/type-aliases/DVTActions.md +139 -0
- package/docs/api/@aastar/core/type-aliases/FactoryActions.md +99 -0
- package/docs/api/@aastar/core/type-aliases/NetworkContracts.md +5 -0
- package/docs/api/@aastar/core/type-aliases/PaymasterV4Actions.md +422 -0
- package/docs/api/@aastar/core/type-aliases/RegistryActions.md +263 -0
- package/docs/api/@aastar/core/type-aliases/ReputationActions.md +47 -0
- package/docs/api/@aastar/core/type-aliases/RoleConfig.md +83 -0
- package/docs/api/@aastar/core/type-aliases/SBTActions.md +203 -0
- package/docs/api/@aastar/core/type-aliases/StakingActions.md +179 -0
- package/docs/api/@aastar/core/type-aliases/SuperPaymasterActions.md +219 -0
- package/docs/api/@aastar/core/type-aliases/SupportedNetwork.md +3 -0
- package/docs/api/@aastar/core/type-aliases/TokenActions.md +151 -0
- package/docs/api/@aastar/core/variables/AASTAR_COMMUNITY.md +8 -0
- package/docs/api/@aastar/core/variables/ALL_ADDRESSES.md +71 -0
- package/docs/api/@aastar/core/variables/BLSAggregatorABI.md +3 -0
- package/docs/api/@aastar/core/variables/BLSHelpers.md +91 -0
- package/docs/api/@aastar/core/variables/BPS_DENOMINATOR.md +5 -0
- package/docs/api/@aastar/core/variables/BRANDING.md +67 -0
- package/docs/api/@aastar/core/variables/BREAD_COMMUNITY.md +8 -0
- package/docs/api/@aastar/core/variables/COMMUNITIES.md +5 -0
- package/docs/api/@aastar/core/variables/COMMUNITY_OWNERS.md +15 -0
- package/docs/api/@aastar/core/variables/CONTRACTS.md +163 -0
- package/docs/api/@aastar/core/variables/CONTRACT_METADATA.md +67 -0
- package/docs/api/@aastar/core/variables/CORE_ADDRESSES.md +35 -0
- package/docs/api/@aastar/core/variables/DEFAULT_APNTS_PRICE_USD.md +5 -0
- package/docs/api/@aastar/core/variables/DEFAULT_GAS_TOKEN_MINT_AMOUNT.md +5 -0
- package/docs/api/@aastar/core/variables/DEFAULT_USDT_MINT_AMOUNT.md +5 -0
- package/docs/api/@aastar/core/variables/DVTValidatorABI.md +3 -0
- package/docs/api/@aastar/core/variables/EntryPointABI.md +3 -0
- package/docs/api/@aastar/core/variables/FAUCET_API_URL.md +5 -0
- package/docs/api/@aastar/core/variables/GTokenABI.md +3 -0
- package/docs/api/@aastar/core/variables/GTokenStakingABI.md +3 -0
- package/docs/api/@aastar/core/variables/LINKS.md +33 -0
- package/docs/api/@aastar/core/variables/MAX_SERVICE_FEE.md +5 -0
- package/docs/api/@aastar/core/variables/MONITORING_ADDRESSES.md +15 -0
- package/docs/api/@aastar/core/variables/MySBTABI.md +3 -0
- package/docs/api/@aastar/core/variables/NETWORKS.md +79 -0
- package/docs/api/@aastar/core/variables/NODE_STAKE_AMOUNTS.md +31 -0
- package/docs/api/@aastar/core/variables/OFFICIAL_ADDRESSES.md +11 -0
- package/docs/api/@aastar/core/variables/PAYMASTER_ADDRESSES.md +15 -0
- package/docs/api/@aastar/core/variables/PaymasterABI.md +3 -0
- package/docs/api/@aastar/core/variables/PaymasterFactoryABI.md +3 -0
- package/docs/api/@aastar/core/variables/PaymasterV4ABI.md +3 -0
- package/docs/api/@aastar/core/variables/ROLE_ANODE.md +3 -0
- package/docs/api/@aastar/core/variables/ROLE_COMMUNITY.md +3 -0
- package/docs/api/@aastar/core/variables/ROLE_ENDUSER.md +5 -0
- package/docs/api/@aastar/core/variables/ROLE_KMS.md +3 -0
- package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_AOA.md +3 -0
- package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_SUPER.md +3 -0
- package/docs/api/@aastar/core/variables/RegistryABI.md +3 -0
- package/docs/api/@aastar/core/variables/ReputationSystemABI.md +3 -0
- package/docs/api/@aastar/core/variables/ReputationSystemV3ABI.md +3 -0
- package/docs/api/@aastar/core/variables/SEPOLIA_CONTRACTS.md +159 -0
- package/docs/api/@aastar/core/variables/SEPOLIA_V2_VERSIONS.md +67 -0
- package/docs/api/@aastar/core/variables/SERVICE_FEE_RATE.md +5 -0
- package/docs/api/@aastar/core/variables/Simple7702AccountABI.md +3 -0
- package/docs/api/@aastar/core/variables/SimpleAccountABI.md +3 -0
- package/docs/api/@aastar/core/variables/SimpleAccountFactoryABI.md +3 -0
- package/docs/api/@aastar/core/variables/SimpleAccountFactoryV08ABI.md +3 -0
- package/docs/api/@aastar/core/variables/SimpleAccountV08ABI.md +3 -0
- package/docs/api/@aastar/core/variables/SuperPaymasterABI.md +3 -0
- package/docs/api/@aastar/core/variables/SuperPaymasterV3ABI.md +3 -0
- package/docs/api/@aastar/core/variables/TEST_ACCOUNT_ADDRESSES.md +11 -0
- package/docs/api/@aastar/core/variables/TEST_ACCOUNT_POOL_SIZE.md +5 -0
- package/docs/api/@aastar/core/variables/TEST_COMMUNITIES.md +19 -0
- package/docs/api/@aastar/core/variables/TEST_TOKEN_ADDRESSES.md +19 -0
- package/docs/api/@aastar/core/variables/TOKEN_ADDRESSES.md +11 -0
- package/docs/api/@aastar/core/variables/V2_SUMMARY.md +39 -0
- package/docs/api/@aastar/core/variables/xPNTsFactoryABI.md +3 -0
- package/docs/api/@aastar/core/variables/xPNTsTokenABI.md +3 -0
- package/docs/api/@aastar/paymaster/README.md +14 -0
- package/docs/api/@aastar/paymaster/classes/SuperPaymasterClient.md +163 -0
- package/docs/api/@aastar/paymaster/functions/checkEligibility.md +28 -0
- package/docs/api/@aastar/paymaster/functions/getPaymasterV4Middleware.md +32 -0
- package/docs/api/@aastar/paymaster/functions/getSuperPaymasterMiddleware.md +32 -0
- package/docs/api/@aastar/paymaster/type-aliases/PaymasterConfig.md +35 -0
- package/docs/api/@aastar/paymaster/type-aliases/PaymasterV4MiddlewareConfig.md +35 -0
- package/docs/api/@aastar/tokens/README.md +3 -0
- package/docs/api/@aastar/tokens/classes/FinanceClient.md +8653 -0
- package/docs/api/README.md +6 -0
- package/docs/examples/community-flow.md +28 -0
- package/docs/examples/enduser-flow.md +24 -0
- package/docs/examples/index.md +18 -0
- package/docs/examples/multi-chain.md +31 -0
- package/docs/examples/operator-flow.md +28 -0
- package/docs/guide/CLI_GUIDE.md +65 -0
- package/docs/guide/DOCUMENTATION_PLAN.md +455 -0
- package/docs/guide/Security-solution.md +106 -0
- package/docs/guide/TEST_COMMANDS.md +320 -0
- package/docs/guide/getting-started.md +133 -0
- package/docs/guide/installation.md +40 -0
- package/docs/guide/paper-data-collection.md +69 -0
- package/docs/guide/quick-start.md +52 -0
- package/docs/guide/task_breakdown.md +121 -0
- package/docs/old-solution.md +1078 -0
- package/docs/paper-data-collection.md +69 -0
- package/docs/technical_plan.md +510 -0
- package/docs/zh/examples/community-flow.md +38 -0
- package/docs/zh/examples/complete-workflow.md +10 -0
- package/docs/zh/examples/enduser-flow.md +33 -0
- package/docs/zh/examples/index.md +18 -0
- package/docs/zh/examples/multi-chain.md +46 -0
- package/docs/zh/examples/operator-flow.md +37 -0
- package/docs/zh/guide/CLI_GUIDE.md +48 -0
- package/docs/zh/guide/DOCUMENTATION_PLAN.md +455 -0
- package/docs/zh/guide/Plan.md +266 -0
- package/docs/zh/guide/SDK_Optimization_Evaluation_Plan.md +51 -0
- package/docs/zh/guide/Security-solution.md +106 -0
- package/docs/zh/guide/TEST_COMMANDS.md +125 -0
- package/docs/zh/guide/TEST_COVERAGE_MATRIX.md +72 -0
- package/docs/zh/guide/concepts/account-abstraction.md +95 -0
- package/docs/zh/guide/concepts/rainbow-bridge.md +68 -0
- package/docs/zh/guide/concepts/reputation.md +95 -0
- package/docs/zh/guide/concepts/superpaymaster.md +141 -0
- package/docs/zh/guide/getting-started.md +133 -0
- package/docs/zh/guide/installation.md +107 -0
- package/docs/zh/guide/old-solution.md +1078 -0
- package/docs/zh/guide/paper-data-collection.md +69 -0
- package/docs/zh/guide/quick-start.md +134 -0
- package/docs/zh/guide/sdk-readme.md +253 -0
- package/docs/zh/guide/task_breakdown.md +76 -0
- package/docs/zh/guide/technical_plan.md +510 -0
- package/docs/zh/guide/use-cases/community-management.md +141 -0
- package/docs/zh/guide/use-cases/gasless-transactions.md +71 -0
- package/docs/zh/guide/use-cases/operator-staking.md +84 -0
- package/docs/zh/guide/use-cases/yop.md +72 -0
- package/examples/sdk-demo/DEVELOPER_GUIDE.md +159 -0
- package/examples/sdk-demo/README.md +30 -0
- package/examples/sdk-demo/usage.ts +137 -0
- package/ext/aastar-shared-config/.env.example +6 -0
- package/ext/aastar-shared-config/.github/workflows/check-secrets.yml +257 -0
- package/ext/aastar-shared-config/AGENTS.md +21 -0
- package/ext/aastar-shared-config/CHANGELOG.md +99 -0
- package/ext/aastar-shared-config/LICENSE +21 -0
- package/ext/aastar-shared-config/QUICK_START.md +215 -0
- package/ext/aastar-shared-config/README.md +412 -0
- package/ext/aastar-shared-config/SHARED_CONFIG_SUMMARY.md +273 -0
- package/ext/aastar-shared-config/check-locker-status.mjs +7 -0
- package/ext/aastar-shared-config/favicon.ico +0 -0
- package/ext/aastar-shared-config/generate-comparison-table.sh +67 -0
- package/ext/aastar-shared-config/package.json +46 -0
- package/ext/aastar-shared-config/pnpm-lock.yaml +1182 -0
- package/ext/aastar-shared-config/src/abis/BLSAggregator.json +1 -0
- package/ext/aastar-shared-config/src/abis/DVTValidator.json +1 -0
- package/ext/aastar-shared-config/src/abis/GToken.json +1 -0
- package/ext/aastar-shared-config/src/abis/GTokenStaking.json +1 -0
- package/ext/aastar-shared-config/src/abis/MySBT.json +1 -0
- package/ext/aastar-shared-config/src/abis/PaymasterFactory.json +1 -0
- package/ext/aastar-shared-config/src/abis/PaymasterV4.json +1098 -0
- package/ext/aastar-shared-config/src/abis/Registry.json +1 -0
- package/ext/aastar-shared-config/src/abis/SimpleAccount.json +557 -0
- package/ext/aastar-shared-config/src/abis/SimpleAccountFactory.json +87 -0
- package/ext/aastar-shared-config/src/abis/SuperPaymasterV2.json +1 -0
- package/ext/aastar-shared-config/src/abis/index.ts +45 -0
- package/ext/aastar-shared-config/src/abis/xPNTsFactory.json +1 -0
- package/ext/aastar-shared-config/src/abis/xPNTsToken.json +1 -0
- package/ext/aastar-shared-config/src/branding.ts +32 -0
- package/ext/aastar-shared-config/src/communities.ts +93 -0
- package/ext/aastar-shared-config/src/constants.ts +67 -0
- package/ext/aastar-shared-config/src/contract-addresses.ts +95 -0
- package/ext/aastar-shared-config/src/contract-versions.ts +374 -0
- package/ext/aastar-shared-config/src/contracts.ts +414 -0
- package/ext/aastar-shared-config/src/index.ts +14 -0
- package/ext/aastar-shared-config/src/networks.ts +117 -0
- package/ext/aastar-shared-config/sync-abis.sh +92 -0
- package/ext/aastar-shared-config/sync-versions.mjs +150 -0
- package/ext/aastar-shared-config/tsconfig.json +18 -0
- package/ext/aastar-shared-config/tsup.config.ts +10 -0
- package/ext/aastar-shared-config/verify-all.sh +207 -0
- package/ext/aastar-shared-config/verify-contracts.sh +85 -0
- package/ext/aastar-shared-config/verify-mysbt-v243.mjs +27 -0
- package/ext/aastar-shared-config/verify-onchain-versions.mjs +93 -0
- package/ext/permissionless.js/.changeset/README.md +8 -0
- package/ext/permissionless.js/.changeset/config.json +11 -0
- package/ext/permissionless.js/.env-example +2 -0
- package/ext/permissionless.js/.github/actions/install-dependencies/action.yml +17 -0
- package/ext/permissionless.js/.github/dependabot.yaml +10 -0
- package/ext/permissionless.js/.github/workflows/canary.yml +49 -0
- package/ext/permissionless.js/.github/workflows/on-pull-request.yml +61 -0
- package/ext/permissionless.js/.github/workflows/on-push-to-main.yml +59 -0
- package/ext/permissionless.js/.github/workflows/prune-tags.yml +92 -0
- package/ext/permissionless.js/.github/workflows/verify.yml +114 -0
- package/ext/permissionless.js/.size-limit.json +13 -0
- package/ext/permissionless.js/LICENSE +21 -0
- package/ext/permissionless.js/assets/banner.png +0 -0
- package/ext/permissionless.js/biome.json +46 -0
- package/ext/permissionless.js/bun.lock +2340 -0
- package/ext/permissionless.js/bun.lockb +0 -0
- package/ext/permissionless.js/package.json +82 -0
- package/ext/permissionless.js/packages/mock-paymaster/CHANGELOG.md +31 -0
- package/ext/permissionless.js/packages/mock-paymaster/constants.ts +84 -0
- package/ext/permissionless.js/packages/mock-paymaster/helpers/abi.ts +1048 -0
- package/ext/permissionless.js/packages/mock-paymaster/helpers/erc20-utils.ts +105 -0
- package/ext/permissionless.js/packages/mock-paymaster/helpers/schema.ts +307 -0
- package/ext/permissionless.js/packages/mock-paymaster/helpers/utils.ts +78 -0
- package/ext/permissionless.js/packages/mock-paymaster/index.ts +63 -0
- package/ext/permissionless.js/packages/mock-paymaster/package.json +33 -0
- package/ext/permissionless.js/packages/mock-paymaster/relay.ts +424 -0
- package/ext/permissionless.js/packages/mock-paymaster/setup.ts +163 -0
- package/ext/permissionless.js/packages/mock-paymaster/singletonPaymasters.ts +230 -0
- package/ext/permissionless.js/packages/permissionless/CHANGELOG.md +893 -0
- package/ext/permissionless.js/packages/permissionless/README.md +122 -0
- package/ext/permissionless.js/packages/permissionless/accounts/biconomy/abi/BiconomySmartAccountAbi.ts +128 -0
- package/ext/permissionless.js/packages/permissionless/accounts/biconomy/toBiconomySmartAccount.ts +374 -0
- package/ext/permissionless.js/packages/permissionless/accounts/decodeCalls.test.ts +505 -0
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/abi/EtherspotBootstrapAbi.ts +94 -0
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/constants.ts +27 -0
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/toEtherspotSmartAccount.ts +369 -0
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/getInitMSAData.ts +56 -0
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/getNonceKey.ts +21 -0
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/wrapMessageHash.ts +43 -0
- package/ext/permissionless.js/packages/permissionless/accounts/index.ts +86 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelAccountAbi.ts +87 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3AccountAbi.ts +813 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3FactoryAbi.ts +12 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3MetaFactoryAbi.ts +17 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/constants.ts +14 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/to7702KernelSmartAccount.ts +63 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/toEcdsaKernelSmartAccount.ts +62 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/toKernelSmartAccount.ts +984 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/decodeCallData.ts +43 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/encodeCallData.ts +57 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/getNonceKey.ts +33 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/isKernelV2.ts +6 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/isWebAuthnAccount.ts +8 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/signMessage.ts +115 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/signTypedData.ts +97 -0
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/wrapMessageHash.ts +44 -0
- package/ext/permissionless.js/packages/permissionless/accounts/light/toLightSmartAccount.ts +496 -0
- package/ext/permissionless.js/packages/permissionless/accounts/nexus/toNexusSmartAccount.ts +351 -0
- package/ext/permissionless.js/packages/permissionless/accounts/safe/index.ts +14 -0
- package/ext/permissionless.js/packages/permissionless/accounts/safe/signUserOperation.test.ts +275 -0
- package/ext/permissionless.js/packages/permissionless/accounts/safe/signUserOperation.ts +316 -0
- package/ext/permissionless.js/packages/permissionless/accounts/safe/toSafeSmartAccount.ts +1980 -0
- package/ext/permissionless.js/packages/permissionless/accounts/simple/to7702SimpleSmartAccount.ts +51 -0
- package/ext/permissionless.js/packages/permissionless/accounts/simple/toSimpleSmartAccount.ts +585 -0
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/toThirdwebSmartAccount.ts +221 -0
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/decodeCallData.ts +87 -0
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/encodeCallData.ts +81 -0
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/getAccountAddress.ts +48 -0
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/getFactoryData.ts +40 -0
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/signMessage.ts +33 -0
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/signTypedData.ts +67 -0
- package/ext/permissionless.js/packages/permissionless/accounts/trust/toTrustSmartAccount.ts +232 -0
- package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/decodeCallData.ts +87 -0
- package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/encodeCallData.ts +81 -0
- package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/getFactoryData.ts +51 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/accountId.test.ts +39 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/accountId.ts +93 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModule.test.ts +216 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModule.ts +99 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModules.test.ts +237 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModules.ts +96 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/isModuleInstalled.test.ts +72 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/isModuleInstalled.ts +132 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsExecutionMode.test.ts +108 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsExecutionMode.ts +158 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsModule.test.ts +35 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsModule.ts +120 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModule.test.ts +129 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModule.ts +98 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModules.test.ts +117 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModules.ts +87 -0
- package/ext/permissionless.js/packages/permissionless/actions/erc7579.ts +103 -0
- package/ext/permissionless.js/packages/permissionless/actions/etherspot/getUserOperationGasPrice.ts +32 -0
- package/ext/permissionless.js/packages/permissionless/actions/etherspot.ts +4 -0
- package/ext/permissionless.js/packages/permissionless/actions/index.ts +9 -0
- package/ext/permissionless.js/packages/permissionless/actions/package.json +6 -0
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/getCredentials.ts +47 -0
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/startAuthentication.ts +39 -0
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/startRegistration.ts +126 -0
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/verifyAuthentication.ts +142 -0
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/verifyRegistration.ts +132 -0
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer.ts +17 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/estimateErc20PaymasterCost.ts +102 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getTokenQuotes.test.ts +90 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getTokenQuotes.ts +77 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationGasPrice.test.ts +82 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationGasPrice.ts +67 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationStatus.test.ts +199 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationStatus.ts +49 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/sendCompressedUserOperation.ts +59 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/sponsorUserOperation.test.ts +236 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/sponsorUserOperation.ts +151 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/validateSponsorshipPolicies.test.ts +153 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/validateSponsorshipPolicies.ts +74 -0
- package/ext/permissionless.js/packages/permissionless/actions/pimlico.ts +38 -0
- package/ext/permissionless.js/packages/permissionless/actions/public/getAccountNonce.test.ts +96 -0
- package/ext/permissionless.js/packages/permissionless/actions/public/getAccountNonce.ts +75 -0
- package/ext/permissionless.js/packages/permissionless/actions/public/getSenderAddress.test.ts +154 -0
- package/ext/permissionless.js/packages/permissionless/actions/public/getSenderAddress.ts +129 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/getCallsStatus.test.ts +255 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/getCallsStatus.ts +91 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendCalls.test.ts +571 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendCalls.ts +38 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendTransaction.test.ts +416 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendTransaction.ts +133 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signMessage.test.ts +219 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signMessage.ts +73 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signTypedData.test.ts +228 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signTypedData.ts +157 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/writeContract.ts +70 -0
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount.ts +7 -0
- package/ext/permissionless.js/packages/permissionless/clients/createSmartAccountClient.ts +181 -0
- package/ext/permissionless.js/packages/permissionless/clients/decorators/passkeyServer.ts +57 -0
- package/ext/permissionless.js/packages/permissionless/clients/decorators/pimlico.ts +189 -0
- package/ext/permissionless.js/packages/permissionless/clients/decorators/smartAccount.ts +350 -0
- package/ext/permissionless.js/packages/permissionless/clients/index.ts +2 -0
- package/ext/permissionless.js/packages/permissionless/clients/passkeyServer.ts +69 -0
- package/ext/permissionless.js/packages/permissionless/clients/pimlico.ts +124 -0
- package/ext/permissionless.js/packages/permissionless/errors/index.ts +17 -0
- package/ext/permissionless.js/packages/permissionless/experimental/pimlico/index.ts +1 -0
- package/ext/permissionless.js/packages/permissionless/experimental/pimlico/utils/prepareUserOperationForErc20Paymaster.test.ts +523 -0
- package/ext/permissionless.js/packages/permissionless/experimental/pimlico/utils/prepareUserOperationForErc20Paymaster.ts +369 -0
- package/ext/permissionless.js/packages/permissionless/index.ts +3 -0
- package/ext/permissionless.js/packages/permissionless/package.json +102 -0
- package/ext/permissionless.js/packages/permissionless/types/etherspot.ts +12 -0
- package/ext/permissionless.js/packages/permissionless/types/package.json +6 -0
- package/ext/permissionless.js/packages/permissionless/types/passkeyServer.ts +125 -0
- package/ext/permissionless.js/packages/permissionless/types/pimlico.ts +151 -0
- package/ext/permissionless.js/packages/permissionless/utils/decode7579Calls.ts +133 -0
- package/ext/permissionless.js/packages/permissionless/utils/decodeNonce.test.ts +40 -0
- package/ext/permissionless.js/packages/permissionless/utils/decodeNonce.ts +10 -0
- package/ext/permissionless.js/packages/permissionless/utils/deepHexlify.test.ts +57 -0
- package/ext/permissionless.js/packages/permissionless/utils/deepHexlify.ts +35 -0
- package/ext/permissionless.js/packages/permissionless/utils/encode7579Calls.test.ts +69 -0
- package/ext/permissionless.js/packages/permissionless/utils/encode7579Calls.ts +114 -0
- package/ext/permissionless.js/packages/permissionless/utils/encodeInstallModule.ts +91 -0
- package/ext/permissionless.js/packages/permissionless/utils/encodeNonce.test.ts +38 -0
- package/ext/permissionless.js/packages/permissionless/utils/encodeNonce.ts +8 -0
- package/ext/permissionless.js/packages/permissionless/utils/encodeUninstallModule.ts +88 -0
- package/ext/permissionless.js/packages/permissionless/utils/erc20AllowanceOverride.test.ts +59 -0
- package/ext/permissionless.js/packages/permissionless/utils/erc20AllowanceOverride.ts +66 -0
- package/ext/permissionless.js/packages/permissionless/utils/erc20BalanceOverride.test.ts +57 -0
- package/ext/permissionless.js/packages/permissionless/utils/erc20BalanceOverride.ts +49 -0
- package/ext/permissionless.js/packages/permissionless/utils/getAddressFromInitCodeOrPaymasterAndData.test.ts +31 -0
- package/ext/permissionless.js/packages/permissionless/utils/getAddressFromInitCodeOrPaymasterAndData.ts +13 -0
- package/ext/permissionless.js/packages/permissionless/utils/getEstimationCallData.ts +297 -0
- package/ext/permissionless.js/packages/permissionless/utils/getPackedUserOperation.test.ts +204 -0
- package/ext/permissionless.js/packages/permissionless/utils/getPackedUserOperation.ts +122 -0
- package/ext/permissionless.js/packages/permissionless/utils/getRequiredPrefund.test.ts +90 -0
- package/ext/permissionless.js/packages/permissionless/utils/getRequiredPrefund.ts +56 -0
- package/ext/permissionless.js/packages/permissionless/utils/index.ts +43 -0
- package/ext/permissionless.js/packages/permissionless/utils/isSmartAccountDeployed.ts +13 -0
- package/ext/permissionless.js/packages/permissionless/utils/ox.ts +48 -0
- package/ext/permissionless.js/packages/permissionless/utils/toOwner.ts +89 -0
- package/ext/permissionless.js/packages/permissionless/vitest.config.ts +31 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/biconomy.ts +22 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/etherspot.ts +12 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/kernel.ts +63 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/light.ts +10 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/nexus.ts +16 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/safe.ts +75 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/simple.ts +16 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/thirdweb.ts +7 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/trust.ts +26 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/core.ts +24 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/index.ts +10 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/index.ts +783 -0
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/instance.ts +290 -0
- package/ext/permissionless.js/packages/permissionless-test/src/testWithRpc.ts +128 -0
- package/ext/permissionless.js/packages/permissionless-test/src/types.ts +12 -0
- package/ext/permissionless.js/packages/permissionless-test/src/utils.ts +1091 -0
- package/ext/permissionless.js/packages/wagmi/CHANGELOG.md +53 -0
- package/ext/permissionless.js/packages/wagmi/README.md +93 -0
- package/ext/permissionless.js/packages/wagmi/context.ts +22 -0
- package/ext/permissionless.js/packages/wagmi/hooks/useAvailableCapabilities.ts +43 -0
- package/ext/permissionless.js/packages/wagmi/hooks/useSendTransaction.ts +164 -0
- package/ext/permissionless.js/packages/wagmi/hooks/useWaitForTransactionReceipt.ts +427 -0
- package/ext/permissionless.js/packages/wagmi/index.ts +15 -0
- package/ext/permissionless.js/packages/wagmi/package.json +26 -0
- package/ext/permissionless.js/packages/wagmi/utils/observe.ts +76 -0
- package/ext/permissionless.js/packages/wagmi-demo/README.md +1 -0
- package/ext/permissionless.js/packages/wagmi-demo/biome.json +13 -0
- package/ext/permissionless.js/packages/wagmi-demo/index.html +12 -0
- package/ext/permissionless.js/packages/wagmi-demo/package.json +16 -0
- package/ext/permissionless.js/packages/wagmi-demo/src/App.tsx +98 -0
- package/ext/permissionless.js/packages/wagmi-demo/src/PasskeyServerDemo.tsx +286 -0
- package/ext/permissionless.js/packages/wagmi-demo/src/PasskeysDemo.tsx +457 -0
- package/ext/permissionless.js/packages/wagmi-demo/src/index.css +21 -0
- package/ext/permissionless.js/packages/wagmi-demo/src/main.tsx +275 -0
- package/ext/permissionless.js/packages/wagmi-demo/src/vite-env.d.ts +1 -0
- package/ext/permissionless.js/packages/wagmi-demo/src/wagmi.ts +33 -0
- package/ext/permissionless.js/packages/wagmi-demo/tsconfig.json +25 -0
- package/ext/permissionless.js/packages/wagmi-demo/tsconfig.node.json +12 -0
- package/ext/permissionless.js/packages/wagmi-demo/vite.config.ts +7 -0
- package/ext/permissionless.js/tsconfig/tsconfig.base.json +42 -0
- package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.cjs.json +11 -0
- package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.esm.json +9 -0
- package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.json +17 -0
- package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.types.json +13 -0
- package/ext/permissionless.js/tsconfig/tsconfig.permissionless.cjs.json +11 -0
- package/ext/permissionless.js/tsconfig/tsconfig.permissionless.esm.json +9 -0
- package/ext/permissionless.js/tsconfig/tsconfig.permissionless.json +18 -0
- package/ext/permissionless.js/tsconfig/tsconfig.permissionless.types.json +13 -0
- package/ext/permissionless.js/tsconfig/tsconfig.wagmi.esm.json +8 -0
- package/ext/permissionless.js/tsconfig/tsconfig.wagmi.json +19 -0
- package/ext/permissionless.js/tsconfig/tsconfig.wagmi.types.json +12 -0
- package/extract_abis.sh +140 -0
- package/extract_addresses_to_env.sh +67 -0
- package/final_safe_harmonize.py +77 -0
- package/lib/SHARED_CONFIG_REFERENCE.md +133 -0
- package/lib/shared-config/.env.example +6 -0
- package/lib/shared-config/.github/workflows/check-secrets.yml +257 -0
- package/lib/shared-config/AGENTS.md +21 -0
- package/lib/shared-config/CHANGELOG.md +99 -0
- package/lib/shared-config/LICENSE +21 -0
- package/lib/shared-config/QUICK_START.md +215 -0
- package/lib/shared-config/README.md +412 -0
- package/lib/shared-config/SHARED_CONFIG_SUMMARY.md +273 -0
- package/lib/shared-config/check-locker-status.mjs +7 -0
- package/lib/shared-config/favicon.ico +0 -0
- package/lib/shared-config/generate-comparison-table.sh +67 -0
- package/lib/shared-config/package.json +46 -0
- package/lib/shared-config/pnpm-lock.yaml +1182 -0
- package/lib/shared-config/src/abis/BLSAggregator.json +1 -0
- package/lib/shared-config/src/abis/DVTValidator.json +1 -0
- package/lib/shared-config/src/abis/GToken.json +1 -0
- package/lib/shared-config/src/abis/GTokenStaking.json +1 -0
- package/lib/shared-config/src/abis/MySBT.json +1 -0
- package/lib/shared-config/src/abis/PaymasterFactory.json +1 -0
- package/lib/shared-config/src/abis/PaymasterV4.json +1098 -0
- package/lib/shared-config/src/abis/Registry.json +1 -0
- package/lib/shared-config/src/abis/SimpleAccount.json +557 -0
- package/lib/shared-config/src/abis/SimpleAccountFactory.json +87 -0
- package/lib/shared-config/src/abis/SuperPaymasterV2.json +1 -0
- package/lib/shared-config/src/abis/index.ts +45 -0
- package/lib/shared-config/src/abis/xPNTsFactory.json +1 -0
- package/lib/shared-config/src/abis/xPNTsToken.json +1 -0
- package/lib/shared-config/src/branding.ts +32 -0
- package/lib/shared-config/src/communities.ts +93 -0
- package/lib/shared-config/src/constants.ts +67 -0
- package/lib/shared-config/src/contract-addresses.ts +95 -0
- package/lib/shared-config/src/contract-versions.ts +374 -0
- package/lib/shared-config/src/contracts.ts +414 -0
- package/lib/shared-config/src/index.ts +14 -0
- package/lib/shared-config/src/networks.ts +117 -0
- package/lib/shared-config/sync-abis.sh +92 -0
- package/lib/shared-config/sync-versions.mjs +150 -0
- package/lib/shared-config/tsconfig.json +18 -0
- package/lib/shared-config/tsup.config.ts +10 -0
- package/lib/shared-config/verify-all.sh +207 -0
- package/lib/shared-config/verify-contracts.sh +85 -0
- package/lib/shared-config/verify-mysbt-v243.mjs +27 -0
- package/lib/shared-config/verify-onchain-versions.mjs +93 -0
- package/package.json +53 -21
- package/packages/account/package.json +20 -0
- package/packages/account/src/accounts/simple.ts +84 -0
- package/packages/account/src/eoa.ts +31 -0
- package/packages/account/src/index.ts +61 -0
- package/packages/account/tsconfig.json +12 -0
- package/packages/analytics/package.json +21 -0
- package/packages/analytics/src/index.ts +145 -0
- package/packages/analytics/tsconfig.json +16 -0
- package/packages/community/package.json +22 -0
- package/packages/community/src/index.ts +306 -0
- package/packages/community/tsconfig.json +8 -0
- package/packages/core/package.json +22 -0
- package/packages/core/src/abis/BLSAggregator.json +572 -0
- package/packages/core/src/abis/BLSValidator.json +26 -0
- package/packages/core/src/abis/DVTValidator.json +370 -0
- package/packages/core/src/abis/Eip7702Support.json +24 -0
- package/packages/core/src/abis/EntryPoint.json +1379 -0
- package/packages/core/src/abis/GToken.json +523 -0
- package/packages/core/src/abis/GTokenStaking.json +931 -0
- package/packages/core/src/abis/LegacyAccount.json +625 -0
- package/packages/core/src/abis/MySBT.json +1586 -0
- package/packages/core/src/abis/Paymaster.json +1205 -0
- package/packages/core/src/abis/PaymasterFactory.json +650 -0
- package/packages/core/src/abis/PaymasterV4_2.json +1183 -0
- package/packages/core/src/abis/Registry.json +1636 -0
- package/packages/core/src/abis/ReputationSystem.json +477 -0
- package/packages/core/src/abis/SenderCreator.json +99 -0
- package/packages/core/src/abis/Simple7702Account.json +395 -0
- package/packages/core/src/abis/SimpleAccount.json +625 -0
- package/packages/core/src/abis/SimpleAccountFactory.json +108 -0
- package/packages/core/src/abis/SimpleAccountFactoryV08.json +87 -0
- package/packages/core/src/abis/SimpleAccountV08.json +557 -0
- package/packages/core/src/abis/SuperPaymaster.json +1399 -0
- package/packages/core/src/abis/UserOperationLib.json +57 -0
- package/packages/core/src/abis/aPNTs.json +1173 -0
- package/packages/core/src/abis/index.ts +68 -0
- package/packages/core/src/abis/xPNTsFactory.json +728 -0
- package/packages/core/src/abis/xPNTsToken.json +1173 -0
- package/packages/core/src/actions/aggregator.ts +41 -0
- package/packages/core/src/actions/dvt.ts +53 -0
- package/packages/core/src/actions/factory.ts +41 -0
- package/packages/core/src/actions/index.ts +10 -0
- package/packages/core/src/actions/paymasterV4.ts +263 -0
- package/packages/core/src/actions/registry.ts +120 -0
- package/packages/core/src/actions/reputation.ts +27 -0
- package/packages/core/src/actions/sbt.ts +97 -0
- package/packages/core/src/actions/staking.ts +79 -0
- package/packages/core/src/actions/superPaymaster.ts +117 -0
- package/packages/core/src/actions/tokens.ts +65 -0
- package/packages/core/src/branding.ts +32 -0
- package/packages/core/src/clients.ts +13 -0
- package/packages/core/src/communities.ts +93 -0
- package/packages/core/src/constants.ts +81 -0
- package/packages/core/src/contract-addresses.ts +101 -0
- package/packages/core/src/contract-versions.ts +374 -0
- package/packages/core/src/contracts.ts +414 -0
- package/packages/core/src/crypto/blsSigner.ts +124 -0
- package/packages/core/src/crypto/index.ts +1 -0
- package/packages/core/src/index.ts +19 -0
- package/packages/core/src/networks.ts +127 -0
- package/packages/core/src/requirementChecker.ts +225 -0
- package/packages/core/src/roles.ts +244 -0
- package/packages/core/src/utils.ts +23 -0
- package/packages/core/tsconfig.json +12 -0
- package/packages/dapp/package.json +27 -0
- package/packages/dapp/src/index.ts +4 -0
- package/packages/dapp/src/ui/components/EvaluationPanel.tsx +40 -0
- package/packages/dapp/src/ui/hooks/useCreditScore.ts +44 -0
- package/packages/dapp/src/ui/hooks/useSuperPaymaster.ts +31 -0
- package/packages/dapp/src/ui/index.ts +22 -0
- package/packages/dapp/tsconfig.json +13 -0
- package/packages/enduser/package.json +21 -0
- package/packages/enduser/src/index.ts +138 -0
- package/packages/enduser/tsconfig.json +8 -0
- package/packages/identity/package.json +22 -0
- package/packages/identity/src/index.ts +82 -0
- package/packages/identity/src/mysbt.ts +48 -0
- package/packages/identity/tsconfig.json +12 -0
- package/packages/operator/package.json +21 -0
- package/packages/operator/src/index.ts +172 -0
- package/packages/operator/tsconfig.json +8 -0
- package/packages/paymaster/package.json +22 -0
- package/packages/paymaster/src/SuperPaymaster/index.ts +168 -0
- package/packages/paymaster/src/V4/index.ts +123 -0
- package/packages/paymaster/src/index.ts +5 -0
- package/packages/paymaster/tsconfig.json +12 -0
- package/packages/sdk/README.md +150 -0
- package/packages/sdk/aastar/package.json +21 -0
- package/packages/sdk/aastar/src/index.ts +3 -0
- package/packages/sdk/aastar/tsconfig.json +8 -0
- package/packages/sdk/examples/config.json +1 -0
- package/packages/sdk/examples/regression_test.ts +106 -0
- package/packages/sdk/package.json +32 -0
- package/packages/sdk/src/clients/admin.ts +54 -0
- package/packages/sdk/src/clients/community.ts +403 -0
- package/packages/sdk/src/clients/endUser.ts +173 -0
- package/packages/sdk/src/clients/operator.ts +277 -0
- package/packages/sdk/src/errors/decoder.ts +48 -0
- package/{dist/index.js → packages/sdk/src/index.ts} +9 -1
- package/packages/sdk/src/utils/errorHandler.ts +167 -0
- package/packages/sdk/src/utils/funding.ts +280 -0
- package/packages/sdk/src/utils/keys.ts +159 -0
- package/packages/sdk/src/utils/roleData.ts +151 -0
- package/packages/sdk/src/utils/validation.ts +356 -0
- package/packages/sdk/tsconfig.json +12 -0
- package/packages/tokens/package.json +22 -0
- package/packages/tokens/src/index.ts +245 -0
- package/packages/tokens/tsconfig.json +12 -0
- package/pnpm-workspace.yaml +2 -0
- package/run_full_regression.sh +215 -0
- package/run_sdk_regression.sh +213 -0
- package/safe_harmonize.py +107 -0
- package/scripts/00_utils.ts +59 -0
- package/scripts/00_verify_phase1.ts +130 -0
- package/scripts/01_1_prep_gtoken.ts +81 -0
- package/scripts/01_2_register_sbt.ts +88 -0
- package/scripts/01_3_prep_tokens_paymaster.ts +102 -0
- package/scripts/01_prepare_all.ts +271 -0
- package/scripts/02_test_eoa.ts +50 -0
- package/scripts/03_test_standard_aa.ts +173 -0
- package/scripts/04_0_check_deploy.ts +24 -0
- package/scripts/04_1_check_allowance.ts +44 -0
- package/scripts/04_2_construct_verify.ts +96 -0
- package/scripts/04_3_verify_estimate.ts +66 -0
- package/scripts/04_4_verify_pack.ts +74 -0
- package/scripts/04_test_paymaster_v4.ts +217 -0
- package/scripts/05_1_deposit.ts +48 -0
- package/scripts/05_test_superpaymaster.ts +380 -0
- package/scripts/06_local_test_v3_admin.ts +163 -0
- package/scripts/06_local_test_v3_execution.ts +132 -0
- package/scripts/06_local_test_v3_full.ts +490 -0
- package/scripts/06_local_test_v3_funding.ts +124 -0
- package/scripts/06_local_test_v3_reputation.ts +234 -0
- package/scripts/07_local_test_v3_audit.ts +181 -0
- package/scripts/08_local_test_registry_lifecycle.ts +382 -0
- package/scripts/09_local_test_community_lifecycle.ts +384 -0
- package/scripts/09_local_test_community_simple.ts +108 -0
- package/scripts/09_scenario_bread_independent.ts +247 -0
- package/scripts/10_scenario_super_shared.ts +196 -0
- package/scripts/10_test_protocol_admin_full.ts +173 -0
- package/scripts/11_scenario_hacker_defense.ts +104 -0
- package/scripts/11_test_core_flows_full.ts +279 -0
- package/scripts/12_test_slash_mechanism.ts +205 -0
- package/scripts/12_test_slash_queries.ts +83 -0
- package/scripts/12_test_staking_exit.ts +152 -0
- package/scripts/12_test_staking_slash.ts +301 -0
- package/scripts/12_test_tier2_slash.ts +139 -0
- package/scripts/13_test_sbt_burn_linkage.ts +266 -0
- package/scripts/14_test_credit_redesign.ts +266 -0
- package/scripts/15_test_bls_full.ts +125 -0
- package/scripts/15_test_dvt_bls_full.ts +133 -0
- package/scripts/17_test_cross_role_collaboration.ts +95 -0
- package/scripts/18_sdk_e2e_verification.ts +67 -0
- package/scripts/18_test_dvt_sdk_flow.ts +138 -0
- package/scripts/18_test_lifecycle_completion.ts +144 -0
- package/scripts/19_sdk_experiment_runner.ts +89 -0
- package/scripts/19_sdk_experiment_runner.ts.backup +391 -0
- package/scripts/20_sdk_full_capability.ts +95 -0
- package/scripts/20_test_superpaymaster_new_apis.ts +193 -0
- package/scripts/21_test_paymasterv4_complete.ts +341 -0
- package/scripts/22_test_bls_signing.ts +260 -0
- package/scripts/23_test_middleware.ts +197 -0
- package/scripts/98_edge_reentrancy.ts +85 -0
- package/scripts/99_bug_hunting_fast.ts +216 -0
- package/scripts/collect_industry_baseline.ts +236 -0
- package/scripts/complete_env_config.ts +97 -0
- package/scripts/debug_account_c.ts +43 -0
- package/scripts/debug_bls.ts +58 -0
- package/scripts/debug_config_v036.ts +13 -0
- package/scripts/debug_contracts.ts +2 -0
- package/scripts/debug_env.ts +69 -0
- package/scripts/debug_find_paymaster.ts +98 -0
- package/scripts/debug_isolated_registration.ts +256 -0
- package/scripts/debug_paymaster_config.ts +19 -0
- package/scripts/debug_pim_addr.ts +23 -0
- package/scripts/debug_pm_status.ts +51 -0
- package/scripts/debug_registry.ts +39 -0
- package/scripts/debug_registry_setup.ts +129 -0
- package/scripts/debug_sanity.ts +32 -0
- package/scripts/debug_shared_config.ts +10 -0
- package/scripts/debug_token_compat.ts +51 -0
- package/scripts/debug_tokens.ts +41 -0
- package/scripts/debug_vcheck.ts +33 -0
- package/scripts/deploy_and_init_v3.sh +134 -0
- package/scripts/deploy_anvil_accounts.ts +144 -0
- package/scripts/deploy_paymaster_v4.ts +139 -0
- package/scripts/deploy_test_accounts.ts +401 -0
- package/scripts/experiment/stage3/SETUP_GUIDE.md +258 -0
- package/scripts/experiment/stage3/archived_scripts/00_token_distribution.ts +78 -0
- package/scripts/experiment/stage3/archived_scripts/01_dao_launch.ts +96 -0
- package/scripts/experiment/stage3/archived_scripts/01b_bread_launch.ts +112 -0
- package/scripts/experiment/stage3/archived_scripts/02_operator_setup.ts +84 -0
- package/scripts/experiment/stage3/archived_scripts/02b_operator_b_setup.ts +104 -0
- package/scripts/experiment/stage3/archived_scripts/02c_finalize_operators.ts +86 -0
- package/scripts/experiment/stage3/archived_scripts/02d_operator_collateral.ts +89 -0
- package/scripts/experiment/stage3/archived_scripts/03_user_onboarding.ts +83 -0
- package/scripts/experiment/stage3/archived_scripts/03b_deploy_aa_account.ts +61 -0
- package/scripts/experiment/stage3/archived_scripts/03c_aa_onboarding.ts +104 -0
- package/scripts/experiment/stage3/archived_scripts/03d_mint_points.ts +60 -0
- package/scripts/experiment/stage3/archived_scripts/04_benchmarking.ts +100 -0
- package/scripts/experiment/stage3/archived_scripts/05_multi_op_setup.ts +149 -0
- package/scripts/experiment/stage3/archived_scripts/README.md +58 -0
- package/scripts/experiment/stage3/archived_scripts/check_roles.ts +29 -0
- package/scripts/experiment/stage3/archived_scripts/decode_error.ts +23 -0
- package/scripts/experiment/stage3/archived_scripts/fund_user.ts +51 -0
- package/scripts/experiment/stage3/archived_scripts/gen_b_key.ts +3 -0
- package/scripts/experiment/stage3/archived_scripts/gen_keys.ts +4 -0
- package/scripts/experiment/stage3/archived_scripts/setup.ts +105 -0
- package/scripts/experiment/stage3/archived_scripts/test_key.ts +4 -0
- package/scripts/experiment/stage3/archived_scripts/verify_state.ts +59 -0
- package/scripts/experiment/stage3/refactored/00_token_distribution.ts +46 -0
- package/scripts/experiment/stage3/refactored/02_operator_setup.ts +65 -0
- package/scripts/experiment/stage3/refactored/03_user_onboarding.ts +68 -0
- package/scripts/experiment/stage3/refactored/05_multi_op_setup.ts +63 -0
- package/scripts/experiment/stage3/refactored/README.md +71 -0
- package/scripts/extract-docs.sh +72 -0
- package/scripts/generate_env_from_deployment.ts +109 -0
- package/scripts/publish_all.sh +39 -0
- package/scripts/quick_setup.ts +124 -0
- package/scripts/run_automated_experiment.sh +121 -0
- package/scripts/run_daily_experiment.ts +70 -0
- package/scripts/security_audit.sh +172 -0
- package/scripts/sync_config_to_env.ts +88 -0
- package/scripts/test_groups.ts +267 -0
- package/scripts/test_multi_community_anvil.ts +276 -0
- package/scripts/test_new_sdk_apis_sepolia.ts +115 -0
- package/scripts/test_sdk_join_idempotent.ts +233 -0
- package/scripts/test_simple_sepolia.ts +44 -0
- package/scripts/v2_regression/00_validate_env.ts +77 -0
- package/scripts/v2_regression/01_setup_and_fund.ts +132 -0
- package/scripts/v2_regression/02_operator_onboarding.ts +300 -0
- package/scripts/v2_regression/03_community_registry.ts +173 -0
- package/scripts/v2_regression/04_enduser_flow.ts +174 -0
- package/scripts/v2_regression/05_admin_audit.ts +157 -0
- package/scripts/v2_regression/README.md +161 -0
- package/scripts/validate_env.ts +112 -0
- package/scripts/validate_environment.ts +140 -0
- package/sdk_experiment_data.csv +2 -0
- package/surgical_harmonize.py +83 -0
- package/tsconfig.json +15 -0
- package/typedoc.json +25 -0
- package/dist/clients/admin.d.ts +0 -12
- package/dist/clients/admin.d.ts.map +0 -1
- package/dist/clients/admin.js +0 -20
- package/dist/clients/admin.js.map +0 -1
- package/dist/clients/community.d.ts +0 -12
- package/dist/clients/community.d.ts.map +0 -1
- package/dist/clients/community.js +0 -18
- package/dist/clients/community.js.map +0 -1
- package/dist/clients/endUser.d.ts +0 -12
- package/dist/clients/endUser.d.ts.map +0 -1
- package/dist/clients/endUser.js +0 -20
- package/dist/clients/endUser.js.map +0 -1
- package/dist/clients/operator.d.ts +0 -18
- package/dist/clients/operator.d.ts.map +0 -1
- package/dist/clients/operator.js +0 -65
- package/dist/clients/operator.js.map +0 -1
- package/dist/index.d.ts +0 -11
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
|
@@ -0,0 +1,496 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type Account,
|
|
3
|
+
type Address,
|
|
4
|
+
type Assign,
|
|
5
|
+
type Chain,
|
|
6
|
+
type Client,
|
|
7
|
+
type Hex,
|
|
8
|
+
type JsonRpcAccount,
|
|
9
|
+
type LocalAccount,
|
|
10
|
+
type OneOf,
|
|
11
|
+
type Transport,
|
|
12
|
+
type WalletClient,
|
|
13
|
+
concat,
|
|
14
|
+
decodeFunctionData,
|
|
15
|
+
encodeFunctionData,
|
|
16
|
+
hashMessage,
|
|
17
|
+
hashTypedData
|
|
18
|
+
} from "viem"
|
|
19
|
+
import {
|
|
20
|
+
type SmartAccount,
|
|
21
|
+
type SmartAccountImplementation,
|
|
22
|
+
type UserOperation,
|
|
23
|
+
entryPoint06Abi,
|
|
24
|
+
entryPoint07Abi,
|
|
25
|
+
entryPoint07Address,
|
|
26
|
+
getUserOperationHash,
|
|
27
|
+
toSmartAccount
|
|
28
|
+
} from "viem/account-abstraction"
|
|
29
|
+
import { getChainId, signMessage } from "viem/actions"
|
|
30
|
+
import { getAction } from "viem/utils"
|
|
31
|
+
import { getAccountNonce } from "../../actions/public/getAccountNonce.js"
|
|
32
|
+
import { getSenderAddress } from "../../actions/public/getSenderAddress.js"
|
|
33
|
+
import { type EthereumProvider, toOwner } from "../../utils/toOwner.js"
|
|
34
|
+
|
|
35
|
+
const getAccountInitCode = async (
|
|
36
|
+
owner: Address,
|
|
37
|
+
index = BigInt(0)
|
|
38
|
+
): Promise<Hex> => {
|
|
39
|
+
if (!owner) throw new Error("Owner account not found")
|
|
40
|
+
|
|
41
|
+
return encodeFunctionData({
|
|
42
|
+
abi: [
|
|
43
|
+
{
|
|
44
|
+
inputs: [
|
|
45
|
+
{
|
|
46
|
+
internalType: "address",
|
|
47
|
+
name: "owner",
|
|
48
|
+
type: "address"
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
internalType: "uint256",
|
|
52
|
+
name: "salt",
|
|
53
|
+
type: "uint256"
|
|
54
|
+
}
|
|
55
|
+
],
|
|
56
|
+
name: "createAccount",
|
|
57
|
+
outputs: [
|
|
58
|
+
{
|
|
59
|
+
internalType: "contract LightAccount",
|
|
60
|
+
name: "ret",
|
|
61
|
+
type: "address"
|
|
62
|
+
}
|
|
63
|
+
],
|
|
64
|
+
stateMutability: "nonpayable",
|
|
65
|
+
type: "function"
|
|
66
|
+
}
|
|
67
|
+
],
|
|
68
|
+
functionName: "createAccount",
|
|
69
|
+
args: [owner, index]
|
|
70
|
+
})
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export type LightAccountVersion<entryPointVersion extends "0.6" | "0.7"> =
|
|
74
|
+
entryPointVersion extends "0.6" ? "1.1.0" : "2.0.0"
|
|
75
|
+
|
|
76
|
+
export type ToLightSmartAccountParameters<
|
|
77
|
+
entryPointVersion extends "0.6" | "0.7" = "0.7"
|
|
78
|
+
> = {
|
|
79
|
+
client: Client<
|
|
80
|
+
Transport,
|
|
81
|
+
Chain | undefined,
|
|
82
|
+
JsonRpcAccount | LocalAccount | undefined
|
|
83
|
+
>
|
|
84
|
+
entryPoint?: {
|
|
85
|
+
address: Address
|
|
86
|
+
version: entryPointVersion
|
|
87
|
+
}
|
|
88
|
+
owner: OneOf<
|
|
89
|
+
| EthereumProvider
|
|
90
|
+
| WalletClient<Transport, Chain | undefined, Account>
|
|
91
|
+
| LocalAccount
|
|
92
|
+
>
|
|
93
|
+
version: LightAccountVersion<entryPointVersion>
|
|
94
|
+
factoryAddress?: Address
|
|
95
|
+
index?: bigint
|
|
96
|
+
address?: Address
|
|
97
|
+
nonceKey?: bigint
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
async function signWith1271WrapperV1(
|
|
101
|
+
signer: LocalAccount,
|
|
102
|
+
chainId: number,
|
|
103
|
+
accountAddress: Address,
|
|
104
|
+
hashedMessage: Hex
|
|
105
|
+
): Promise<Hex> {
|
|
106
|
+
return signer.signTypedData({
|
|
107
|
+
domain: {
|
|
108
|
+
chainId: Number(chainId),
|
|
109
|
+
name: "LightAccount",
|
|
110
|
+
verifyingContract: accountAddress,
|
|
111
|
+
version: "1"
|
|
112
|
+
},
|
|
113
|
+
types: {
|
|
114
|
+
LightAccountMessage: [{ name: "message", type: "bytes" }]
|
|
115
|
+
},
|
|
116
|
+
message: {
|
|
117
|
+
message: hashedMessage
|
|
118
|
+
},
|
|
119
|
+
primaryType: "LightAccountMessage"
|
|
120
|
+
})
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
const LIGHT_VERSION_TO_ADDRESSES_MAP: {
|
|
124
|
+
[key in LightAccountVersion<"0.6" | "0.7">]: {
|
|
125
|
+
factoryAddress: Address
|
|
126
|
+
}
|
|
127
|
+
} = {
|
|
128
|
+
"1.1.0": {
|
|
129
|
+
factoryAddress: "0x00004EC70002a32400f8ae005A26081065620D20"
|
|
130
|
+
},
|
|
131
|
+
"2.0.0": {
|
|
132
|
+
factoryAddress: "0x0000000000400CdFef5E2714E63d8040b700BC24"
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
const getDefaultAddresses = (
|
|
137
|
+
lightAccountVersion: LightAccountVersion<"0.6" | "0.7">,
|
|
138
|
+
{
|
|
139
|
+
factoryAddress: _factoryAddress
|
|
140
|
+
}: {
|
|
141
|
+
factoryAddress?: Address
|
|
142
|
+
}
|
|
143
|
+
) => {
|
|
144
|
+
const factoryAddress =
|
|
145
|
+
_factoryAddress ??
|
|
146
|
+
LIGHT_VERSION_TO_ADDRESSES_MAP[lightAccountVersion].factoryAddress
|
|
147
|
+
|
|
148
|
+
return {
|
|
149
|
+
factoryAddress
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
export type LightSmartAccountImplementation<
|
|
154
|
+
entryPointVersion extends "0.6" | "0.7"
|
|
155
|
+
> = Assign<
|
|
156
|
+
SmartAccountImplementation<
|
|
157
|
+
entryPointVersion extends "0.6"
|
|
158
|
+
? typeof entryPoint06Abi
|
|
159
|
+
: typeof entryPoint07Abi,
|
|
160
|
+
entryPointVersion
|
|
161
|
+
>,
|
|
162
|
+
{ sign: NonNullable<SmartAccountImplementation["sign"]> }
|
|
163
|
+
>
|
|
164
|
+
|
|
165
|
+
export type ToLightSmartAccountReturnType<
|
|
166
|
+
entryPointVersion extends "0.6" | "0.7" = "0.7"
|
|
167
|
+
> = SmartAccount<LightSmartAccountImplementation<entryPointVersion>>
|
|
168
|
+
|
|
169
|
+
enum SignatureType {
|
|
170
|
+
EOA = "0x00"
|
|
171
|
+
// CONTRACT = "0x01",
|
|
172
|
+
// CONTRACT_WITH_ADDR = "0x02"
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
/**
|
|
176
|
+
* @description Creates an Light Account from a private key.
|
|
177
|
+
*
|
|
178
|
+
* @returns A Private Key Light Account.
|
|
179
|
+
*/
|
|
180
|
+
export async function toLightSmartAccount<
|
|
181
|
+
entryPointVersion extends "0.6" | "0.7" = "0.7"
|
|
182
|
+
>(
|
|
183
|
+
parameters: ToLightSmartAccountParameters<entryPointVersion>
|
|
184
|
+
): Promise<ToLightSmartAccountReturnType<entryPointVersion>> {
|
|
185
|
+
const {
|
|
186
|
+
version,
|
|
187
|
+
factoryAddress: _factoryAddress,
|
|
188
|
+
address,
|
|
189
|
+
owner,
|
|
190
|
+
client,
|
|
191
|
+
index = BigInt(0),
|
|
192
|
+
nonceKey
|
|
193
|
+
} = parameters
|
|
194
|
+
|
|
195
|
+
const localOwner = await toOwner({ owner })
|
|
196
|
+
|
|
197
|
+
const entryPoint = {
|
|
198
|
+
address: parameters.entryPoint?.address ?? entryPoint07Address,
|
|
199
|
+
abi:
|
|
200
|
+
(parameters.entryPoint?.version ?? "0.7") === "0.6"
|
|
201
|
+
? entryPoint06Abi
|
|
202
|
+
: entryPoint07Abi,
|
|
203
|
+
version: parameters.entryPoint?.version ?? "0.7"
|
|
204
|
+
} as const
|
|
205
|
+
|
|
206
|
+
const { factoryAddress } = getDefaultAddresses(version, {
|
|
207
|
+
factoryAddress: _factoryAddress
|
|
208
|
+
})
|
|
209
|
+
|
|
210
|
+
let accountAddress: Address | undefined = address
|
|
211
|
+
|
|
212
|
+
let chainId: number
|
|
213
|
+
|
|
214
|
+
const getMemoizedChainId = async () => {
|
|
215
|
+
if (chainId) return chainId
|
|
216
|
+
chainId = client.chain
|
|
217
|
+
? client.chain.id
|
|
218
|
+
: await getAction(client, getChainId, "getChainId")({})
|
|
219
|
+
return chainId
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
const getFactoryArgs = async () => {
|
|
223
|
+
return {
|
|
224
|
+
factory: factoryAddress,
|
|
225
|
+
factoryData: await getAccountInitCode(localOwner.address, index)
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
return toSmartAccount({
|
|
230
|
+
client,
|
|
231
|
+
entryPoint,
|
|
232
|
+
getFactoryArgs,
|
|
233
|
+
async getAddress() {
|
|
234
|
+
if (accountAddress) return accountAddress
|
|
235
|
+
|
|
236
|
+
const { factory, factoryData } = await getFactoryArgs()
|
|
237
|
+
|
|
238
|
+
accountAddress = await getSenderAddress(client, {
|
|
239
|
+
factory,
|
|
240
|
+
factoryData,
|
|
241
|
+
entryPointAddress: entryPoint.address
|
|
242
|
+
})
|
|
243
|
+
|
|
244
|
+
return accountAddress
|
|
245
|
+
},
|
|
246
|
+
async encodeCalls(calls) {
|
|
247
|
+
if (calls.length > 1) {
|
|
248
|
+
return encodeFunctionData({
|
|
249
|
+
abi: [
|
|
250
|
+
{
|
|
251
|
+
inputs: [
|
|
252
|
+
{
|
|
253
|
+
internalType: "address[]",
|
|
254
|
+
name: "dest",
|
|
255
|
+
type: "address[]"
|
|
256
|
+
},
|
|
257
|
+
{
|
|
258
|
+
internalType: "uint256[]",
|
|
259
|
+
name: "value",
|
|
260
|
+
type: "uint256[]"
|
|
261
|
+
},
|
|
262
|
+
{
|
|
263
|
+
internalType: "bytes[]",
|
|
264
|
+
name: "func",
|
|
265
|
+
type: "bytes[]"
|
|
266
|
+
}
|
|
267
|
+
],
|
|
268
|
+
name: "executeBatch",
|
|
269
|
+
outputs: [],
|
|
270
|
+
stateMutability: "nonpayable",
|
|
271
|
+
type: "function"
|
|
272
|
+
}
|
|
273
|
+
],
|
|
274
|
+
functionName: "executeBatch",
|
|
275
|
+
args: [
|
|
276
|
+
calls.map((a) => a.to),
|
|
277
|
+
calls.map((a) => a.value ?? 0n),
|
|
278
|
+
calls.map((a) => a.data ?? "0x")
|
|
279
|
+
]
|
|
280
|
+
})
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
const call = calls.length === 0 ? undefined : calls[0]
|
|
284
|
+
|
|
285
|
+
if (!call) {
|
|
286
|
+
throw new Error("No calls to encode")
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
return encodeFunctionData({
|
|
290
|
+
abi: [
|
|
291
|
+
{
|
|
292
|
+
inputs: [
|
|
293
|
+
{
|
|
294
|
+
internalType: "address",
|
|
295
|
+
name: "dest",
|
|
296
|
+
type: "address"
|
|
297
|
+
},
|
|
298
|
+
{
|
|
299
|
+
internalType: "uint256",
|
|
300
|
+
name: "value",
|
|
301
|
+
type: "uint256"
|
|
302
|
+
},
|
|
303
|
+
{
|
|
304
|
+
internalType: "bytes",
|
|
305
|
+
name: "func",
|
|
306
|
+
type: "bytes"
|
|
307
|
+
}
|
|
308
|
+
],
|
|
309
|
+
name: "execute",
|
|
310
|
+
outputs: [],
|
|
311
|
+
stateMutability: "nonpayable",
|
|
312
|
+
type: "function"
|
|
313
|
+
}
|
|
314
|
+
],
|
|
315
|
+
functionName: "execute",
|
|
316
|
+
args: [call.to, call.value ?? 0n, call.data ?? "0x"]
|
|
317
|
+
})
|
|
318
|
+
},
|
|
319
|
+
async decodeCalls(callData) {
|
|
320
|
+
try {
|
|
321
|
+
const decoded = decodeFunctionData({
|
|
322
|
+
abi: [
|
|
323
|
+
{
|
|
324
|
+
inputs: [
|
|
325
|
+
{
|
|
326
|
+
internalType: "address[]",
|
|
327
|
+
name: "dest",
|
|
328
|
+
type: "address[]"
|
|
329
|
+
},
|
|
330
|
+
{
|
|
331
|
+
internalType: "uint256[]",
|
|
332
|
+
name: "value",
|
|
333
|
+
type: "uint256[]"
|
|
334
|
+
},
|
|
335
|
+
{
|
|
336
|
+
internalType: "bytes[]",
|
|
337
|
+
name: "func",
|
|
338
|
+
type: "bytes[]"
|
|
339
|
+
}
|
|
340
|
+
],
|
|
341
|
+
name: "executeBatch",
|
|
342
|
+
outputs: [],
|
|
343
|
+
stateMutability: "nonpayable",
|
|
344
|
+
type: "function"
|
|
345
|
+
}
|
|
346
|
+
],
|
|
347
|
+
data: callData
|
|
348
|
+
})
|
|
349
|
+
|
|
350
|
+
if (decoded.functionName === "executeBatch") {
|
|
351
|
+
const calls: {
|
|
352
|
+
to: Address
|
|
353
|
+
value: bigint
|
|
354
|
+
data: Hex
|
|
355
|
+
}[] = []
|
|
356
|
+
|
|
357
|
+
for (let i = 0; i < decoded.args[0].length; i++) {
|
|
358
|
+
calls.push({
|
|
359
|
+
to: decoded.args[0][i],
|
|
360
|
+
value: decoded.args[1][i],
|
|
361
|
+
data: decoded.args[2][i]
|
|
362
|
+
})
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
return calls
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
throw new Error("Invalid function name")
|
|
369
|
+
} catch {
|
|
370
|
+
const decoded = decodeFunctionData({
|
|
371
|
+
abi: [
|
|
372
|
+
{
|
|
373
|
+
inputs: [
|
|
374
|
+
{
|
|
375
|
+
internalType: "address",
|
|
376
|
+
name: "dest",
|
|
377
|
+
type: "address"
|
|
378
|
+
},
|
|
379
|
+
{
|
|
380
|
+
internalType: "uint256",
|
|
381
|
+
name: "value",
|
|
382
|
+
type: "uint256"
|
|
383
|
+
},
|
|
384
|
+
{
|
|
385
|
+
internalType: "bytes",
|
|
386
|
+
name: "func",
|
|
387
|
+
type: "bytes"
|
|
388
|
+
}
|
|
389
|
+
],
|
|
390
|
+
name: "execute",
|
|
391
|
+
outputs: [],
|
|
392
|
+
stateMutability: "nonpayable",
|
|
393
|
+
type: "function"
|
|
394
|
+
}
|
|
395
|
+
],
|
|
396
|
+
data: callData
|
|
397
|
+
})
|
|
398
|
+
|
|
399
|
+
return [
|
|
400
|
+
{
|
|
401
|
+
to: decoded.args[0],
|
|
402
|
+
value: decoded.args[1],
|
|
403
|
+
data: decoded.args[2]
|
|
404
|
+
}
|
|
405
|
+
]
|
|
406
|
+
}
|
|
407
|
+
},
|
|
408
|
+
async getNonce(args) {
|
|
409
|
+
return getAccountNonce(client, {
|
|
410
|
+
address: await this.getAddress(),
|
|
411
|
+
entryPointAddress: entryPoint.address,
|
|
412
|
+
key: nonceKey ?? args?.key
|
|
413
|
+
})
|
|
414
|
+
},
|
|
415
|
+
async getStubSignature() {
|
|
416
|
+
const signature =
|
|
417
|
+
"0xfffffffffffffffffffffffffffffff0000000000000000000000000000000007aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa1c"
|
|
418
|
+
|
|
419
|
+
switch (version) {
|
|
420
|
+
case "1.1.0":
|
|
421
|
+
return signature
|
|
422
|
+
case "2.0.0":
|
|
423
|
+
return concat([SignatureType.EOA, signature])
|
|
424
|
+
default:
|
|
425
|
+
throw new Error("Unknown Light Account version")
|
|
426
|
+
}
|
|
427
|
+
},
|
|
428
|
+
async sign({ hash }) {
|
|
429
|
+
return this.signMessage({ message: hash })
|
|
430
|
+
},
|
|
431
|
+
async signMessage({ message }) {
|
|
432
|
+
const signature = await signWith1271WrapperV1(
|
|
433
|
+
localOwner,
|
|
434
|
+
await getMemoizedChainId(),
|
|
435
|
+
await this.getAddress(),
|
|
436
|
+
hashMessage(message)
|
|
437
|
+
)
|
|
438
|
+
|
|
439
|
+
switch (version) {
|
|
440
|
+
case "1.1.0":
|
|
441
|
+
return signature
|
|
442
|
+
case "2.0.0":
|
|
443
|
+
return concat([SignatureType.EOA, signature])
|
|
444
|
+
default:
|
|
445
|
+
throw new Error("Unknown Light Account version")
|
|
446
|
+
}
|
|
447
|
+
},
|
|
448
|
+
async signTypedData(typedData) {
|
|
449
|
+
const signature = await signWith1271WrapperV1(
|
|
450
|
+
localOwner,
|
|
451
|
+
await getMemoizedChainId(),
|
|
452
|
+
await this.getAddress(),
|
|
453
|
+
hashTypedData(typedData)
|
|
454
|
+
)
|
|
455
|
+
|
|
456
|
+
switch (version) {
|
|
457
|
+
case "1.1.0":
|
|
458
|
+
return signature
|
|
459
|
+
case "2.0.0":
|
|
460
|
+
return concat([SignatureType.EOA, signature])
|
|
461
|
+
default:
|
|
462
|
+
throw new Error("Unknown Light Account version")
|
|
463
|
+
}
|
|
464
|
+
},
|
|
465
|
+
async signUserOperation(parameters) {
|
|
466
|
+
const { chainId = await getMemoizedChainId(), ...userOperation } =
|
|
467
|
+
parameters
|
|
468
|
+
|
|
469
|
+
const hash = getUserOperationHash({
|
|
470
|
+
userOperation: {
|
|
471
|
+
...userOperation,
|
|
472
|
+
signature: "0x"
|
|
473
|
+
} as UserOperation<entryPointVersion>,
|
|
474
|
+
entryPointAddress: entryPoint.address,
|
|
475
|
+
entryPointVersion: entryPoint.version,
|
|
476
|
+
chainId: chainId
|
|
477
|
+
})
|
|
478
|
+
|
|
479
|
+
const signature = await signMessage(client, {
|
|
480
|
+
account: localOwner,
|
|
481
|
+
message: {
|
|
482
|
+
raw: hash
|
|
483
|
+
}
|
|
484
|
+
})
|
|
485
|
+
|
|
486
|
+
switch (version) {
|
|
487
|
+
case "1.1.0":
|
|
488
|
+
return signature
|
|
489
|
+
case "2.0.0":
|
|
490
|
+
return concat([SignatureType.EOA, signature])
|
|
491
|
+
default:
|
|
492
|
+
throw new Error("Unknown Light Account version")
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
}) as Promise<ToLightSmartAccountReturnType<entryPointVersion>>
|
|
496
|
+
}
|