@aastar/sdk 0.14.3 → 0.16.8
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/README.md +100 -120
- package/dist/account/src/accounts/simple.d.ts +18 -0
- package/{packages/account/src/accounts/simple.ts → dist/account/src/accounts/simple.js} +12 -47
- package/dist/account/src/eoa.d.ts +10 -0
- package/dist/account/src/eoa.js +21 -0
- package/dist/account/src/index.d.ts +19 -0
- package/dist/account/src/index.js +49 -0
- package/dist/core/src/abis/BLSAggregator.json +686 -0
- package/dist/core/src/abis/BLSValidator.json +42 -0
- package/dist/core/src/abis/DVTValidator.json +368 -0
- package/dist/core/src/abis/EntryPoint.json +1382 -0
- package/dist/core/src/abis/GToken.json +513 -0
- package/dist/core/src/abis/GTokenStaking.json +949 -0
- package/dist/core/src/abis/MySBT.json +1518 -0
- package/dist/core/src/abis/Paymaster.json +1143 -0
- package/dist/core/src/abis/PaymasterFactory.json +640 -0
- package/dist/core/src/abis/Registry.json +1942 -0
- package/dist/core/src/abis/ReputationSystem.json +699 -0
- package/dist/core/src/abis/SimpleAccount.json +560 -0
- package/dist/core/src/abis/SimpleAccountFactory.json +111 -0
- package/dist/core/src/abis/SuperPaymaster.json +1781 -0
- package/dist/core/src/abis/index.d.ts +1126 -0
- package/dist/core/src/abis/index.js +91 -0
- package/dist/core/src/abis/xPNTsFactory.json +718 -0
- package/dist/core/src/abis/xPNTsToken.json +1280 -0
- package/dist/core/src/actions/StateValidator.d.ts +68 -0
- package/dist/core/src/actions/StateValidator.js +187 -0
- package/dist/core/src/actions/account.d.ts +55 -0
- package/dist/core/src/actions/account.js +133 -0
- package/dist/core/src/actions/aggregator.d.ts +17 -0
- package/dist/core/src/actions/aggregator.js +31 -0
- package/dist/core/src/actions/dvt.d.ts +30 -0
- package/dist/core/src/actions/dvt.js +41 -0
- package/dist/core/src/actions/entryPoint.d.ts +90 -0
- package/dist/core/src/actions/entryPoint.js +211 -0
- package/dist/core/src/actions/factory.d.ts +215 -0
- package/dist/core/src/actions/factory.js +442 -0
- package/dist/core/src/actions/faucet.d.ts +48 -0
- package/dist/core/src/actions/faucet.js +337 -0
- package/dist/core/src/actions/gtokenExtended.d.ts +39 -0
- package/dist/core/src/actions/gtokenExtended.js +115 -0
- package/{packages/core/src/actions/index.ts → dist/core/src/actions/index.d.ts} +5 -0
- package/dist/core/src/actions/index.js +17 -0
- package/dist/core/src/actions/paymasterV4.d.ts +170 -0
- package/dist/core/src/actions/paymasterV4.js +334 -0
- package/dist/core/src/actions/registry.d.ts +246 -0
- package/dist/core/src/actions/registry.js +667 -0
- package/dist/core/src/actions/reputation.d.ts +129 -0
- package/dist/core/src/actions/reputation.js +281 -0
- package/dist/core/src/actions/sbt.d.ts +191 -0
- package/dist/core/src/actions/sbt.js +533 -0
- package/dist/core/src/actions/staking.d.ts +132 -0
- package/dist/core/src/actions/staking.js +330 -0
- package/dist/core/src/actions/superPaymaster.d.ts +237 -0
- package/dist/core/src/actions/superPaymaster.js +644 -0
- package/dist/core/src/actions/tokens.d.ts +229 -0
- package/dist/core/src/actions/tokens.js +415 -0
- package/dist/core/src/branding.d.ts +30 -0
- package/dist/core/src/branding.js +30 -0
- package/dist/core/src/clients/BaseClient.d.ts +25 -0
- package/dist/core/src/clients/BaseClient.js +66 -0
- package/dist/core/src/clients/types.d.ts +60 -0
- package/dist/core/src/clients/types.js +1 -0
- package/dist/core/src/clients.d.ts +5 -0
- package/dist/core/src/clients.js +11 -0
- package/dist/core/src/communities.d.ts +52 -0
- package/dist/core/src/communities.js +73 -0
- package/dist/core/src/config/ContractConfigManager.d.ts +20 -0
- package/dist/core/src/config/ContractConfigManager.js +48 -0
- package/dist/core/src/constants.d.ts +88 -0
- package/dist/core/src/constants.js +125 -0
- package/dist/core/src/contract-addresses.d.ts +110 -0
- package/dist/core/src/contract-addresses.js +99 -0
- package/dist/core/src/contracts.d.ts +424 -0
- package/dist/core/src/contracts.js +343 -0
- package/dist/core/src/crypto/blsSigner.d.ts +64 -0
- package/{packages/core/src/crypto/blsSigner.ts → dist/core/src/crypto/blsSigner.js} +23 -49
- package/dist/core/src/crypto/index.js +1 -0
- package/dist/core/src/index.d.ts +21 -0
- package/{packages/core/src/index.ts → dist/core/src/index.js} +4 -2
- package/dist/core/src/networks.d.ts +127 -0
- package/{ext/aastar-shared-config/src/networks.ts → dist/core/src/networks.js} +34 -33
- package/dist/core/src/requirementChecker.d.ts +38 -0
- package/{packages/core/src/requirementChecker.ts → dist/core/src/requirementChecker.js} +27 -113
- package/dist/core/src/roles.d.ts +204 -0
- package/dist/core/src/roles.js +211 -0
- package/dist/core/src/utils/validation.d.ts +24 -0
- package/dist/core/src/utils/validation.js +56 -0
- package/{packages/dapp/src/index.ts → dist/dapp/src/index.d.ts} +0 -1
- package/dist/dapp/src/index.js +3 -0
- package/dist/dapp/src/ui/hooks/useCreditScore.d.ts +13 -0
- package/{packages/dapp/src/ui/hooks/useCreditScore.ts → dist/dapp/src/ui/hooks/useCreditScore.js} +10 -22
- package/dist/dapp/src/ui/hooks/useSuperPaymaster.d.ts +8 -0
- package/{packages/dapp/src/ui/hooks/useSuperPaymaster.ts → dist/dapp/src/ui/hooks/useSuperPaymaster.js} +9 -17
- package/dist/dapp/src/ui/index.d.ts +4 -0
- package/{packages/dapp/src/ui/index.ts → dist/dapp/src/ui/index.js} +3 -8
- package/dist/identity/src/index.d.ts +46 -0
- package/dist/identity/src/index.js +94 -0
- package/dist/identity/src/mysbt.d.ts +13 -0
- package/{packages/identity/src/mysbt.ts → dist/identity/src/mysbt.js} +9 -20
- package/dist/paymaster/src/SuperPaymaster/index.d.ts +44 -0
- package/{packages/paymaster/src/SuperPaymaster/index.ts → dist/paymaster/src/SuperPaymaster/index.js} +29 -64
- package/dist/paymaster/src/V4/PaymasterClient.d.ts +79 -0
- package/dist/paymaster/src/V4/PaymasterClient.js +315 -0
- package/dist/paymaster/src/V4/PaymasterOperator.d.ts +41 -0
- package/dist/paymaster/src/V4/PaymasterOperator.js +241 -0
- package/dist/paymaster/src/V4/PaymasterUtils.d.ts +55 -0
- package/dist/paymaster/src/V4/PaymasterUtils.js +124 -0
- package/dist/paymaster/src/V4/SuperPaymasterClient.d.ts +21 -0
- package/dist/paymaster/src/V4/SuperPaymasterClient.js +73 -0
- package/dist/paymaster/src/V4/index.d.ts +4 -0
- package/dist/paymaster/src/V4/index.js +4 -0
- package/dist/paymaster/src/index.d.ts +2 -0
- package/{packages/paymaster/src/index.ts → dist/paymaster/src/index.js} +0 -1
- package/dist/sdk/src/clients/ExperimentClient.d.ts +34 -0
- package/dist/sdk/src/clients/ExperimentClient.js +58 -0
- package/dist/sdk/src/clients/ExperimentClient.test.d.ts +1 -0
- package/dist/sdk/src/clients/ExperimentClient.test.js +53 -0
- package/dist/sdk/src/clients/admin.d.ts +57 -0
- package/dist/sdk/src/clients/admin.js +105 -0
- package/dist/sdk/src/clients/admin.test.d.ts +1 -0
- package/dist/sdk/src/clients/admin.test.js +79 -0
- package/dist/sdk/src/clients/clients.test.d.ts +1 -0
- package/dist/sdk/src/clients/clients.test.js +91 -0
- package/dist/sdk/src/clients/community.d.ts +48 -0
- package/dist/sdk/src/clients/community.js +244 -0
- package/dist/sdk/src/clients/community.test.d.ts +1 -0
- package/dist/sdk/src/clients/community.test.js +99 -0
- package/dist/sdk/src/clients/endUser.d.ts +95 -0
- package/dist/sdk/src/clients/endUser.js +388 -0
- package/dist/sdk/src/clients/endUser.test.d.ts +1 -0
- package/dist/sdk/src/clients/endUser.test.js +188 -0
- package/dist/sdk/src/clients/operator.d.ts +96 -0
- package/dist/sdk/src/clients/operator.js +247 -0
- package/dist/sdk/src/clients/operator.test.d.ts +1 -0
- package/dist/sdk/src/clients/operator.test.js +139 -0
- package/dist/sdk/src/errors/AAStarError.d.ts +26 -0
- package/dist/sdk/src/errors/AAStarError.js +32 -0
- package/dist/sdk/src/errors/AAStarError.test.d.ts +1 -0
- package/dist/sdk/src/errors/AAStarError.test.js +74 -0
- package/dist/sdk/src/errors/decoder.d.ts +1 -0
- package/dist/sdk/src/errors/decoder.js +83 -0
- package/dist/sdk/src/errors/decoder.test.d.ts +1 -0
- package/dist/sdk/src/errors/decoder.test.js +90 -0
- package/dist/sdk/src/index.d.ts +16 -0
- package/dist/sdk/src/index.js +20 -0
- package/dist/sdk/src/node/index.d.ts +7 -0
- package/dist/sdk/src/node/index.js +7 -0
- package/dist/sdk/src/types/result.d.ts +15 -0
- package/dist/sdk/src/types/result.js +23 -0
- package/dist/sdk/src/utils/errorHandler.d.ts +40 -0
- package/{packages/sdk/src/utils/errorHandler.ts → dist/sdk/src/utils/errorHandler.js} +22 -75
- package/dist/sdk/src/utils/errorHandler.test.d.ts +1 -0
- package/dist/sdk/src/utils/errorHandler.test.js +89 -0
- package/dist/sdk/src/utils/eventDecoder.d.ts +7 -0
- package/dist/sdk/src/utils/eventDecoder.js +54 -0
- package/dist/sdk/src/utils/eventDecoder.test.d.ts +1 -0
- package/dist/sdk/src/utils/eventDecoder.test.js +48 -0
- package/dist/sdk/src/utils/funding.d.ts +115 -0
- package/{packages/sdk/src/utils/funding.ts → dist/sdk/src/utils/funding.js} +27 -119
- package/dist/sdk/src/utils/funding.test.d.ts +1 -0
- package/dist/sdk/src/utils/funding.test.js +105 -0
- package/dist/sdk/src/utils/keys.d.ts +73 -0
- package/{packages/sdk/src/utils/keys.ts → dist/sdk/src/utils/keys.js} +22 -44
- package/dist/sdk/src/utils/keys.test.d.ts +1 -0
- package/dist/sdk/src/utils/keys.test.js +81 -0
- package/dist/sdk/src/utils/roleData.d.ts +66 -0
- package/{packages/sdk/src/utils/roleData.ts → dist/sdk/src/utils/roleData.js} +36 -72
- package/dist/sdk/src/utils/roleData.test.d.ts +1 -0
- package/dist/sdk/src/utils/roleData.test.js +74 -0
- package/dist/sdk/src/utils/testScenarios.d.ts +33 -0
- package/dist/sdk/src/utils/testScenarios.js +85 -0
- package/dist/sdk/src/utils/testScenarios.test.d.ts +1 -0
- package/dist/sdk/src/utils/testScenarios.test.js +68 -0
- package/dist/sdk/src/utils/userOp.d.ts +78 -0
- package/dist/sdk/src/utils/userOp.js +195 -0
- package/dist/sdk/src/utils/userOp.test.d.ts +1 -0
- package/dist/sdk/src/utils/userOp.test.js +152 -0
- package/dist/tokens/src/index.d.ts +56 -0
- package/dist/tokens/src/index.js +230 -0
- package/examples/regression_test.d.ts +2 -0
- package/examples/regression_test.d.ts.map +1 -0
- package/examples/regression_test.js +89 -0
- package/examples/regression_test.js.map +1 -0
- package/package.json +40 -54
- package/scripts/v2_regression/00_validate_env.ts +28 -4
- package/scripts/v2_regression/01_setup_and_fund.ts +1 -1
- package/scripts/v2_regression/02_operator_onboarding.ts +16 -142
- package/scripts/v2_regression/03_community_registry.ts +24 -58
- package/scripts/v2_regression/04_enduser_flow.ts +16 -49
- package/scripts/v2_regression/05_admin_audit.ts +1 -1
- package/.eslintrc.js +0 -28
- package/.gitmodules +0 -9
- package/aastar-sdk.code-workspace +0 -14
- package/abis/BLSAggregator.json +0 -572
- package/abis/BLSValidator.json +0 -26
- package/abis/DVTValidator.json +0 -370
- package/abis/Eip7702Support.json +0 -24
- package/abis/EntryPoint.json +0 -1379
- package/abis/GToken.json +0 -479
- package/abis/GTokenStaking.json +0 -944
- package/abis/LegacyAccount.json +0 -625
- package/abis/MySBT.json +0 -1586
- package/abis/Paymaster.json +0 -1205
- package/abis/PaymasterFactory.json +0 -650
- package/abis/PaymasterV4_2.json +0 -1183
- package/abis/Registry.json +0 -1636
- package/abis/ReputationSystem.json +0 -477
- package/abis/SenderCreator.json +0 -99
- package/abis/Simple7702Account.json +0 -395
- package/abis/SimpleAccount.json +0 -625
- package/abis/SimpleAccountFactory.json +0 -108
- package/abis/SimpleAccountFactoryV08.json +0 -87
- package/abis/SimpleAccountV08.json +0 -557
- package/abis/SuperPaymaster.json +0 -1399
- package/abis/UserOperationLib.json +0 -57
- package/abis/aPNTs.json +0 -1173
- package/abis/xPNTsFactory.json +0 -728
- package/abis/xPNTsToken.json +0 -1173
- package/config/networks/README.md +0 -54
- package/config/networks/mainnet.env.example +0 -39
- package/config/networks/optimism-sepolia.env.example +0 -35
- package/config/networks/optimism.env.example +0 -36
- package/config/networks/sepolia.env.example +0 -36
- package/data/experiment_data.csv +0 -36
- package/data/industry_baseline_2025-12-23.json +0 -154
- package/data/industry_baseline_latest.json +0 -154
- package/docs/API_REFERENCE.md +0 -796
- package/docs/DAO_Mining_Distribution_Plan.md +0 -522
- package/docs/DOCUMENTATION_PLAN.md +0 -455
- package/docs/Plan.md +0 -266
- package/docs/Regression_Testing_Guide.md +0 -70
- package/docs/SDK_Optimization_Evaluation_Plan.md +0 -51
- package/docs/SEPOLIA_ENV_REFERENCE.md +0 -51
- package/docs/STAGE_3_SCENARIO_EXP_PLAN.md +0 -77
- package/docs/Script_Comparison_Report.md +0 -91
- package/docs/Sepolia_Latest_Deployment.md +0 -117
- package/docs/TEST_COVERAGE_MATRIX.md +0 -72
- package/docs/TODO_SDK_COVERAGE.md +0 -55
- package/docs/USER_CASE_DESIGN.md +0 -110
- package/docs/api/@aastar/account/README.md +0 -15
- package/docs/api/@aastar/account/classes/UserOpClient.md +0 -87
- package/docs/api/@aastar/account/functions/createEOAWalletClient.md +0 -21
- package/docs/api/@aastar/account/functions/getUserOpHash.md +0 -23
- package/docs/api/@aastar/account/functions/packUserOpLimits.md +0 -19
- package/docs/api/@aastar/account/functions/toSimpleSmartAccount.md +0 -83
- package/docs/api/@aastar/account/type-aliases/EOAWalletClient.md +0 -37
- package/docs/api/@aastar/account/type-aliases/SimpleSmartAccount.md +0 -39
- package/docs/api/@aastar/core/README.md +0 -136
- package/docs/api/@aastar/core/classes/BLSSigner.md +0 -147
- package/docs/api/@aastar/core/enumerations/NodeType.md +0 -33
- package/docs/api/@aastar/core/functions/aggregatorActions.md +0 -2714
- package/docs/api/@aastar/core/functions/createAAStarPublicClient.md +0 -3105
- package/docs/api/@aastar/core/functions/dvtActions.md +0 -2714
- package/docs/api/@aastar/core/functions/factoryActions.md +0 -2714
- package/docs/api/@aastar/core/functions/getAddressUrl.md +0 -32
- package/docs/api/@aastar/core/functions/getAllCommunityConfigs.md +0 -9
- package/docs/api/@aastar/core/functions/getAllV2Contracts.md +0 -20
- package/docs/api/@aastar/core/functions/getBlockExplorer.md +0 -26
- package/docs/api/@aastar/core/functions/getChainId.md +0 -26
- package/docs/api/@aastar/core/functions/getCommunities.md +0 -76
- package/docs/api/@aastar/core/functions/getCommunity.md +0 -32
- package/docs/api/@aastar/core/functions/getCommunityConfig.md +0 -15
- package/docs/api/@aastar/core/functions/getContract.md +0 -37
- package/docs/api/@aastar/core/functions/getContractNetworks.md +0 -18
- package/docs/api/@aastar/core/functions/getContracts.md +0 -178
- package/docs/api/@aastar/core/functions/getCoreContracts.md +0 -55
- package/docs/api/@aastar/core/functions/getDeploymentDate.md +0 -32
- package/docs/api/@aastar/core/functions/getEntryPoint.md +0 -25
- package/docs/api/@aastar/core/functions/getNetwork.md +0 -26
- package/docs/api/@aastar/core/functions/getPaymasterV4_1.md +0 -25
- package/docs/api/@aastar/core/functions/getRpcUrl.md +0 -25
- package/docs/api/@aastar/core/functions/getSimpleAccountFactory.md +0 -25
- package/docs/api/@aastar/core/functions/getSuperPaymasterV2.md +0 -25
- package/docs/api/@aastar/core/functions/getTestAccounts.md +0 -30
- package/docs/api/@aastar/core/functions/getTestTokenContracts.md +0 -38
- package/docs/api/@aastar/core/functions/getTokenContracts.md +0 -31
- package/docs/api/@aastar/core/functions/getTxUrl.md +0 -32
- package/docs/api/@aastar/core/functions/getV2ContractByAddress.md +0 -28
- package/docs/api/@aastar/core/functions/getV2ContractByName.md +0 -28
- package/docs/api/@aastar/core/functions/getV2ContractsByDate.md +0 -26
- package/docs/api/@aastar/core/functions/isContractNetworkSupported.md +0 -27
- package/docs/api/@aastar/core/functions/isRegisteredCommunity.md +0 -15
- package/docs/api/@aastar/core/functions/isV2Contract.md +0 -27
- package/docs/api/@aastar/core/functions/paymasterV4Actions.md +0 -2719
- package/docs/api/@aastar/core/functions/registryActions.md +0 -2720
- package/docs/api/@aastar/core/functions/reputationActions.md +0 -2720
- package/docs/api/@aastar/core/functions/sbtActions.md +0 -2720
- package/docs/api/@aastar/core/functions/stakingActions.md +0 -2720
- package/docs/api/@aastar/core/functions/superPaymasterActions.md +0 -2720
- package/docs/api/@aastar/core/functions/tokenActions.md +0 -2714
- package/docs/api/@aastar/core/interfaces/CommunityConfig.md +0 -81
- package/docs/api/@aastar/core/interfaces/ContractVersion.md +0 -63
- package/docs/api/@aastar/core/type-aliases/AggregatorActions.md +0 -79
- package/docs/api/@aastar/core/type-aliases/ContractCategory.md +0 -5
- package/docs/api/@aastar/core/type-aliases/ContractNetwork.md +0 -5
- package/docs/api/@aastar/core/type-aliases/DVTActions.md +0 -139
- package/docs/api/@aastar/core/type-aliases/FactoryActions.md +0 -99
- package/docs/api/@aastar/core/type-aliases/NetworkContracts.md +0 -5
- package/docs/api/@aastar/core/type-aliases/PaymasterV4Actions.md +0 -422
- package/docs/api/@aastar/core/type-aliases/RegistryActions.md +0 -263
- package/docs/api/@aastar/core/type-aliases/ReputationActions.md +0 -47
- package/docs/api/@aastar/core/type-aliases/RoleConfig.md +0 -83
- package/docs/api/@aastar/core/type-aliases/SBTActions.md +0 -203
- package/docs/api/@aastar/core/type-aliases/StakingActions.md +0 -179
- package/docs/api/@aastar/core/type-aliases/SuperPaymasterActions.md +0 -219
- package/docs/api/@aastar/core/type-aliases/SupportedNetwork.md +0 -3
- package/docs/api/@aastar/core/type-aliases/TokenActions.md +0 -151
- package/docs/api/@aastar/core/variables/AASTAR_COMMUNITY.md +0 -8
- package/docs/api/@aastar/core/variables/ALL_ADDRESSES.md +0 -71
- package/docs/api/@aastar/core/variables/BLSAggregatorABI.md +0 -3
- package/docs/api/@aastar/core/variables/BLSHelpers.md +0 -91
- package/docs/api/@aastar/core/variables/BPS_DENOMINATOR.md +0 -5
- package/docs/api/@aastar/core/variables/BRANDING.md +0 -67
- package/docs/api/@aastar/core/variables/BREAD_COMMUNITY.md +0 -8
- package/docs/api/@aastar/core/variables/COMMUNITIES.md +0 -5
- package/docs/api/@aastar/core/variables/COMMUNITY_OWNERS.md +0 -15
- package/docs/api/@aastar/core/variables/CONTRACTS.md +0 -163
- package/docs/api/@aastar/core/variables/CONTRACT_METADATA.md +0 -67
- package/docs/api/@aastar/core/variables/CORE_ADDRESSES.md +0 -35
- package/docs/api/@aastar/core/variables/DEFAULT_APNTS_PRICE_USD.md +0 -5
- package/docs/api/@aastar/core/variables/DEFAULT_GAS_TOKEN_MINT_AMOUNT.md +0 -5
- package/docs/api/@aastar/core/variables/DEFAULT_USDT_MINT_AMOUNT.md +0 -5
- package/docs/api/@aastar/core/variables/DVTValidatorABI.md +0 -3
- package/docs/api/@aastar/core/variables/EntryPointABI.md +0 -3
- package/docs/api/@aastar/core/variables/FAUCET_API_URL.md +0 -5
- package/docs/api/@aastar/core/variables/GTokenABI.md +0 -3
- package/docs/api/@aastar/core/variables/GTokenStakingABI.md +0 -3
- package/docs/api/@aastar/core/variables/LINKS.md +0 -33
- package/docs/api/@aastar/core/variables/MAX_SERVICE_FEE.md +0 -5
- package/docs/api/@aastar/core/variables/MONITORING_ADDRESSES.md +0 -15
- package/docs/api/@aastar/core/variables/MySBTABI.md +0 -3
- package/docs/api/@aastar/core/variables/NETWORKS.md +0 -79
- package/docs/api/@aastar/core/variables/NODE_STAKE_AMOUNTS.md +0 -31
- package/docs/api/@aastar/core/variables/OFFICIAL_ADDRESSES.md +0 -11
- package/docs/api/@aastar/core/variables/PAYMASTER_ADDRESSES.md +0 -15
- package/docs/api/@aastar/core/variables/PaymasterABI.md +0 -3
- package/docs/api/@aastar/core/variables/PaymasterFactoryABI.md +0 -3
- package/docs/api/@aastar/core/variables/PaymasterV4ABI.md +0 -3
- package/docs/api/@aastar/core/variables/ROLE_ANODE.md +0 -3
- package/docs/api/@aastar/core/variables/ROLE_COMMUNITY.md +0 -3
- package/docs/api/@aastar/core/variables/ROLE_ENDUSER.md +0 -5
- package/docs/api/@aastar/core/variables/ROLE_KMS.md +0 -3
- package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_AOA.md +0 -3
- package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_SUPER.md +0 -3
- package/docs/api/@aastar/core/variables/RegistryABI.md +0 -3
- package/docs/api/@aastar/core/variables/ReputationSystemABI.md +0 -3
- package/docs/api/@aastar/core/variables/ReputationSystemV3ABI.md +0 -3
- package/docs/api/@aastar/core/variables/SEPOLIA_CONTRACTS.md +0 -159
- package/docs/api/@aastar/core/variables/SEPOLIA_V2_VERSIONS.md +0 -67
- package/docs/api/@aastar/core/variables/SERVICE_FEE_RATE.md +0 -5
- package/docs/api/@aastar/core/variables/Simple7702AccountABI.md +0 -3
- package/docs/api/@aastar/core/variables/SimpleAccountABI.md +0 -3
- package/docs/api/@aastar/core/variables/SimpleAccountFactoryABI.md +0 -3
- package/docs/api/@aastar/core/variables/SimpleAccountFactoryV08ABI.md +0 -3
- package/docs/api/@aastar/core/variables/SimpleAccountV08ABI.md +0 -3
- package/docs/api/@aastar/core/variables/SuperPaymasterABI.md +0 -3
- package/docs/api/@aastar/core/variables/SuperPaymasterV3ABI.md +0 -3
- package/docs/api/@aastar/core/variables/TEST_ACCOUNT_ADDRESSES.md +0 -11
- package/docs/api/@aastar/core/variables/TEST_ACCOUNT_POOL_SIZE.md +0 -5
- package/docs/api/@aastar/core/variables/TEST_COMMUNITIES.md +0 -19
- package/docs/api/@aastar/core/variables/TEST_TOKEN_ADDRESSES.md +0 -19
- package/docs/api/@aastar/core/variables/TOKEN_ADDRESSES.md +0 -11
- package/docs/api/@aastar/core/variables/V2_SUMMARY.md +0 -39
- package/docs/api/@aastar/core/variables/xPNTsFactoryABI.md +0 -3
- package/docs/api/@aastar/core/variables/xPNTsTokenABI.md +0 -3
- package/docs/api/@aastar/paymaster/README.md +0 -14
- package/docs/api/@aastar/paymaster/classes/SuperPaymasterClient.md +0 -163
- package/docs/api/@aastar/paymaster/functions/checkEligibility.md +0 -28
- package/docs/api/@aastar/paymaster/functions/getPaymasterV4Middleware.md +0 -32
- package/docs/api/@aastar/paymaster/functions/getSuperPaymasterMiddleware.md +0 -32
- package/docs/api/@aastar/paymaster/type-aliases/PaymasterConfig.md +0 -35
- package/docs/api/@aastar/paymaster/type-aliases/PaymasterV4MiddlewareConfig.md +0 -35
- package/docs/api/@aastar/tokens/README.md +0 -3
- package/docs/api/@aastar/tokens/classes/FinanceClient.md +0 -8653
- package/docs/api/README.md +0 -6
- package/docs/examples/community-flow.md +0 -28
- package/docs/examples/enduser-flow.md +0 -24
- package/docs/examples/index.md +0 -18
- package/docs/examples/multi-chain.md +0 -31
- package/docs/examples/operator-flow.md +0 -28
- package/docs/guide/CLI_GUIDE.md +0 -65
- package/docs/guide/DOCUMENTATION_PLAN.md +0 -455
- package/docs/guide/Security-solution.md +0 -106
- package/docs/guide/TEST_COMMANDS.md +0 -320
- package/docs/guide/getting-started.md +0 -133
- package/docs/guide/installation.md +0 -40
- package/docs/guide/paper-data-collection.md +0 -69
- package/docs/guide/quick-start.md +0 -52
- package/docs/guide/task_breakdown.md +0 -121
- package/docs/old-solution.md +0 -1078
- package/docs/paper-data-collection.md +0 -69
- package/docs/technical_plan.md +0 -510
- package/docs/zh/examples/community-flow.md +0 -38
- package/docs/zh/examples/complete-workflow.md +0 -10
- package/docs/zh/examples/enduser-flow.md +0 -33
- package/docs/zh/examples/index.md +0 -18
- package/docs/zh/examples/multi-chain.md +0 -46
- package/docs/zh/examples/operator-flow.md +0 -37
- package/docs/zh/guide/CLI_GUIDE.md +0 -48
- package/docs/zh/guide/DOCUMENTATION_PLAN.md +0 -455
- package/docs/zh/guide/Plan.md +0 -266
- package/docs/zh/guide/SDK_Optimization_Evaluation_Plan.md +0 -51
- package/docs/zh/guide/Security-solution.md +0 -106
- package/docs/zh/guide/TEST_COMMANDS.md +0 -125
- package/docs/zh/guide/TEST_COVERAGE_MATRIX.md +0 -72
- package/docs/zh/guide/concepts/account-abstraction.md +0 -95
- package/docs/zh/guide/concepts/rainbow-bridge.md +0 -68
- package/docs/zh/guide/concepts/reputation.md +0 -95
- package/docs/zh/guide/concepts/superpaymaster.md +0 -141
- package/docs/zh/guide/getting-started.md +0 -133
- package/docs/zh/guide/installation.md +0 -107
- package/docs/zh/guide/old-solution.md +0 -1078
- package/docs/zh/guide/paper-data-collection.md +0 -69
- package/docs/zh/guide/quick-start.md +0 -134
- package/docs/zh/guide/sdk-readme.md +0 -253
- package/docs/zh/guide/task_breakdown.md +0 -76
- package/docs/zh/guide/technical_plan.md +0 -510
- package/docs/zh/guide/use-cases/community-management.md +0 -141
- package/docs/zh/guide/use-cases/gasless-transactions.md +0 -71
- package/docs/zh/guide/use-cases/operator-staking.md +0 -84
- package/docs/zh/guide/use-cases/yop.md +0 -72
- package/examples/sdk-demo/DEVELOPER_GUIDE.md +0 -159
- package/examples/sdk-demo/README.md +0 -30
- package/examples/sdk-demo/usage.ts +0 -137
- package/ext/aastar-shared-config/.env.example +0 -6
- package/ext/aastar-shared-config/.github/workflows/check-secrets.yml +0 -257
- package/ext/aastar-shared-config/AGENTS.md +0 -21
- package/ext/aastar-shared-config/CHANGELOG.md +0 -99
- package/ext/aastar-shared-config/LICENSE +0 -21
- package/ext/aastar-shared-config/QUICK_START.md +0 -215
- package/ext/aastar-shared-config/README.md +0 -412
- package/ext/aastar-shared-config/SHARED_CONFIG_SUMMARY.md +0 -273
- package/ext/aastar-shared-config/check-locker-status.mjs +0 -7
- package/ext/aastar-shared-config/favicon.ico +0 -0
- package/ext/aastar-shared-config/generate-comparison-table.sh +0 -67
- package/ext/aastar-shared-config/package.json +0 -46
- package/ext/aastar-shared-config/pnpm-lock.yaml +0 -1182
- package/ext/aastar-shared-config/src/abis/BLSAggregator.json +0 -1
- package/ext/aastar-shared-config/src/abis/DVTValidator.json +0 -1
- package/ext/aastar-shared-config/src/abis/GToken.json +0 -1
- package/ext/aastar-shared-config/src/abis/GTokenStaking.json +0 -1
- package/ext/aastar-shared-config/src/abis/MySBT.json +0 -1
- package/ext/aastar-shared-config/src/abis/PaymasterFactory.json +0 -1
- package/ext/aastar-shared-config/src/abis/PaymasterV4.json +0 -1098
- package/ext/aastar-shared-config/src/abis/Registry.json +0 -1
- package/ext/aastar-shared-config/src/abis/SimpleAccount.json +0 -557
- package/ext/aastar-shared-config/src/abis/SimpleAccountFactory.json +0 -87
- package/ext/aastar-shared-config/src/abis/SuperPaymasterV2.json +0 -1
- package/ext/aastar-shared-config/src/abis/index.ts +0 -45
- package/ext/aastar-shared-config/src/abis/xPNTsFactory.json +0 -1
- package/ext/aastar-shared-config/src/abis/xPNTsToken.json +0 -1
- package/ext/aastar-shared-config/src/branding.ts +0 -32
- package/ext/aastar-shared-config/src/communities.ts +0 -93
- package/ext/aastar-shared-config/src/constants.ts +0 -67
- package/ext/aastar-shared-config/src/contract-addresses.ts +0 -95
- package/ext/aastar-shared-config/src/contract-versions.ts +0 -374
- package/ext/aastar-shared-config/src/contracts.ts +0 -414
- package/ext/aastar-shared-config/src/index.ts +0 -14
- package/ext/aastar-shared-config/sync-abis.sh +0 -92
- package/ext/aastar-shared-config/sync-versions.mjs +0 -150
- package/ext/aastar-shared-config/tsconfig.json +0 -18
- package/ext/aastar-shared-config/tsup.config.ts +0 -10
- package/ext/aastar-shared-config/verify-all.sh +0 -207
- package/ext/aastar-shared-config/verify-contracts.sh +0 -85
- package/ext/aastar-shared-config/verify-mysbt-v243.mjs +0 -27
- package/ext/aastar-shared-config/verify-onchain-versions.mjs +0 -93
- package/ext/permissionless.js/.changeset/README.md +0 -8
- package/ext/permissionless.js/.changeset/config.json +0 -11
- package/ext/permissionless.js/.env-example +0 -2
- package/ext/permissionless.js/.github/actions/install-dependencies/action.yml +0 -17
- package/ext/permissionless.js/.github/dependabot.yaml +0 -10
- package/ext/permissionless.js/.github/workflows/canary.yml +0 -49
- package/ext/permissionless.js/.github/workflows/on-pull-request.yml +0 -61
- package/ext/permissionless.js/.github/workflows/on-push-to-main.yml +0 -59
- package/ext/permissionless.js/.github/workflows/prune-tags.yml +0 -92
- package/ext/permissionless.js/.github/workflows/verify.yml +0 -114
- package/ext/permissionless.js/.size-limit.json +0 -13
- package/ext/permissionless.js/LICENSE +0 -21
- package/ext/permissionless.js/assets/banner.png +0 -0
- package/ext/permissionless.js/biome.json +0 -46
- package/ext/permissionless.js/bun.lock +0 -2340
- package/ext/permissionless.js/bun.lockb +0 -0
- package/ext/permissionless.js/package.json +0 -82
- package/ext/permissionless.js/packages/mock-paymaster/CHANGELOG.md +0 -31
- package/ext/permissionless.js/packages/mock-paymaster/constants.ts +0 -84
- package/ext/permissionless.js/packages/mock-paymaster/helpers/abi.ts +0 -1048
- package/ext/permissionless.js/packages/mock-paymaster/helpers/erc20-utils.ts +0 -105
- package/ext/permissionless.js/packages/mock-paymaster/helpers/schema.ts +0 -307
- package/ext/permissionless.js/packages/mock-paymaster/helpers/utils.ts +0 -78
- package/ext/permissionless.js/packages/mock-paymaster/index.ts +0 -63
- package/ext/permissionless.js/packages/mock-paymaster/package.json +0 -33
- package/ext/permissionless.js/packages/mock-paymaster/relay.ts +0 -424
- package/ext/permissionless.js/packages/mock-paymaster/setup.ts +0 -163
- package/ext/permissionless.js/packages/mock-paymaster/singletonPaymasters.ts +0 -230
- package/ext/permissionless.js/packages/permissionless/CHANGELOG.md +0 -893
- package/ext/permissionless.js/packages/permissionless/README.md +0 -122
- package/ext/permissionless.js/packages/permissionless/accounts/biconomy/abi/BiconomySmartAccountAbi.ts +0 -128
- package/ext/permissionless.js/packages/permissionless/accounts/biconomy/toBiconomySmartAccount.ts +0 -374
- package/ext/permissionless.js/packages/permissionless/accounts/decodeCalls.test.ts +0 -505
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/abi/EtherspotBootstrapAbi.ts +0 -94
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/constants.ts +0 -27
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/toEtherspotSmartAccount.ts +0 -369
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/getInitMSAData.ts +0 -56
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/getNonceKey.ts +0 -21
- package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/wrapMessageHash.ts +0 -43
- package/ext/permissionless.js/packages/permissionless/accounts/index.ts +0 -86
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelAccountAbi.ts +0 -87
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3AccountAbi.ts +0 -813
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3FactoryAbi.ts +0 -12
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3MetaFactoryAbi.ts +0 -17
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/constants.ts +0 -14
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/to7702KernelSmartAccount.ts +0 -63
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/toEcdsaKernelSmartAccount.ts +0 -62
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/toKernelSmartAccount.ts +0 -984
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/decodeCallData.ts +0 -43
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/encodeCallData.ts +0 -57
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/getNonceKey.ts +0 -33
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/isKernelV2.ts +0 -6
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/isWebAuthnAccount.ts +0 -8
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/signMessage.ts +0 -115
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/signTypedData.ts +0 -97
- package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/wrapMessageHash.ts +0 -44
- package/ext/permissionless.js/packages/permissionless/accounts/light/toLightSmartAccount.ts +0 -496
- package/ext/permissionless.js/packages/permissionless/accounts/nexus/toNexusSmartAccount.ts +0 -351
- package/ext/permissionless.js/packages/permissionless/accounts/safe/index.ts +0 -14
- package/ext/permissionless.js/packages/permissionless/accounts/safe/signUserOperation.test.ts +0 -275
- package/ext/permissionless.js/packages/permissionless/accounts/safe/signUserOperation.ts +0 -316
- package/ext/permissionless.js/packages/permissionless/accounts/safe/toSafeSmartAccount.ts +0 -1980
- package/ext/permissionless.js/packages/permissionless/accounts/simple/to7702SimpleSmartAccount.ts +0 -51
- package/ext/permissionless.js/packages/permissionless/accounts/simple/toSimpleSmartAccount.ts +0 -585
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/toThirdwebSmartAccount.ts +0 -221
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/decodeCallData.ts +0 -87
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/encodeCallData.ts +0 -81
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/getAccountAddress.ts +0 -48
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/getFactoryData.ts +0 -40
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/signMessage.ts +0 -33
- package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/signTypedData.ts +0 -67
- package/ext/permissionless.js/packages/permissionless/accounts/trust/toTrustSmartAccount.ts +0 -232
- package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/decodeCallData.ts +0 -87
- package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/encodeCallData.ts +0 -81
- package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/getFactoryData.ts +0 -51
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/accountId.test.ts +0 -39
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/accountId.ts +0 -93
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModule.test.ts +0 -216
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModule.ts +0 -99
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModules.test.ts +0 -237
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModules.ts +0 -96
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/isModuleInstalled.test.ts +0 -72
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/isModuleInstalled.ts +0 -132
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsExecutionMode.test.ts +0 -108
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsExecutionMode.ts +0 -158
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsModule.test.ts +0 -35
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsModule.ts +0 -120
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModule.test.ts +0 -129
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModule.ts +0 -98
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModules.test.ts +0 -117
- package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModules.ts +0 -87
- package/ext/permissionless.js/packages/permissionless/actions/erc7579.ts +0 -103
- package/ext/permissionless.js/packages/permissionless/actions/etherspot/getUserOperationGasPrice.ts +0 -32
- package/ext/permissionless.js/packages/permissionless/actions/etherspot.ts +0 -4
- package/ext/permissionless.js/packages/permissionless/actions/index.ts +0 -9
- package/ext/permissionless.js/packages/permissionless/actions/package.json +0 -6
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/getCredentials.ts +0 -47
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/startAuthentication.ts +0 -39
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/startRegistration.ts +0 -126
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/verifyAuthentication.ts +0 -142
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/verifyRegistration.ts +0 -132
- package/ext/permissionless.js/packages/permissionless/actions/passkeyServer.ts +0 -17
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/estimateErc20PaymasterCost.ts +0 -102
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getTokenQuotes.test.ts +0 -90
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getTokenQuotes.ts +0 -77
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationGasPrice.test.ts +0 -82
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationGasPrice.ts +0 -67
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationStatus.test.ts +0 -199
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationStatus.ts +0 -49
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/sendCompressedUserOperation.ts +0 -59
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/sponsorUserOperation.test.ts +0 -236
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/sponsorUserOperation.ts +0 -151
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/validateSponsorshipPolicies.test.ts +0 -153
- package/ext/permissionless.js/packages/permissionless/actions/pimlico/validateSponsorshipPolicies.ts +0 -74
- package/ext/permissionless.js/packages/permissionless/actions/pimlico.ts +0 -38
- package/ext/permissionless.js/packages/permissionless/actions/public/getAccountNonce.test.ts +0 -96
- package/ext/permissionless.js/packages/permissionless/actions/public/getAccountNonce.ts +0 -75
- package/ext/permissionless.js/packages/permissionless/actions/public/getSenderAddress.test.ts +0 -154
- package/ext/permissionless.js/packages/permissionless/actions/public/getSenderAddress.ts +0 -129
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/getCallsStatus.test.ts +0 -255
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/getCallsStatus.ts +0 -91
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendCalls.test.ts +0 -571
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendCalls.ts +0 -38
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendTransaction.test.ts +0 -416
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendTransaction.ts +0 -133
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signMessage.test.ts +0 -219
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signMessage.ts +0 -73
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signTypedData.test.ts +0 -228
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signTypedData.ts +0 -157
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount/writeContract.ts +0 -70
- package/ext/permissionless.js/packages/permissionless/actions/smartAccount.ts +0 -7
- package/ext/permissionless.js/packages/permissionless/clients/createSmartAccountClient.ts +0 -181
- package/ext/permissionless.js/packages/permissionless/clients/decorators/passkeyServer.ts +0 -57
- package/ext/permissionless.js/packages/permissionless/clients/decorators/pimlico.ts +0 -189
- package/ext/permissionless.js/packages/permissionless/clients/decorators/smartAccount.ts +0 -350
- package/ext/permissionless.js/packages/permissionless/clients/index.ts +0 -2
- package/ext/permissionless.js/packages/permissionless/clients/passkeyServer.ts +0 -69
- package/ext/permissionless.js/packages/permissionless/clients/pimlico.ts +0 -124
- package/ext/permissionless.js/packages/permissionless/errors/index.ts +0 -17
- package/ext/permissionless.js/packages/permissionless/experimental/pimlico/index.ts +0 -1
- package/ext/permissionless.js/packages/permissionless/experimental/pimlico/utils/prepareUserOperationForErc20Paymaster.test.ts +0 -523
- package/ext/permissionless.js/packages/permissionless/experimental/pimlico/utils/prepareUserOperationForErc20Paymaster.ts +0 -369
- package/ext/permissionless.js/packages/permissionless/index.ts +0 -3
- package/ext/permissionless.js/packages/permissionless/package.json +0 -102
- package/ext/permissionless.js/packages/permissionless/types/etherspot.ts +0 -12
- package/ext/permissionless.js/packages/permissionless/types/package.json +0 -6
- package/ext/permissionless.js/packages/permissionless/types/passkeyServer.ts +0 -125
- package/ext/permissionless.js/packages/permissionless/types/pimlico.ts +0 -151
- package/ext/permissionless.js/packages/permissionless/utils/decode7579Calls.ts +0 -133
- package/ext/permissionless.js/packages/permissionless/utils/decodeNonce.test.ts +0 -40
- package/ext/permissionless.js/packages/permissionless/utils/decodeNonce.ts +0 -10
- package/ext/permissionless.js/packages/permissionless/utils/deepHexlify.test.ts +0 -57
- package/ext/permissionless.js/packages/permissionless/utils/deepHexlify.ts +0 -35
- package/ext/permissionless.js/packages/permissionless/utils/encode7579Calls.test.ts +0 -69
- package/ext/permissionless.js/packages/permissionless/utils/encode7579Calls.ts +0 -114
- package/ext/permissionless.js/packages/permissionless/utils/encodeInstallModule.ts +0 -91
- package/ext/permissionless.js/packages/permissionless/utils/encodeNonce.test.ts +0 -38
- package/ext/permissionless.js/packages/permissionless/utils/encodeNonce.ts +0 -8
- package/ext/permissionless.js/packages/permissionless/utils/encodeUninstallModule.ts +0 -88
- package/ext/permissionless.js/packages/permissionless/utils/erc20AllowanceOverride.test.ts +0 -59
- package/ext/permissionless.js/packages/permissionless/utils/erc20AllowanceOverride.ts +0 -66
- package/ext/permissionless.js/packages/permissionless/utils/erc20BalanceOverride.test.ts +0 -57
- package/ext/permissionless.js/packages/permissionless/utils/erc20BalanceOverride.ts +0 -49
- package/ext/permissionless.js/packages/permissionless/utils/getAddressFromInitCodeOrPaymasterAndData.test.ts +0 -31
- package/ext/permissionless.js/packages/permissionless/utils/getAddressFromInitCodeOrPaymasterAndData.ts +0 -13
- package/ext/permissionless.js/packages/permissionless/utils/getEstimationCallData.ts +0 -297
- package/ext/permissionless.js/packages/permissionless/utils/getPackedUserOperation.test.ts +0 -204
- package/ext/permissionless.js/packages/permissionless/utils/getPackedUserOperation.ts +0 -122
- package/ext/permissionless.js/packages/permissionless/utils/getRequiredPrefund.test.ts +0 -90
- package/ext/permissionless.js/packages/permissionless/utils/getRequiredPrefund.ts +0 -56
- package/ext/permissionless.js/packages/permissionless/utils/index.ts +0 -43
- package/ext/permissionless.js/packages/permissionless/utils/isSmartAccountDeployed.ts +0 -13
- package/ext/permissionless.js/packages/permissionless/utils/ox.ts +0 -48
- package/ext/permissionless.js/packages/permissionless/utils/toOwner.ts +0 -89
- package/ext/permissionless.js/packages/permissionless/vitest.config.ts +0 -31
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/biconomy.ts +0 -22
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/etherspot.ts +0 -12
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/kernel.ts +0 -63
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/light.ts +0 -10
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/nexus.ts +0 -16
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/safe.ts +0 -75
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/simple.ts +0 -16
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/thirdweb.ts +0 -7
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/trust.ts +0 -26
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/core.ts +0 -24
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/index.ts +0 -10
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/index.ts +0 -783
- package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/instance.ts +0 -290
- package/ext/permissionless.js/packages/permissionless-test/src/testWithRpc.ts +0 -128
- package/ext/permissionless.js/packages/permissionless-test/src/types.ts +0 -12
- package/ext/permissionless.js/packages/permissionless-test/src/utils.ts +0 -1091
- package/ext/permissionless.js/packages/wagmi/CHANGELOG.md +0 -53
- package/ext/permissionless.js/packages/wagmi/README.md +0 -93
- package/ext/permissionless.js/packages/wagmi/context.ts +0 -22
- package/ext/permissionless.js/packages/wagmi/hooks/useAvailableCapabilities.ts +0 -43
- package/ext/permissionless.js/packages/wagmi/hooks/useSendTransaction.ts +0 -164
- package/ext/permissionless.js/packages/wagmi/hooks/useWaitForTransactionReceipt.ts +0 -427
- package/ext/permissionless.js/packages/wagmi/index.ts +0 -15
- package/ext/permissionless.js/packages/wagmi/package.json +0 -26
- package/ext/permissionless.js/packages/wagmi/utils/observe.ts +0 -76
- package/ext/permissionless.js/packages/wagmi-demo/README.md +0 -1
- package/ext/permissionless.js/packages/wagmi-demo/biome.json +0 -13
- package/ext/permissionless.js/packages/wagmi-demo/index.html +0 -12
- package/ext/permissionless.js/packages/wagmi-demo/package.json +0 -16
- package/ext/permissionless.js/packages/wagmi-demo/src/App.tsx +0 -98
- package/ext/permissionless.js/packages/wagmi-demo/src/PasskeyServerDemo.tsx +0 -286
- package/ext/permissionless.js/packages/wagmi-demo/src/PasskeysDemo.tsx +0 -457
- package/ext/permissionless.js/packages/wagmi-demo/src/index.css +0 -21
- package/ext/permissionless.js/packages/wagmi-demo/src/main.tsx +0 -275
- package/ext/permissionless.js/packages/wagmi-demo/src/vite-env.d.ts +0 -1
- package/ext/permissionless.js/packages/wagmi-demo/src/wagmi.ts +0 -33
- package/ext/permissionless.js/packages/wagmi-demo/tsconfig.json +0 -25
- package/ext/permissionless.js/packages/wagmi-demo/tsconfig.node.json +0 -12
- package/ext/permissionless.js/packages/wagmi-demo/vite.config.ts +0 -7
- package/ext/permissionless.js/tsconfig/tsconfig.base.json +0 -42
- package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.cjs.json +0 -11
- package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.esm.json +0 -9
- package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.json +0 -17
- package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.types.json +0 -13
- package/ext/permissionless.js/tsconfig/tsconfig.permissionless.cjs.json +0 -11
- package/ext/permissionless.js/tsconfig/tsconfig.permissionless.esm.json +0 -9
- package/ext/permissionless.js/tsconfig/tsconfig.permissionless.json +0 -18
- package/ext/permissionless.js/tsconfig/tsconfig.permissionless.types.json +0 -13
- package/ext/permissionless.js/tsconfig/tsconfig.wagmi.esm.json +0 -8
- package/ext/permissionless.js/tsconfig/tsconfig.wagmi.json +0 -19
- package/ext/permissionless.js/tsconfig/tsconfig.wagmi.types.json +0 -12
- package/extract_abis.sh +0 -140
- package/extract_addresses_to_env.sh +0 -67
- package/final_safe_harmonize.py +0 -77
- package/lib/SHARED_CONFIG_REFERENCE.md +0 -133
- package/lib/shared-config/.env.example +0 -6
- package/lib/shared-config/.github/workflows/check-secrets.yml +0 -257
- package/lib/shared-config/AGENTS.md +0 -21
- package/lib/shared-config/CHANGELOG.md +0 -99
- package/lib/shared-config/LICENSE +0 -21
- package/lib/shared-config/QUICK_START.md +0 -215
- package/lib/shared-config/README.md +0 -412
- package/lib/shared-config/SHARED_CONFIG_SUMMARY.md +0 -273
- package/lib/shared-config/check-locker-status.mjs +0 -7
- package/lib/shared-config/favicon.ico +0 -0
- package/lib/shared-config/generate-comparison-table.sh +0 -67
- package/lib/shared-config/package.json +0 -46
- package/lib/shared-config/pnpm-lock.yaml +0 -1182
- package/lib/shared-config/src/abis/BLSAggregator.json +0 -1
- package/lib/shared-config/src/abis/DVTValidator.json +0 -1
- package/lib/shared-config/src/abis/GToken.json +0 -1
- package/lib/shared-config/src/abis/GTokenStaking.json +0 -1
- package/lib/shared-config/src/abis/MySBT.json +0 -1
- package/lib/shared-config/src/abis/PaymasterFactory.json +0 -1
- package/lib/shared-config/src/abis/PaymasterV4.json +0 -1098
- package/lib/shared-config/src/abis/Registry.json +0 -1
- package/lib/shared-config/src/abis/SimpleAccount.json +0 -557
- package/lib/shared-config/src/abis/SimpleAccountFactory.json +0 -87
- package/lib/shared-config/src/abis/SuperPaymasterV2.json +0 -1
- package/lib/shared-config/src/abis/index.ts +0 -45
- package/lib/shared-config/src/abis/xPNTsFactory.json +0 -1
- package/lib/shared-config/src/abis/xPNTsToken.json +0 -1
- package/lib/shared-config/src/branding.ts +0 -32
- package/lib/shared-config/src/communities.ts +0 -93
- package/lib/shared-config/src/constants.ts +0 -67
- package/lib/shared-config/src/contract-addresses.ts +0 -95
- package/lib/shared-config/src/contract-versions.ts +0 -374
- package/lib/shared-config/src/contracts.ts +0 -414
- package/lib/shared-config/src/index.ts +0 -14
- package/lib/shared-config/src/networks.ts +0 -117
- package/lib/shared-config/sync-abis.sh +0 -92
- package/lib/shared-config/sync-versions.mjs +0 -150
- package/lib/shared-config/tsconfig.json +0 -18
- package/lib/shared-config/tsup.config.ts +0 -10
- package/lib/shared-config/verify-all.sh +0 -207
- package/lib/shared-config/verify-contracts.sh +0 -85
- package/lib/shared-config/verify-mysbt-v243.mjs +0 -27
- package/lib/shared-config/verify-onchain-versions.mjs +0 -93
- package/packages/account/package.json +0 -20
- package/packages/account/src/eoa.ts +0 -31
- package/packages/account/src/index.ts +0 -61
- package/packages/account/tsconfig.json +0 -12
- package/packages/analytics/package.json +0 -21
- package/packages/analytics/src/index.ts +0 -145
- package/packages/analytics/tsconfig.json +0 -16
- package/packages/community/package.json +0 -22
- package/packages/community/src/index.ts +0 -306
- package/packages/community/tsconfig.json +0 -8
- package/packages/core/package.json +0 -22
- package/packages/core/src/abis/BLSAggregator.json +0 -572
- package/packages/core/src/abis/BLSValidator.json +0 -26
- package/packages/core/src/abis/DVTValidator.json +0 -370
- package/packages/core/src/abis/Eip7702Support.json +0 -24
- package/packages/core/src/abis/EntryPoint.json +0 -1379
- package/packages/core/src/abis/GToken.json +0 -523
- package/packages/core/src/abis/GTokenStaking.json +0 -931
- package/packages/core/src/abis/LegacyAccount.json +0 -625
- package/packages/core/src/abis/MySBT.json +0 -1586
- package/packages/core/src/abis/Paymaster.json +0 -1205
- package/packages/core/src/abis/PaymasterFactory.json +0 -650
- package/packages/core/src/abis/PaymasterV4_2.json +0 -1183
- package/packages/core/src/abis/Registry.json +0 -1636
- package/packages/core/src/abis/ReputationSystem.json +0 -477
- package/packages/core/src/abis/SenderCreator.json +0 -99
- package/packages/core/src/abis/Simple7702Account.json +0 -395
- package/packages/core/src/abis/SimpleAccount.json +0 -625
- package/packages/core/src/abis/SimpleAccountFactory.json +0 -108
- package/packages/core/src/abis/SimpleAccountFactoryV08.json +0 -87
- package/packages/core/src/abis/SimpleAccountV08.json +0 -557
- package/packages/core/src/abis/SuperPaymaster.json +0 -1399
- package/packages/core/src/abis/UserOperationLib.json +0 -57
- package/packages/core/src/abis/aPNTs.json +0 -1173
- package/packages/core/src/abis/index.ts +0 -68
- package/packages/core/src/abis/xPNTsFactory.json +0 -728
- package/packages/core/src/abis/xPNTsToken.json +0 -1173
- package/packages/core/src/actions/aggregator.ts +0 -41
- package/packages/core/src/actions/dvt.ts +0 -53
- package/packages/core/src/actions/factory.ts +0 -41
- package/packages/core/src/actions/paymasterV4.ts +0 -263
- package/packages/core/src/actions/registry.ts +0 -120
- package/packages/core/src/actions/reputation.ts +0 -27
- package/packages/core/src/actions/sbt.ts +0 -97
- package/packages/core/src/actions/staking.ts +0 -79
- package/packages/core/src/actions/superPaymaster.ts +0 -117
- package/packages/core/src/actions/tokens.ts +0 -65
- package/packages/core/src/branding.ts +0 -32
- package/packages/core/src/clients.ts +0 -13
- package/packages/core/src/communities.ts +0 -93
- package/packages/core/src/constants.ts +0 -81
- package/packages/core/src/contract-addresses.ts +0 -101
- package/packages/core/src/contract-versions.ts +0 -374
- package/packages/core/src/contracts.ts +0 -414
- package/packages/core/src/networks.ts +0 -127
- package/packages/core/src/roles.ts +0 -244
- package/packages/core/src/utils.ts +0 -23
- package/packages/core/tsconfig.json +0 -12
- package/packages/dapp/package.json +0 -27
- package/packages/dapp/src/ui/components/EvaluationPanel.tsx +0 -40
- package/packages/dapp/tsconfig.json +0 -13
- package/packages/enduser/package.json +0 -21
- package/packages/enduser/src/index.ts +0 -138
- package/packages/enduser/tsconfig.json +0 -8
- package/packages/identity/package.json +0 -22
- package/packages/identity/src/index.ts +0 -82
- package/packages/identity/tsconfig.json +0 -12
- package/packages/operator/package.json +0 -21
- package/packages/operator/src/index.ts +0 -172
- package/packages/operator/tsconfig.json +0 -8
- package/packages/paymaster/package.json +0 -22
- package/packages/paymaster/src/V4/index.ts +0 -123
- package/packages/paymaster/tsconfig.json +0 -12
- package/packages/sdk/README.md +0 -150
- package/packages/sdk/aastar/package.json +0 -21
- package/packages/sdk/aastar/src/index.ts +0 -3
- package/packages/sdk/aastar/tsconfig.json +0 -8
- package/packages/sdk/package.json +0 -32
- package/packages/sdk/src/clients/admin.ts +0 -54
- package/packages/sdk/src/clients/community.ts +0 -403
- package/packages/sdk/src/clients/endUser.ts +0 -173
- package/packages/sdk/src/clients/operator.ts +0 -277
- package/packages/sdk/src/errors/decoder.ts +0 -48
- package/packages/sdk/src/index.ts +0 -20
- package/packages/sdk/src/utils/validation.ts +0 -356
- package/packages/sdk/tsconfig.json +0 -12
- package/packages/tokens/package.json +0 -22
- package/packages/tokens/src/index.ts +0 -245
- package/packages/tokens/tsconfig.json +0 -12
- package/pnpm-workspace.yaml +0 -2
- package/run_full_regression.sh +0 -215
- package/run_sdk_regression.sh +0 -213
- package/safe_harmonize.py +0 -107
- package/scripts/00_utils.ts +0 -59
- package/scripts/00_verify_phase1.ts +0 -130
- package/scripts/01_1_prep_gtoken.ts +0 -81
- package/scripts/01_2_register_sbt.ts +0 -88
- package/scripts/01_3_prep_tokens_paymaster.ts +0 -102
- package/scripts/01_prepare_all.ts +0 -271
- package/scripts/02_test_eoa.ts +0 -50
- package/scripts/03_test_standard_aa.ts +0 -173
- package/scripts/04_0_check_deploy.ts +0 -24
- package/scripts/04_1_check_allowance.ts +0 -44
- package/scripts/04_2_construct_verify.ts +0 -96
- package/scripts/04_3_verify_estimate.ts +0 -66
- package/scripts/04_4_verify_pack.ts +0 -74
- package/scripts/04_test_paymaster_v4.ts +0 -217
- package/scripts/05_1_deposit.ts +0 -48
- package/scripts/05_test_superpaymaster.ts +0 -380
- package/scripts/06_local_test_v3_admin.ts +0 -163
- package/scripts/06_local_test_v3_execution.ts +0 -132
- package/scripts/06_local_test_v3_full.ts +0 -490
- package/scripts/06_local_test_v3_funding.ts +0 -124
- package/scripts/06_local_test_v3_reputation.ts +0 -234
- package/scripts/07_local_test_v3_audit.ts +0 -181
- package/scripts/08_local_test_registry_lifecycle.ts +0 -382
- package/scripts/09_local_test_community_lifecycle.ts +0 -384
- package/scripts/09_local_test_community_simple.ts +0 -108
- package/scripts/09_scenario_bread_independent.ts +0 -247
- package/scripts/10_scenario_super_shared.ts +0 -196
- package/scripts/10_test_protocol_admin_full.ts +0 -173
- package/scripts/11_scenario_hacker_defense.ts +0 -104
- package/scripts/11_test_core_flows_full.ts +0 -279
- package/scripts/12_test_slash_mechanism.ts +0 -205
- package/scripts/12_test_slash_queries.ts +0 -83
- package/scripts/12_test_staking_exit.ts +0 -152
- package/scripts/12_test_staking_slash.ts +0 -301
- package/scripts/12_test_tier2_slash.ts +0 -139
- package/scripts/13_test_sbt_burn_linkage.ts +0 -266
- package/scripts/14_test_credit_redesign.ts +0 -266
- package/scripts/15_test_bls_full.ts +0 -125
- package/scripts/15_test_dvt_bls_full.ts +0 -133
- package/scripts/17_test_cross_role_collaboration.ts +0 -95
- package/scripts/18_sdk_e2e_verification.ts +0 -67
- package/scripts/18_test_dvt_sdk_flow.ts +0 -138
- package/scripts/18_test_lifecycle_completion.ts +0 -144
- package/scripts/19_sdk_experiment_runner.ts +0 -89
- package/scripts/19_sdk_experiment_runner.ts.backup +0 -391
- package/scripts/20_sdk_full_capability.ts +0 -95
- package/scripts/20_test_superpaymaster_new_apis.ts +0 -193
- package/scripts/21_test_paymasterv4_complete.ts +0 -341
- package/scripts/22_test_bls_signing.ts +0 -260
- package/scripts/23_test_middleware.ts +0 -197
- package/scripts/98_edge_reentrancy.ts +0 -85
- package/scripts/99_bug_hunting_fast.ts +0 -216
- package/scripts/collect_industry_baseline.ts +0 -236
- package/scripts/complete_env_config.ts +0 -97
- package/scripts/debug_account_c.ts +0 -43
- package/scripts/debug_bls.ts +0 -58
- package/scripts/debug_config_v036.ts +0 -13
- package/scripts/debug_contracts.ts +0 -2
- package/scripts/debug_env.ts +0 -69
- package/scripts/debug_find_paymaster.ts +0 -98
- package/scripts/debug_isolated_registration.ts +0 -256
- package/scripts/debug_paymaster_config.ts +0 -19
- package/scripts/debug_pim_addr.ts +0 -23
- package/scripts/debug_pm_status.ts +0 -51
- package/scripts/debug_registry.ts +0 -39
- package/scripts/debug_registry_setup.ts +0 -129
- package/scripts/debug_sanity.ts +0 -32
- package/scripts/debug_shared_config.ts +0 -10
- package/scripts/debug_token_compat.ts +0 -51
- package/scripts/debug_tokens.ts +0 -41
- package/scripts/debug_vcheck.ts +0 -33
- package/scripts/deploy_and_init_v3.sh +0 -134
- package/scripts/deploy_anvil_accounts.ts +0 -144
- package/scripts/deploy_paymaster_v4.ts +0 -139
- package/scripts/deploy_test_accounts.ts +0 -401
- package/scripts/experiment/stage3/SETUP_GUIDE.md +0 -258
- package/scripts/experiment/stage3/archived_scripts/00_token_distribution.ts +0 -78
- package/scripts/experiment/stage3/archived_scripts/01_dao_launch.ts +0 -96
- package/scripts/experiment/stage3/archived_scripts/01b_bread_launch.ts +0 -112
- package/scripts/experiment/stage3/archived_scripts/02_operator_setup.ts +0 -84
- package/scripts/experiment/stage3/archived_scripts/02b_operator_b_setup.ts +0 -104
- package/scripts/experiment/stage3/archived_scripts/02c_finalize_operators.ts +0 -86
- package/scripts/experiment/stage3/archived_scripts/02d_operator_collateral.ts +0 -89
- package/scripts/experiment/stage3/archived_scripts/03_user_onboarding.ts +0 -83
- package/scripts/experiment/stage3/archived_scripts/03b_deploy_aa_account.ts +0 -61
- package/scripts/experiment/stage3/archived_scripts/03c_aa_onboarding.ts +0 -104
- package/scripts/experiment/stage3/archived_scripts/03d_mint_points.ts +0 -60
- package/scripts/experiment/stage3/archived_scripts/04_benchmarking.ts +0 -100
- package/scripts/experiment/stage3/archived_scripts/05_multi_op_setup.ts +0 -149
- package/scripts/experiment/stage3/archived_scripts/README.md +0 -58
- package/scripts/experiment/stage3/archived_scripts/check_roles.ts +0 -29
- package/scripts/experiment/stage3/archived_scripts/decode_error.ts +0 -23
- package/scripts/experiment/stage3/archived_scripts/fund_user.ts +0 -51
- package/scripts/experiment/stage3/archived_scripts/gen_b_key.ts +0 -3
- package/scripts/experiment/stage3/archived_scripts/gen_keys.ts +0 -4
- package/scripts/experiment/stage3/archived_scripts/setup.ts +0 -105
- package/scripts/experiment/stage3/archived_scripts/test_key.ts +0 -4
- package/scripts/experiment/stage3/archived_scripts/verify_state.ts +0 -59
- package/scripts/experiment/stage3/refactored/00_token_distribution.ts +0 -46
- package/scripts/experiment/stage3/refactored/02_operator_setup.ts +0 -65
- package/scripts/experiment/stage3/refactored/03_user_onboarding.ts +0 -68
- package/scripts/experiment/stage3/refactored/05_multi_op_setup.ts +0 -63
- package/scripts/experiment/stage3/refactored/README.md +0 -71
- package/scripts/extract-docs.sh +0 -72
- package/scripts/generate_env_from_deployment.ts +0 -109
- package/scripts/publish_all.sh +0 -39
- package/scripts/quick_setup.ts +0 -124
- package/scripts/run_automated_experiment.sh +0 -121
- package/scripts/run_daily_experiment.ts +0 -70
- package/scripts/security_audit.sh +0 -172
- package/scripts/sync_config_to_env.ts +0 -88
- package/scripts/test_groups.ts +0 -267
- package/scripts/test_multi_community_anvil.ts +0 -276
- package/scripts/test_new_sdk_apis_sepolia.ts +0 -115
- package/scripts/test_sdk_join_idempotent.ts +0 -233
- package/scripts/test_simple_sepolia.ts +0 -44
- package/scripts/v2_regression/README.md +0 -161
- package/scripts/validate_environment.ts +0 -140
- package/sdk_experiment_data.csv +0 -2
- package/surgical_harmonize.py +0 -83
- package/tsconfig.json +0 -15
- package/typedoc.json +0 -25
- /package/{packages/core/src/crypto/index.ts → dist/core/src/crypto/index.d.ts} +0 -0
- /package/{packages/sdk/examples → examples}/config.json +0 -0
- /package/{packages/sdk/examples → examples}/regression_test.ts +0 -0
|
@@ -0,0 +1,388 @@
|
|
|
1
|
+
import { createClient, publicActions, walletActions, parseEther, encodeFunctionData, pad, concat } from 'viem';
|
|
2
|
+
import { registryActions, sbtActions, superPaymasterActions, paymasterV4Actions, CORE_ADDRESSES, TOKEN_ADDRESSES, TEST_ACCOUNT_ADDRESSES, RegistryABI, EntryPointABI, SimpleAccountFactoryABI, xPNTsFactoryABI, validateAddress, validateHex, } from '@aastar/core';
|
|
3
|
+
import { AAStarError, AAStarErrorCode as AAStarErrorType, createError } from '../errors/AAStarError.js';
|
|
4
|
+
import { decodeContractError } from '../errors/decoder.js';
|
|
5
|
+
import { decodeContractEvents, logDecodedEvents } from '../utils/eventDecoder.js';
|
|
6
|
+
export function createEndUserClient({ chain, transport, account, addresses }) {
|
|
7
|
+
const client = createClient({
|
|
8
|
+
chain,
|
|
9
|
+
transport,
|
|
10
|
+
account
|
|
11
|
+
})
|
|
12
|
+
.extend(publicActions)
|
|
13
|
+
.extend(walletActions);
|
|
14
|
+
const usedAddresses = { ...CORE_ADDRESSES, ...TOKEN_ADDRESSES, ...TEST_ACCOUNT_ADDRESSES, ...addresses };
|
|
15
|
+
const actions = {
|
|
16
|
+
...registryActions(usedAddresses.registry)(client),
|
|
17
|
+
...sbtActions(usedAddresses.mySBT)(client),
|
|
18
|
+
...superPaymasterActions(usedAddresses.superPaymaster)(client),
|
|
19
|
+
...paymasterV4Actions(usedAddresses.paymasterV4)(client)
|
|
20
|
+
};
|
|
21
|
+
return Object.assign(client, actions, {
|
|
22
|
+
async onboard({ community, roleId, roleData }) {
|
|
23
|
+
community = validateAddress(community, 'Community');
|
|
24
|
+
roleId = validateHex(roleId, 'RoleId');
|
|
25
|
+
console.log('👤 Onboarding user to community...');
|
|
26
|
+
const result = await this.joinAndActivate({ community, roleId, roleData });
|
|
27
|
+
console.log(`✅ User onboarded! SBT ID: ${result.sbtId}`);
|
|
28
|
+
return { hash: result.hash, events: result.events, sbtId: result.sbtId };
|
|
29
|
+
},
|
|
30
|
+
async joinAndActivate({ community, roleId, roleData }) {
|
|
31
|
+
const accountToUse = account;
|
|
32
|
+
if (!accountToUse)
|
|
33
|
+
throw createError.validation("Account", "Account required for joinAndActivate");
|
|
34
|
+
// Validation
|
|
35
|
+
community = validateAddress(community, 'Community');
|
|
36
|
+
roleId = validateHex(roleId, 'RoleId');
|
|
37
|
+
console.log(` SDK: Joining community ${community}...`);
|
|
38
|
+
// Registry.registerRoleSelf is now idempotent (modified contract)
|
|
39
|
+
// If roleData not provided, encode EndUserRoleData structure
|
|
40
|
+
let finalData;
|
|
41
|
+
if (roleData) {
|
|
42
|
+
finalData = roleData;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
// Encode EndUserRoleData: (address account, address community, string avatarURI, string ensName, uint256 stakeAmount)
|
|
46
|
+
const { encodeAbiParameters } = await import('viem');
|
|
47
|
+
finalData = encodeAbiParameters([
|
|
48
|
+
{ name: 'account', type: 'address' },
|
|
49
|
+
{ name: 'community', type: 'address' },
|
|
50
|
+
{ name: 'avatarURI', type: 'string' },
|
|
51
|
+
{ name: 'ensName', type: 'string' },
|
|
52
|
+
{ name: 'stakeAmount', type: 'uint256' }
|
|
53
|
+
], [accountToUse.address, community, '', '', 0n] // Use minimum stake (Registry will use roleConfig.minStake)
|
|
54
|
+
);
|
|
55
|
+
}
|
|
56
|
+
try {
|
|
57
|
+
const regTx = await client.writeContract({
|
|
58
|
+
address: usedAddresses.registry,
|
|
59
|
+
abi: RegistryABI,
|
|
60
|
+
functionName: 'registerRoleSelf',
|
|
61
|
+
args: [roleId, finalData],
|
|
62
|
+
account: accountToUse,
|
|
63
|
+
chain
|
|
64
|
+
});
|
|
65
|
+
const receipt = await client.waitForTransactionReceipt({ hash: regTx });
|
|
66
|
+
const events = decodeContractEvents(receipt.logs);
|
|
67
|
+
logDecodedEvents(events);
|
|
68
|
+
// 2. Fetch SBT ID
|
|
69
|
+
const sbtId = await actions.sbtGetUserSBT({ user: accountToUse.address, roleId });
|
|
70
|
+
console.log(` SDK: User joined. SBT ID: ${sbtId}`);
|
|
71
|
+
// 3. Fetch Initial Credit for verification
|
|
72
|
+
let credit = 0n;
|
|
73
|
+
try {
|
|
74
|
+
// Use Imported ABI
|
|
75
|
+
const tokenAddress = await client.readContract({
|
|
76
|
+
address: usedAddresses.xPNTsFactory,
|
|
77
|
+
abi: xPNTsFactoryABI,
|
|
78
|
+
functionName: 'communityToToken',
|
|
79
|
+
args: [community]
|
|
80
|
+
});
|
|
81
|
+
// If token exists (not zero address), check credit
|
|
82
|
+
if (tokenAddress && tokenAddress !== '0x0000000000000000000000000000000000000000') {
|
|
83
|
+
credit = await actions.superPaymasterGetAvailableCredit({
|
|
84
|
+
user: client.aaAddress || accountToUse.address,
|
|
85
|
+
operator: tokenAddress
|
|
86
|
+
});
|
|
87
|
+
console.log(` SDK: Activation complete. Current Credit: ${credit} points.`);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
catch (error) {
|
|
91
|
+
// Graceful degradation if credit system not ready
|
|
92
|
+
console.log(` SDK: Credit system check skipped (${error.message?.split('\n')[0]}).`);
|
|
93
|
+
}
|
|
94
|
+
return {
|
|
95
|
+
hash: regTx,
|
|
96
|
+
events,
|
|
97
|
+
sbtId,
|
|
98
|
+
initialCredit: credit
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
catch (error) {
|
|
102
|
+
const decodedMsg = decodeContractError(error);
|
|
103
|
+
console.error(` ❌ joinAndActivate failed:`, decodedMsg || error.message);
|
|
104
|
+
if (decodedMsg) {
|
|
105
|
+
throw new AAStarError(`Joining Community Failed: ${decodedMsg}`, AAStarErrorType.CONTRACT_ERROR);
|
|
106
|
+
}
|
|
107
|
+
throw error;
|
|
108
|
+
}
|
|
109
|
+
},
|
|
110
|
+
async executeGasless({ target, data, value = 0n, operator }) {
|
|
111
|
+
const accountToUse = account;
|
|
112
|
+
if (!accountToUse)
|
|
113
|
+
throw createError.validation("Wallet", "Wallet account required for gasless execution");
|
|
114
|
+
// Validation
|
|
115
|
+
target = validateAddress(target, 'Target Address');
|
|
116
|
+
operator = validateAddress(operator, 'Operator Address');
|
|
117
|
+
if (value < 0n)
|
|
118
|
+
throw new AAStarError('Value must be positive', AAStarErrorType.VALIDATION_ERROR);
|
|
119
|
+
// 1. Get AA Address (Predict if necessary)
|
|
120
|
+
const { accountAddress } = await this.createSmartAccount({ owner: accountToUse.address });
|
|
121
|
+
console.log(` SDK: Executing gasless via AA ${accountAddress} Sponsored by ${operator}`);
|
|
122
|
+
// 2. Fetch Nonce from EntryPoint (v0.7 standard)
|
|
123
|
+
let nonce = 0n;
|
|
124
|
+
try {
|
|
125
|
+
nonce = await client.readContract({
|
|
126
|
+
address: usedAddresses.entryPoint,
|
|
127
|
+
abi: EntryPointABI,
|
|
128
|
+
functionName: 'getNonce',
|
|
129
|
+
args: [accountAddress, 0n] // 0 = default nonce key
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
catch (e) {
|
|
133
|
+
console.warn(` ⚠️ Failed to fetch nonce from EntryPoint, using default 0:`, e.message);
|
|
134
|
+
nonce = 0n;
|
|
135
|
+
}
|
|
136
|
+
// 3. Build UserOp via PaymasterClient Helpers available or explicit logic
|
|
137
|
+
// Since PaymasterClient.submitGaslessUserOperation is an all-in-one, we can't easily use it here
|
|
138
|
+
// if we want to return the exact structure { hash, events } AND control the signing manually if needed (EndUserClient acts as the wallet interface).
|
|
139
|
+
// However, EndUserClient has access to 'account' (privateKey account usually).
|
|
140
|
+
// So we can use PaymasterClient helpers.
|
|
141
|
+
// Construct CallData
|
|
142
|
+
// PaymasterClient.encodeExecution is STATIC.
|
|
143
|
+
const callData = encodeFunctionData({
|
|
144
|
+
abi: [{ type: 'function', name: 'execute', inputs: [{ type: 'address' }, { type: 'uint256' }, { type: 'bytes' }] }],
|
|
145
|
+
functionName: 'execute',
|
|
146
|
+
args: [target, value, data]
|
|
147
|
+
});
|
|
148
|
+
// Construct UserOp
|
|
149
|
+
const paymasterVerificationGas = 250000n; // Estimation safe buffer
|
|
150
|
+
const paymasterPostOpGas = 50000n;
|
|
151
|
+
const paymasterAndData = concat([
|
|
152
|
+
usedAddresses.superPaymaster,
|
|
153
|
+
pad(`0x${paymasterVerificationGas.toString(16)}`, { dir: 'left', size: 16 }),
|
|
154
|
+
pad(`0x${paymasterPostOpGas.toString(16)}`, { dir: 'left', size: 16 }),
|
|
155
|
+
operator
|
|
156
|
+
]);
|
|
157
|
+
const accountGasLimits = concat([
|
|
158
|
+
pad(`0x${(100000).toString(16)}`, { dir: 'left', size: 16 }), // verification
|
|
159
|
+
pad(`0x${(100000).toString(16)}`, { dir: 'left', size: 16 }) // call
|
|
160
|
+
]);
|
|
161
|
+
const gasFees = concat([
|
|
162
|
+
pad(`0x${(2000000000).toString(16)}`, { dir: 'left', size: 16 }), // 2 gwei defaults
|
|
163
|
+
pad(`0x${(2000000000).toString(16)}`, { dir: 'left', size: 16 })
|
|
164
|
+
]);
|
|
165
|
+
const userOp = {
|
|
166
|
+
sender: accountAddress,
|
|
167
|
+
nonce,
|
|
168
|
+
initCode: '0x', // Optimization: Assume deployed or separate deploy
|
|
169
|
+
callData,
|
|
170
|
+
accountGasLimits,
|
|
171
|
+
preVerificationGas: 50000n,
|
|
172
|
+
gasFees,
|
|
173
|
+
paymasterAndData,
|
|
174
|
+
signature: '0x'
|
|
175
|
+
};
|
|
176
|
+
// If account is not deployed, initCode needs to be set.
|
|
177
|
+
const byteCode = await client.getBytecode({ address: accountAddress });
|
|
178
|
+
if (!byteCode || byteCode === '0x') {
|
|
179
|
+
const { initCode } = await this.createSmartAccount({ owner: accountToUse.address });
|
|
180
|
+
userOp.initCode = initCode;
|
|
181
|
+
}
|
|
182
|
+
// Get Hash
|
|
183
|
+
const entryPointAddress = usedAddresses.entryPoint || '0x0000000071727De22E5E9d8BAf0edAc6f37da032';
|
|
184
|
+
const userOpHash = await client.readContract({
|
|
185
|
+
address: entryPointAddress,
|
|
186
|
+
abi: EntryPointABI,
|
|
187
|
+
functionName: 'getUserOpHash',
|
|
188
|
+
args: [userOp]
|
|
189
|
+
});
|
|
190
|
+
// Sign
|
|
191
|
+
const signature = await accountToUse.signMessage({
|
|
192
|
+
message: { raw: userOpHash }
|
|
193
|
+
});
|
|
194
|
+
userOp.signature = signature;
|
|
195
|
+
try {
|
|
196
|
+
// Submit
|
|
197
|
+
console.log(` SDK: Submitting UserOp ${userOpHash}...`);
|
|
198
|
+
const tx = await client.writeContract({
|
|
199
|
+
address: entryPointAddress,
|
|
200
|
+
abi: EntryPointABI,
|
|
201
|
+
functionName: 'handleOps',
|
|
202
|
+
args: [[userOp], accountToUse.address],
|
|
203
|
+
account,
|
|
204
|
+
chain
|
|
205
|
+
});
|
|
206
|
+
const receipt = await client.waitForTransactionReceipt({ hash: tx });
|
|
207
|
+
const events = decodeContractEvents(receipt.logs);
|
|
208
|
+
logDecodedEvents(events);
|
|
209
|
+
return { hash: tx, events };
|
|
210
|
+
}
|
|
211
|
+
catch (error) {
|
|
212
|
+
const decodedMsg = decodeContractError(error);
|
|
213
|
+
if (decodedMsg) {
|
|
214
|
+
throw new AAStarError(`Gasless Execution Failed: ${decodedMsg}`, AAStarErrorType.CONTRACT_ERROR);
|
|
215
|
+
}
|
|
216
|
+
throw error;
|
|
217
|
+
}
|
|
218
|
+
},
|
|
219
|
+
async executeGaslessBatch({ targets, datas, values, operator }) {
|
|
220
|
+
const accountToUse = account;
|
|
221
|
+
if (!accountToUse)
|
|
222
|
+
throw createError.validation("Wallet", "Wallet account required for gasless execution");
|
|
223
|
+
// Validation
|
|
224
|
+
targets.forEach(t => validateAddress(t, 'Target'));
|
|
225
|
+
operator = validateAddress(operator, 'Operator');
|
|
226
|
+
const finalValues = values || targets.map(() => 0n);
|
|
227
|
+
// 1. Get AA Address (Predict if necessary)
|
|
228
|
+
const { accountAddress } = await this.createSmartAccount({ owner: accountToUse.address });
|
|
229
|
+
console.log(` SDK: Executing gasless batch via AA ${accountAddress} Sponsored by ${operator}`);
|
|
230
|
+
// 2. Fetch Nonce
|
|
231
|
+
let nonce = 0n;
|
|
232
|
+
try {
|
|
233
|
+
nonce = await client.readContract({
|
|
234
|
+
address: usedAddresses.entryPoint,
|
|
235
|
+
abi: EntryPointABI,
|
|
236
|
+
functionName: 'getNonce',
|
|
237
|
+
args: [accountAddress, 0n]
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
catch (e) {
|
|
241
|
+
nonce = 0n;
|
|
242
|
+
}
|
|
243
|
+
// 3. Build CallData (executeBatch)
|
|
244
|
+
const executeData = encodeFunctionData({
|
|
245
|
+
abi: [{ type: 'function', name: 'executeBatch', inputs: [{ type: 'address[]' }, { type: 'uint256[]' }, { type: 'bytes[]' }] }],
|
|
246
|
+
functionName: 'executeBatch',
|
|
247
|
+
args: [targets, finalValues, datas]
|
|
248
|
+
});
|
|
249
|
+
// 4. Build Gas Limits & Fees
|
|
250
|
+
const accountGasLimits = concat([
|
|
251
|
+
pad(`0x${(150000).toString(16)}`, { dir: 'left', size: 16 }),
|
|
252
|
+
pad(`0x${(300000).toString(16)}`, { dir: 'left', size: 16 })
|
|
253
|
+
]);
|
|
254
|
+
const gasFees = concat([
|
|
255
|
+
pad(`0x${(2000000000).toString(16)}`, { dir: 'left', size: 16 }),
|
|
256
|
+
pad(`0x${(2000000000).toString(16)}`, { dir: 'left', size: 16 })
|
|
257
|
+
]);
|
|
258
|
+
// 5. Paymaster
|
|
259
|
+
const paymasterAndData = concat([
|
|
260
|
+
usedAddresses.superPaymaster,
|
|
261
|
+
pad(`0x${(300000).toString(16)}`, { dir: 'left', size: 16 }),
|
|
262
|
+
pad(`0x${(50000).toString(16)}`, { dir: 'left', size: 16 }),
|
|
263
|
+
operator
|
|
264
|
+
]);
|
|
265
|
+
const userOp = {
|
|
266
|
+
sender: accountAddress,
|
|
267
|
+
nonce,
|
|
268
|
+
initCode: '0x',
|
|
269
|
+
callData: executeData,
|
|
270
|
+
accountGasLimits,
|
|
271
|
+
preVerificationGas: 100000n,
|
|
272
|
+
gasFees,
|
|
273
|
+
paymasterAndData,
|
|
274
|
+
signature: '0x'
|
|
275
|
+
};
|
|
276
|
+
const byteCode = await client.getBytecode({ address: accountAddress });
|
|
277
|
+
if (!byteCode || byteCode === '0x') {
|
|
278
|
+
const { initCode } = await this.createSmartAccount({ owner: accountToUse.address });
|
|
279
|
+
userOp.initCode = initCode;
|
|
280
|
+
}
|
|
281
|
+
const entryPointAddress = usedAddresses.entryPoint || '0x0000000071727De22E5E9d8BAf0edAc6f37da032';
|
|
282
|
+
const userOpHash = await client.readContract({
|
|
283
|
+
address: entryPointAddress,
|
|
284
|
+
abi: EntryPointABI,
|
|
285
|
+
functionName: 'getUserOpHash',
|
|
286
|
+
args: [userOp]
|
|
287
|
+
});
|
|
288
|
+
const signature = await accountToUse.signMessage({
|
|
289
|
+
message: { raw: userOpHash }
|
|
290
|
+
});
|
|
291
|
+
userOp.signature = signature;
|
|
292
|
+
try {
|
|
293
|
+
console.log(` SDK: Submitting Batch UserOp ${userOpHash}...`);
|
|
294
|
+
const tx = await client.writeContract({
|
|
295
|
+
address: entryPointAddress,
|
|
296
|
+
abi: EntryPointABI,
|
|
297
|
+
functionName: 'handleOps',
|
|
298
|
+
args: [[userOp], accountToUse.address],
|
|
299
|
+
account,
|
|
300
|
+
chain
|
|
301
|
+
});
|
|
302
|
+
const receipt = await client.waitForTransactionReceipt({ hash: tx });
|
|
303
|
+
const events = decodeContractEvents(receipt.logs);
|
|
304
|
+
logDecodedEvents(events);
|
|
305
|
+
return { hash: tx, events };
|
|
306
|
+
}
|
|
307
|
+
catch (error) {
|
|
308
|
+
const decodedMsg = decodeContractError(error);
|
|
309
|
+
if (decodedMsg) {
|
|
310
|
+
throw new AAStarError(`Gasless Batch Execution Failed: ${decodedMsg}`, AAStarErrorType.CONTRACT_ERROR);
|
|
311
|
+
}
|
|
312
|
+
throw error;
|
|
313
|
+
}
|
|
314
|
+
},
|
|
315
|
+
async checkJoinRequirements(address) {
|
|
316
|
+
const accountToUse = address || account?.address;
|
|
317
|
+
if (!accountToUse)
|
|
318
|
+
throw createError.validation("Account", "Account address required for requirement check");
|
|
319
|
+
validateAddress(accountToUse, 'Check Address');
|
|
320
|
+
const { RequirementChecker } = await import('@aastar/core');
|
|
321
|
+
const checker = new RequirementChecker(client, usedAddresses);
|
|
322
|
+
return await checker.checkRequirements({
|
|
323
|
+
address: accountToUse,
|
|
324
|
+
requiredGToken: 440000000000000000n, // 0.44 GT
|
|
325
|
+
requireSBT: false
|
|
326
|
+
});
|
|
327
|
+
},
|
|
328
|
+
async createSmartAccount({ owner, salt = 0n }) {
|
|
329
|
+
// Using Imported ABI
|
|
330
|
+
owner = validateAddress(owner, 'Owner');
|
|
331
|
+
let factoryAddress = usedAddresses.simpleAccountFactory;
|
|
332
|
+
if (!factoryAddress || factoryAddress === '0x0000000000000000000000000000000000000000') {
|
|
333
|
+
throw new AAStarError("SimpleAccountFactory not found", AAStarErrorType.CONFIGURATION_ERROR);
|
|
334
|
+
}
|
|
335
|
+
const accountAddress = await client.readContract({
|
|
336
|
+
address: factoryAddress,
|
|
337
|
+
abi: SimpleAccountFactoryABI,
|
|
338
|
+
functionName: 'getAddress',
|
|
339
|
+
args: [owner, salt]
|
|
340
|
+
});
|
|
341
|
+
const createAccountData = encodeFunctionData({
|
|
342
|
+
abi: SimpleAccountFactoryABI,
|
|
343
|
+
functionName: 'createAccount',
|
|
344
|
+
args: [owner, salt]
|
|
345
|
+
});
|
|
346
|
+
const initCode = concat([factoryAddress, createAccountData]);
|
|
347
|
+
const byteCode = await client.getBytecode({ address: accountAddress });
|
|
348
|
+
const isDeployed = byteCode !== undefined && byteCode !== '0x';
|
|
349
|
+
return { accountAddress, initCode, isDeployed };
|
|
350
|
+
},
|
|
351
|
+
async deploySmartAccount({ owner, salt = 0n, fundWithETH = 0n }) {
|
|
352
|
+
const { accountAddress, isDeployed } = await this.createSmartAccount({ owner, salt });
|
|
353
|
+
const { formatEther } = await import('viem');
|
|
354
|
+
let deployHash = '0x0';
|
|
355
|
+
if (isDeployed) {
|
|
356
|
+
console.log(` ℹ️ Account ${accountAddress} already deployed.`);
|
|
357
|
+
}
|
|
358
|
+
else {
|
|
359
|
+
let factoryAddress = usedAddresses.simpleAccountFactory;
|
|
360
|
+
console.log(` 🏭 Deploying Smart Account for ${owner}...`);
|
|
361
|
+
deployHash = await client.writeContract({
|
|
362
|
+
address: factoryAddress,
|
|
363
|
+
abi: SimpleAccountFactoryABI,
|
|
364
|
+
functionName: 'createAccount',
|
|
365
|
+
args: [owner, salt],
|
|
366
|
+
account,
|
|
367
|
+
chain
|
|
368
|
+
});
|
|
369
|
+
await client.waitForTransactionReceipt({ hash: deployHash });
|
|
370
|
+
console.log(` ✅ Deployed at ${accountAddress}`);
|
|
371
|
+
}
|
|
372
|
+
if (fundWithETH > 0n) {
|
|
373
|
+
const balance = await client.getBalance({ address: accountAddress });
|
|
374
|
+
if (balance < parseEther('0.01')) {
|
|
375
|
+
console.log(` ⛽ Funding account with ${formatEther(fundWithETH)} ETH...`);
|
|
376
|
+
const tx = await client.sendTransaction({
|
|
377
|
+
to: accountAddress,
|
|
378
|
+
value: fundWithETH,
|
|
379
|
+
account,
|
|
380
|
+
chain
|
|
381
|
+
});
|
|
382
|
+
await client.waitForTransactionReceipt({ hash: tx });
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
return { accountAddress, deployTxHash: deployHash, isDeployed: true };
|
|
386
|
+
}
|
|
387
|
+
});
|
|
388
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
import { describe, it, expect, vi } from 'vitest';
|
|
2
|
+
import { createEndUserClient } from './endUser.js';
|
|
3
|
+
import { mainnet } from 'viem/chains';
|
|
4
|
+
import { http, parseEther } from 'viem';
|
|
5
|
+
vi.mock('@aastar/core', async () => {
|
|
6
|
+
const actual = await vi.importActual('@aastar/core');
|
|
7
|
+
return {
|
|
8
|
+
...actual,
|
|
9
|
+
registryActions: vi.fn(() => vi.fn(() => ({
|
|
10
|
+
registryRegisterRoleSelf: vi.fn().mockResolvedValue('0xhash')
|
|
11
|
+
}))),
|
|
12
|
+
sbtActions: vi.fn(() => vi.fn(() => ({
|
|
13
|
+
sbtGetUserSBT: vi.fn().mockResolvedValue(123n)
|
|
14
|
+
}))),
|
|
15
|
+
superPaymasterActions: vi.fn(() => vi.fn(() => ({
|
|
16
|
+
superPaymasterGetAvailableCredit: vi.fn().mockResolvedValue(100n)
|
|
17
|
+
}))),
|
|
18
|
+
paymasterV4Actions: vi.fn(() => vi.fn(() => ({
|
|
19
|
+
// pmv4
|
|
20
|
+
}))),
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
describe('EndUserClient', () => {
|
|
24
|
+
const MOCK_ADDR = '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266';
|
|
25
|
+
const MOCK_COMMUNITY = '0x1111111111111111111111111111111111111111';
|
|
26
|
+
it('should create end user client', () => {
|
|
27
|
+
const client = createEndUserClient({ chain: mainnet, transport: http() });
|
|
28
|
+
expect(client.joinAndActivate).toBeDefined();
|
|
29
|
+
});
|
|
30
|
+
describe('joinAndActivate', () => {
|
|
31
|
+
it('should join community and fetch SBT', async () => {
|
|
32
|
+
const client = createEndUserClient({
|
|
33
|
+
chain: mainnet,
|
|
34
|
+
transport: http(),
|
|
35
|
+
account: { address: MOCK_ADDR }
|
|
36
|
+
});
|
|
37
|
+
client.readContract = vi.fn().mockResolvedValue('0x0000000000000000000000000000000000000000');
|
|
38
|
+
client.writeContract = vi.fn().mockResolvedValue('0xhash');
|
|
39
|
+
client.waitForTransactionReceipt = vi.fn().mockResolvedValue({ logs: [] });
|
|
40
|
+
const result = await client.joinAndActivate({ community: MOCK_COMMUNITY, roleId: '0x1' });
|
|
41
|
+
expect(result.sbtId).toBe(123n);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
describe('executeGasless', () => {
|
|
45
|
+
it('should execute gasless transaction', async () => {
|
|
46
|
+
const client = createEndUserClient({
|
|
47
|
+
chain: mainnet,
|
|
48
|
+
transport: http(),
|
|
49
|
+
account: { address: MOCK_ADDR, signMessage: vi.fn().mockResolvedValue('0xsignature') }
|
|
50
|
+
});
|
|
51
|
+
client.createSmartAccount = vi.fn().mockResolvedValue({ accountAddress: '0xaa', isDeployed: true });
|
|
52
|
+
client.readContract = vi.fn().mockResolvedValue(0n); // nonce or userOpHash
|
|
53
|
+
client.getBytecode = vi.fn().mockResolvedValue('0x123');
|
|
54
|
+
client.writeContract = vi.fn().mockResolvedValue('0xhash');
|
|
55
|
+
client.waitForTransactionReceipt = vi.fn().mockResolvedValue({ logs: [] });
|
|
56
|
+
const result = await client.executeGasless({
|
|
57
|
+
target: MOCK_COMMUNITY,
|
|
58
|
+
data: '0x',
|
|
59
|
+
operator: MOCK_COMMUNITY
|
|
60
|
+
});
|
|
61
|
+
expect(result.hash).toBe('0xhash');
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
describe('executeGaslessBatch', () => {
|
|
65
|
+
it('should execute gasless batch', async () => {
|
|
66
|
+
const client = createEndUserClient({
|
|
67
|
+
chain: mainnet,
|
|
68
|
+
transport: http(),
|
|
69
|
+
account: { address: MOCK_ADDR, signMessage: vi.fn().mockResolvedValue('0xsignature') }
|
|
70
|
+
});
|
|
71
|
+
client.createSmartAccount = vi.fn().mockResolvedValue({ accountAddress: '0xaa', isDeployed: true });
|
|
72
|
+
client.readContract = vi.fn().mockResolvedValue(0n);
|
|
73
|
+
client.getBytecode = vi.fn().mockResolvedValue('0x123');
|
|
74
|
+
client.writeContract = vi.fn().mockResolvedValue('0xhash');
|
|
75
|
+
client.waitForTransactionReceipt = vi.fn().mockResolvedValue({ logs: [] });
|
|
76
|
+
const result = await client.executeGaslessBatch({
|
|
77
|
+
targets: [MOCK_COMMUNITY],
|
|
78
|
+
datas: ['0x'],
|
|
79
|
+
operator: MOCK_COMMUNITY
|
|
80
|
+
});
|
|
81
|
+
expect(result.hash).toBe('0xhash');
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
describe('Requirements and Credits', () => {
|
|
85
|
+
it('should call onboard (alias for joinAndActivate)', async () => {
|
|
86
|
+
const client = createEndUserClient({
|
|
87
|
+
chain: mainnet,
|
|
88
|
+
transport: http(),
|
|
89
|
+
account: { address: MOCK_ADDR }
|
|
90
|
+
});
|
|
91
|
+
client.joinAndActivate = vi.fn().mockResolvedValue({ hash: '0xhash', events: [], sbtId: 1n });
|
|
92
|
+
const result = await client.onboard({ community: MOCK_COMMUNITY, roleId: '0x1', roleData: '0x' });
|
|
93
|
+
expect(result.sbtId).toBe(1n);
|
|
94
|
+
});
|
|
95
|
+
it('should check join requirements', async () => {
|
|
96
|
+
const client = createEndUserClient({ chain: mainnet, transport: http() });
|
|
97
|
+
// Mock balance return for GToken balance check >= 0.44 GT
|
|
98
|
+
client.readContract = vi.fn().mockResolvedValue(1000000000000000000n);
|
|
99
|
+
const result = await client.checkJoinRequirements(MOCK_ADDR);
|
|
100
|
+
expect(result.hasEnoughGToken).toBe(true);
|
|
101
|
+
});
|
|
102
|
+
it('should get available credit', async () => {
|
|
103
|
+
const client = createEndUserClient({ chain: mainnet, transport: http() });
|
|
104
|
+
// getAvailableCredit is part of SuperPaymasterActions which is extended in client
|
|
105
|
+
const credit = await client.superPaymasterGetAvailableCredit({ operator: MOCK_COMMUNITY, user: MOCK_ADDR });
|
|
106
|
+
expect(credit).toBe(100n);
|
|
107
|
+
});
|
|
108
|
+
});
|
|
109
|
+
describe('Smart Account Management', () => {
|
|
110
|
+
it('should create smart account with prediction', async () => {
|
|
111
|
+
const client = createEndUserClient({ chain: mainnet, transport: http() });
|
|
112
|
+
client.readContract = vi.fn().mockResolvedValue('0xAccountAddress');
|
|
113
|
+
client.getBytecode = vi.fn().mockResolvedValue(undefined);
|
|
114
|
+
const result = await client.createSmartAccount({ owner: MOCK_ADDR, salt: 123n });
|
|
115
|
+
expect(result.accountAddress).toBe('0xAccountAddress');
|
|
116
|
+
expect(result.isDeployed).toBe(false);
|
|
117
|
+
expect(result.initCode).toBeDefined();
|
|
118
|
+
});
|
|
119
|
+
it('should detect already deployed smart account', async () => {
|
|
120
|
+
const client = createEndUserClient({ chain: mainnet, transport: http() });
|
|
121
|
+
client.readContract = vi.fn().mockResolvedValue('0xDeployedAccount');
|
|
122
|
+
client.getBytecode = vi.fn().mockResolvedValue('0x123456');
|
|
123
|
+
const result = await client.createSmartAccount({ owner: MOCK_ADDR });
|
|
124
|
+
expect(result.isDeployed).toBe(true);
|
|
125
|
+
});
|
|
126
|
+
it('should throw error if factory not configured', async () => {
|
|
127
|
+
const client = createEndUserClient({ chain: mainnet, transport: http(), addresses: { simpleAccountFactory: '0x0000000000000000000000000000000000000000' } });
|
|
128
|
+
await expect(client.createSmartAccount({ owner: MOCK_ADDR }))
|
|
129
|
+
.rejects.toThrow('SimpleAccountFactory not found');
|
|
130
|
+
});
|
|
131
|
+
it('should deploy new smart account', async () => {
|
|
132
|
+
const client = createEndUserClient({
|
|
133
|
+
chain: mainnet,
|
|
134
|
+
transport: http(),
|
|
135
|
+
account: { address: MOCK_ADDR }
|
|
136
|
+
});
|
|
137
|
+
client.createSmartAccount = vi.fn().mockResolvedValue({ accountAddress: '0xNewAccount', isDeployed: false });
|
|
138
|
+
client.writeContract = vi.fn().mockResolvedValue('0xdeployhash');
|
|
139
|
+
client.waitForTransactionReceipt = vi.fn().mockResolvedValue({ logs: [] });
|
|
140
|
+
client.getBalance = vi.fn().mockResolvedValue(0n);
|
|
141
|
+
client.sendTransaction = vi.fn().mockResolvedValue('0xfundhash');
|
|
142
|
+
const result = await client.deploySmartAccount({ owner: MOCK_ADDR, fundWithETH: parseEther('0.1') });
|
|
143
|
+
expect(result.accountAddress).toBe('0xNewAccount');
|
|
144
|
+
expect(result.deployTxHash).toBe('0xdeployhash');
|
|
145
|
+
});
|
|
146
|
+
it('should skip deploy if already deployed', async () => {
|
|
147
|
+
const client = createEndUserClient({
|
|
148
|
+
chain: mainnet,
|
|
149
|
+
transport: http(),
|
|
150
|
+
account: { address: MOCK_ADDR }
|
|
151
|
+
});
|
|
152
|
+
client.createSmartAccount = vi.fn().mockResolvedValue({ accountAddress: '0xExisting', isDeployed: true });
|
|
153
|
+
client.getBalance = vi.fn().mockResolvedValue(parseEther('1'));
|
|
154
|
+
const result = await client.deploySmartAccount({ owner: MOCK_ADDR });
|
|
155
|
+
expect(result.accountAddress).toBe('0xExisting');
|
|
156
|
+
expect(result.deployTxHash).toBe('0x0');
|
|
157
|
+
});
|
|
158
|
+
it('should handle logic when smart account not deployed during batch', async () => {
|
|
159
|
+
const mockAccount = { address: MOCK_ADDR, signMessage: vi.fn().mockResolvedValue('0xsig') };
|
|
160
|
+
const client = createEndUserClient({ chain: mainnet, transport: http(), account: mockAccount });
|
|
161
|
+
// Mock getBytecode to return undefined/0x
|
|
162
|
+
client.getBytecode = vi.fn().mockResolvedValue('0x'); // Not deployed
|
|
163
|
+
client.createSmartAccount = vi.fn().mockResolvedValue({ initCode: '0x123' });
|
|
164
|
+
client.readContract = vi.fn().mockResolvedValue('0xhash');
|
|
165
|
+
client.writeContract = vi.fn().mockResolvedValue('0xhash');
|
|
166
|
+
client.waitForTransactionReceipt = vi.fn().mockResolvedValue({ logs: [] });
|
|
167
|
+
const results = await client.executeGaslessBatch({
|
|
168
|
+
targets: [MOCK_ADDR],
|
|
169
|
+
datas: ['0x'],
|
|
170
|
+
operator: MOCK_ADDR
|
|
171
|
+
});
|
|
172
|
+
expect(client.createSmartAccount).toHaveBeenCalled();
|
|
173
|
+
expect(results.hash).toBe('0xhash');
|
|
174
|
+
});
|
|
175
|
+
it('should handle execution errors in gasless batch', async () => {
|
|
176
|
+
const mockAccount = { address: MOCK_ADDR, signMessage: vi.fn().mockResolvedValue('0xsig') };
|
|
177
|
+
const client = createEndUserClient({ chain: mainnet, transport: http(), account: mockAccount });
|
|
178
|
+
client.getBytecode = vi.fn().mockResolvedValue('0xcode'); // deployed
|
|
179
|
+
client.readContract = vi.fn().mockResolvedValue('0xhash');
|
|
180
|
+
client.writeContract = vi.fn().mockRejectedValue(new Error('Contract Reverted'));
|
|
181
|
+
await expect(client.executeGaslessBatch({
|
|
182
|
+
targets: [MOCK_ADDR],
|
|
183
|
+
datas: ['0x'],
|
|
184
|
+
operator: MOCK_ADDR
|
|
185
|
+
})).rejects.toThrow('Contract Reverted');
|
|
186
|
+
});
|
|
187
|
+
});
|
|
188
|
+
});
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { type Client, type Transport, type Chain, type Account, type Hash, type Hex, type PublicActions, type WalletActions, type Address } from 'viem';
|
|
2
|
+
import { type StakingActions, type RegistryActions, type SuperPaymasterActions, type PaymasterV4Actions, type TokenActions } from '@aastar/core';
|
|
3
|
+
import { type DecodedEvent } from '../utils/eventDecoder.js';
|
|
4
|
+
export type OperatorClient = Client<Transport, Chain, Account | undefined> & PublicActions<Transport, Chain, Account | undefined> & WalletActions<Chain, Account | undefined> & RegistryActions & SuperPaymasterActions & PaymasterV4Actions & StakingActions & TokenActions & {
|
|
5
|
+
/**
|
|
6
|
+
* High-level API: Setup operator with automatic funding and onboarding
|
|
7
|
+
*/
|
|
8
|
+
setup: (args: {
|
|
9
|
+
stakeAmount: bigint;
|
|
10
|
+
depositAmount: bigint;
|
|
11
|
+
roleId: Hex;
|
|
12
|
+
roleData?: Hex;
|
|
13
|
+
}) => Promise<{
|
|
14
|
+
txs: {
|
|
15
|
+
hash: Hash;
|
|
16
|
+
events: DecodedEvent[];
|
|
17
|
+
}[];
|
|
18
|
+
}>;
|
|
19
|
+
deployPaymasterV4: (args?: {
|
|
20
|
+
version?: string;
|
|
21
|
+
initData?: Hex;
|
|
22
|
+
}) => Promise<Hash>;
|
|
23
|
+
/**
|
|
24
|
+
* Orchestrates the full onboarding flow:
|
|
25
|
+
* 1. Approve GToken (Stake)
|
|
26
|
+
* 2. Register Role (Stake Lock)
|
|
27
|
+
* 3. Approve aPNTs (Deposit)
|
|
28
|
+
* 4. Deposit aPNTs (SuperPaymaster)
|
|
29
|
+
*/
|
|
30
|
+
onboardFully: (args: {
|
|
31
|
+
stakeAmount: bigint;
|
|
32
|
+
depositAmount: bigint;
|
|
33
|
+
roleId: Hex;
|
|
34
|
+
roleData?: Hex;
|
|
35
|
+
gasTokens?: Address[];
|
|
36
|
+
}) => Promise<{
|
|
37
|
+
hash: Hash;
|
|
38
|
+
events: DecodedEvent[];
|
|
39
|
+
}[]>;
|
|
40
|
+
/** @deprecated Use onboardFully */
|
|
41
|
+
onboardOperator: (args: {
|
|
42
|
+
stakeAmount: bigint;
|
|
43
|
+
depositAmount: bigint;
|
|
44
|
+
roleId: Hex;
|
|
45
|
+
roleData?: Hex;
|
|
46
|
+
}) => Promise<{
|
|
47
|
+
hash: Hash;
|
|
48
|
+
events: DecodedEvent[];
|
|
49
|
+
}[]>;
|
|
50
|
+
configureOperator: (args: {
|
|
51
|
+
xPNTsToken: Address;
|
|
52
|
+
treasury: Address;
|
|
53
|
+
exchangeRate: bigint;
|
|
54
|
+
account?: Account | Address;
|
|
55
|
+
}) => Promise<Hash>;
|
|
56
|
+
/**
|
|
57
|
+
* 🧙 Wisdom: Check if operator is ready and compliant.
|
|
58
|
+
*/
|
|
59
|
+
checkReadiness: () => Promise<{
|
|
60
|
+
isRegistered: boolean;
|
|
61
|
+
isConfigured: boolean;
|
|
62
|
+
collateralBalance: bigint;
|
|
63
|
+
isPaused: boolean;
|
|
64
|
+
roleStatus: boolean;
|
|
65
|
+
}>;
|
|
66
|
+
getOperatorStatus: (accountAddress: Address) => Promise<{
|
|
67
|
+
type: 'super' | 'v4' | null;
|
|
68
|
+
superPaymaster: {
|
|
69
|
+
hasRole: boolean;
|
|
70
|
+
isConfigured: boolean;
|
|
71
|
+
balance: bigint;
|
|
72
|
+
exchangeRate: bigint;
|
|
73
|
+
treasury: Address;
|
|
74
|
+
} | null;
|
|
75
|
+
paymasterV4: {
|
|
76
|
+
address: Address;
|
|
77
|
+
balance: bigint;
|
|
78
|
+
} | null;
|
|
79
|
+
}>;
|
|
80
|
+
isOperator: (operator: Address) => Promise<boolean>;
|
|
81
|
+
getDepositDetails: () => Promise<{
|
|
82
|
+
deposit: bigint;
|
|
83
|
+
}>;
|
|
84
|
+
deposit: (args: {
|
|
85
|
+
amount: bigint;
|
|
86
|
+
account?: Account | Address;
|
|
87
|
+
}) => Promise<Hash>;
|
|
88
|
+
};
|
|
89
|
+
export declare function createOperatorClient({ chain, transport, account, addresses }: {
|
|
90
|
+
chain: Chain;
|
|
91
|
+
transport: Transport;
|
|
92
|
+
account?: Account;
|
|
93
|
+
addresses?: {
|
|
94
|
+
[key: string]: Address;
|
|
95
|
+
};
|
|
96
|
+
}): OperatorClient;
|