@aastar/sdk 0.16.11 → 0.16.12
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 -128
- package/dist/clients/ExperimentClient.d.ts +34 -0
- package/{packages/sdk/src/clients/ExperimentClient.ts → dist/clients/ExperimentClient.js} +11 -33
- package/dist/clients/ExperimentClient.test.d.ts +1 -0
- package/dist/clients/ExperimentClient.test.js +53 -0
- package/dist/clients/admin.d.ts +11 -0
- package/dist/clients/admin.js +20 -0
- package/dist/clients/admin.test.d.ts +1 -0
- package/dist/clients/admin.test.js +79 -0
- package/dist/clients/clients.test.d.ts +1 -0
- package/dist/clients/clients.test.js +91 -0
- package/dist/clients/community.d.ts +40 -0
- package/{packages/sdk/src/clients/community.ts → dist/clients/community.js} +86 -189
- package/dist/clients/community.test.d.ts +1 -0
- package/dist/clients/community.test.js +99 -0
- package/dist/clients/endUser.d.ts +77 -0
- package/dist/clients/endUser.js +298 -0
- package/dist/clients/endUser.test.d.ts +1 -0
- package/dist/clients/endUser.test.js +188 -0
- package/dist/clients/operator.d.ts +66 -0
- package/{packages/sdk/src/clients/operator.ts → dist/clients/operator.js} +66 -137
- package/dist/clients/operator.test.d.ts +1 -0
- package/dist/clients/operator.test.js +139 -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/xPNTsFactory.json +718 -0
- package/dist/core/src/abis/xPNTsToken.json +1280 -0
- package/dist/errors/AAStarError.d.ts +26 -0
- package/dist/errors/AAStarError.js +32 -0
- package/dist/errors/AAStarError.test.d.ts +1 -0
- package/dist/errors/AAStarError.test.js +74 -0
- package/dist/errors/decoder.d.ts +6 -0
- package/{packages/sdk/src/errors/decoder.ts → dist/errors/decoder.js} +15 -19
- package/dist/errors/decoder.test.d.ts +1 -0
- package/dist/errors/decoder.test.js +90 -0
- package/dist/index.d.ts +18 -0
- package/{packages/sdk/src/index.ts → dist/index.js} +0 -3
- package/dist/node/index.d.ts +7 -0
- package/dist/node/index.js +7 -0
- package/dist/types/result.d.ts +15 -0
- package/dist/types/result.js +23 -0
- package/dist/utils/errorHandler.d.ts +40 -0
- package/{packages/sdk/src/utils/errorHandler.ts → dist/utils/errorHandler.js} +22 -75
- package/dist/utils/errorHandler.test.d.ts +1 -0
- package/dist/utils/errorHandler.test.js +89 -0
- package/dist/utils/eventDecoder.d.ts +7 -0
- package/dist/utils/eventDecoder.js +54 -0
- package/dist/utils/eventDecoder.test.d.ts +1 -0
- package/dist/utils/eventDecoder.test.js +48 -0
- package/dist/utils/funding.d.ts +115 -0
- package/{packages/sdk/src/utils/funding.ts → dist/utils/funding.js} +27 -119
- package/dist/utils/funding.test.d.ts +1 -0
- package/dist/utils/funding.test.js +105 -0
- package/dist/utils/keys.d.ts +61 -0
- package/{packages/sdk/src/utils/keys.ts → dist/utils/keys.js} +15 -44
- package/dist/utils/keys.test.d.ts +1 -0
- package/dist/utils/keys.test.js +81 -0
- package/dist/utils/roleData.d.ts +66 -0
- package/{packages/sdk/src/utils/roleData.ts → dist/utils/roleData.js} +34 -57
- package/dist/utils/roleData.test.d.ts +1 -0
- package/dist/utils/roleData.test.js +74 -0
- package/dist/utils/testScenarios.d.ts +33 -0
- package/dist/utils/testScenarios.js +85 -0
- package/dist/utils/testScenarios.test.d.ts +1 -0
- package/dist/utils/testScenarios.test.js +68 -0
- package/dist/utils/userOp.d.ts +78 -0
- package/{packages/sdk/src/utils/userOp.ts → dist/utils/userOp.js} +59 -126
- package/dist/utils/userOp.test.d.ts +1 -0
- package/dist/utils/userOp.test.js +152 -0
- package/package.json +25 -61
- package/.github/workflows/gas-analytics-daily.yml +0 -52
- package/.gitmodules +0 -9
- package/CHANGELOG.md +0 -43
- package/aastar-sdk.code-workspace +0 -14
- package/abis/BLSAggregator.json +0 -572
- package/abis/BLSValidator.json +0 -39
- package/abis/DVTValidator.json +0 -383
- package/abis/Eip7702Support.json +0 -24
- package/abis/EntryPoint.json +0 -1379
- package/abis/GToken.json +0 -510
- package/abis/GTokenStaking.json +0 -918
- package/abis/LegacyAccount.json +0 -625
- package/abis/MySBT.json +0 -1547
- package/abis/Paymaster.json +0 -1192
- package/abis/PaymasterFactory.json +0 -637
- package/abis/PaymasterV4_2.json +0 -1193
- package/abis/Registry.json +0 -1677
- package/abis/ReputationSystem.json +0 -659
- 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 -1568
- package/abis/UserOperationLib.json +0 -57
- package/abis/aPNTs.json +0 -1160
- package/abis/xPNTsFactory.json +0 -715
- package/abis/xPNTsToken.json +0 -1160
- package/backup/run_sdk_regression.sh +0 -135
- 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/config.anvil.json +0 -1
- package/config.sepolia.json +0 -19
- package/config.test.json +0 -27
- 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/ABI_MAINTENANCE_PLAN.md +0 -132
- package/docs/API_REFERENCE.md +0 -796
- package/docs/Configuration_Sync.md +0 -47
- package/docs/DAO_Mining_Distribution_Plan.md +0 -522
- package/docs/DEMO_REFACTOR_PLAN.md +0 -289
- package/docs/DOCUMENTATION_PLAN.md +0 -455
- package/docs/ENV_SEPOLIA_UPDATE.md +0 -68
- package/docs/L2_BUSINESS_CLIENTS_PLAN.md +0 -394
- package/docs/L4_Manual_Test_CheatSheet.md +0 -172
- package/docs/Plan.md +0 -266
- package/docs/Regression_Testing_Guide.md +0 -70
- package/docs/Reputation-to-Credit_Mapping_Whitepaper.md +0 -242
- package/docs/SDK_ABI_COVERAGE.md +0 -839
- package/docs/SDK_COVERAGE_STRATEGY.md +0 -397
- package/docs/SDK_Optimization_Evaluation_Plan.md +0 -51
- package/docs/SDK_REGRESSION_AND_API_PLAN.md +0 -98
- package/docs/SDK_STAGE3_PLAN.md +0 -151
- package/docs/SEPOLIA_ENV_REFERENCE.md +0 -51
- package/docs/STAGE3.md +0 -191
- package/docs/Script_Comparison_Report.md +0 -91
- package/docs/Sepolia_Latest_Deployment.md +0 -117
- package/docs/TESTER_GUIDE_GASLESS.md +0 -409
- 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/Verifier_L4_Gasless_Plan.md +0 -454
- 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 -211
- package/docs/api/@aastar/core/classes/BLSSigner.md +0 -147
- package/docs/api/@aastar/core/classes/BaseClient.md +0 -9657
- package/docs/api/@aastar/core/classes/ContractConfigManager.md +0 -25
- package/docs/api/@aastar/core/classes/RequirementChecker.md +0 -1837
- package/docs/api/@aastar/core/classes/SepoliaFaucetAPI.md +0 -13661
- package/docs/api/@aastar/core/classes/StateValidator.md +0 -133
- package/docs/api/@aastar/core/enumerations/EntryPointVersion.md +0 -17
- package/docs/api/@aastar/core/enumerations/NodeType.md +0 -33
- package/docs/api/@aastar/core/enumerations/RolePermissionLevel.md +0 -43
- package/docs/api/@aastar/core/functions/accountActions.md +0 -2720
- package/docs/api/@aastar/core/functions/accountFactoryActions.md +0 -2720
- package/docs/api/@aastar/core/functions/aggregatorActions.md +0 -2720
- package/docs/api/@aastar/core/functions/createAAStarPublicClient.md +0 -3105
- package/docs/api/@aastar/core/functions/dvtActions.md +0 -2720
- package/docs/api/@aastar/core/functions/entryPointActions.md +0 -2724
- package/docs/api/@aastar/core/functions/gTokenActions.md +0 -2714
- package/docs/api/@aastar/core/functions/gTokenExtendedActions.md +0 -2720
- 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 -194
- package/docs/api/@aastar/core/functions/getCoreContracts.md +0 -71
- 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/getRoleName.md +0 -15
- 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/paymasterActions.md +0 -2720
- package/docs/api/@aastar/core/functions/paymasterFactoryActions.md +0 -2720
- 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/functions/xPNTsFactoryActions.md +0 -2720
- package/docs/api/@aastar/core/interfaces/AccountBalance.md +0 -41
- package/docs/api/@aastar/core/interfaces/BalanceValidationParams.md +0 -51
- package/docs/api/@aastar/core/interfaces/ClientConfig.md +0 -4841
- 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/interfaces/DeploymentValidationParams.md +0 -39
- package/docs/api/@aastar/core/interfaces/RoleConfig.md +0 -83
- package/docs/api/@aastar/core/interfaces/RoleRequirement.md +0 -43
- package/docs/api/@aastar/core/interfaces/RoleValidationParams.md +0 -55
- package/docs/api/@aastar/core/interfaces/SuperPaymasterConfig.md +0 -57
- package/docs/api/@aastar/core/interfaces/TokenBalanceValidationParams.md +0 -63
- package/docs/api/@aastar/core/interfaces/TransactionOptions.md +0 -24
- package/docs/api/@aastar/core/interfaces/ValidationParams.md +0 -25
- package/docs/api/@aastar/core/interfaces/ValidationResult.md +0 -25
- package/docs/api/@aastar/core/type-aliases/AccountActions.md +0 -151
- package/docs/api/@aastar/core/type-aliases/AccountFactoryActions.md +0 -55
- package/docs/api/@aastar/core/type-aliases/AggregatorActions.md +0 -471
- package/docs/api/@aastar/core/type-aliases/BusinessResult.md +0 -12
- 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 -319
- package/docs/api/@aastar/core/type-aliases/EntryPointActions.md +0 -103
- package/docs/api/@aastar/core/type-aliases/GTokenExtendedActions.md +0 -239
- package/docs/api/@aastar/core/type-aliases/NetworkContracts.md +0 -5
- package/docs/api/@aastar/core/type-aliases/PaymasterActions.md +0 -1087
- package/docs/api/@aastar/core/type-aliases/PaymasterFactoryActions.md +0 -263
- package/docs/api/@aastar/core/type-aliases/RegistryActions.md +0 -1543
- package/docs/api/@aastar/core/type-aliases/ReputationActions.md +0 -811
- package/docs/api/@aastar/core/type-aliases/SBTActions.md +0 -1199
- package/docs/api/@aastar/core/type-aliases/StakingActions.md +0 -703
- package/docs/api/@aastar/core/type-aliases/SuperPaymasterActions.md +0 -1311
- package/docs/api/@aastar/core/type-aliases/SupportedNetwork.md +0 -3
- package/docs/api/@aastar/core/type-aliases/TokenActions.md +0 -1227
- package/docs/api/@aastar/core/type-aliases/XPNTsFactoryActions.md +0 -395
- package/docs/api/@aastar/core/variables/AASTAR_COMMUNITY.md +0 -8
- package/docs/api/@aastar/core/variables/ALL_ADDRESSES.md +0 -75
- package/docs/api/@aastar/core/variables/ALL_ROLES.md +0 -5
- package/docs/api/@aastar/core/variables/APNTS_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/BLSAggregatorABI.md +0 -3
- package/docs/api/@aastar/core/variables/BLSAggregatorArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/BLSHelpers.md +0 -101
- package/docs/api/@aastar/core/variables/BLSValidatorABI.md +0 -3
- package/docs/api/@aastar/core/variables/BLSValidatorArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/BLS_AGGREGATOR_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/BLS_VALIDATOR_ADDRESS.md +0 -3
- 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/CHAIN_MAINNET.md +0 -3
- package/docs/api/@aastar/core/variables/CHAIN_SEPOLIA.md +0 -5
- 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 -179
- package/docs/api/@aastar/core/variables/CONTRACT_METADATA.md +0 -67
- package/docs/api/@aastar/core/variables/CONTRACT_SRC_HASH.md +0 -5
- package/docs/api/@aastar/core/variables/CORE_ADDRESSES.md +0 -51
- package/docs/api/@aastar/core/variables/DEFAULT_ADMIN_ROLE.md +0 -17
- package/docs/api/@aastar/core/variables/DEFAULT_APNTS_PRICE_USD.md +0 -5
- package/docs/api/@aastar/core/variables/DEFAULT_CALL_GAS_LIMIT.md +0 -3
- package/docs/api/@aastar/core/variables/DEFAULT_GAS_TOKEN_MINT_AMOUNT.md +0 -5
- package/docs/api/@aastar/core/variables/DEFAULT_PRE_VERIFICATION_GAS.md +0 -3
- package/docs/api/@aastar/core/variables/DEFAULT_TIMEOUT_MS.md +0 -5
- package/docs/api/@aastar/core/variables/DEFAULT_TOKEN_NAME.md +0 -3
- package/docs/api/@aastar/core/variables/DEFAULT_TOKEN_SYMBOL.md +0 -5
- package/docs/api/@aastar/core/variables/DEFAULT_USDT_MINT_AMOUNT.md +0 -5
- package/docs/api/@aastar/core/variables/DEFAULT_VERIFICATION_GAS_LIMIT.md +0 -5
- package/docs/api/@aastar/core/variables/DVTValidatorABI.md +0 -3
- package/docs/api/@aastar/core/variables/DVTValidatorArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/DVT_VALIDATOR_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/ENTRY_POINT_0_8_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/ENTRY_POINT_0_9_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/ENTRY_POINT_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/EntryPointABI.md +0 -3
- package/docs/api/@aastar/core/variables/EntryPointArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/FAUCET_API_URL.md +0 -5
- package/docs/api/@aastar/core/variables/GTOKEN_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/GTOKEN_STAKING_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/GTokenABI.md +0 -3
- package/docs/api/@aastar/core/variables/GTokenArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/GTokenStakingABI.md +0 -3
- package/docs/api/@aastar/core/variables/GTokenStakingArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/INITIAL_ROLE_STAKES.md +0 -13
- 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/MySBTArtifact.md +0 -13
- 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/PAYMASTER_FACTORY_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/PAYMASTER_V4_IMPL_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/PaymasterABI.md +0 -3
- package/docs/api/@aastar/core/variables/PaymasterArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/PaymasterFactoryABI.md +0 -3
- package/docs/api/@aastar/core/variables/PaymasterFactoryArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/PaymasterV4ABI.md +0 -3
- package/docs/api/@aastar/core/variables/PaymasterV4Artifact.md +0 -13
- package/docs/api/@aastar/core/variables/REGISTRY_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/REPUTATION_SYSTEM_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/ROLE_ANODE.md +0 -29
- package/docs/api/@aastar/core/variables/ROLE_COMMUNITY.md +0 -29
- package/docs/api/@aastar/core/variables/ROLE_DVT.md +0 -29
- package/docs/api/@aastar/core/variables/ROLE_ENDUSER.md +0 -33
- package/docs/api/@aastar/core/variables/ROLE_KMS.md +0 -29
- package/docs/api/@aastar/core/variables/ROLE_NAMES.md +0 -3
- package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_AOA.md +0 -29
- package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_SUPER.md +0 -33
- package/docs/api/@aastar/core/variables/ROLE_PERMISSION_LEVELS.md +0 -3
- package/docs/api/@aastar/core/variables/RegistryABI.md +0 -3
- package/docs/api/@aastar/core/variables/RegistryArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/ReputationSystemABI.md +0 -3
- package/docs/api/@aastar/core/variables/ReputationSystemArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/SBT_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/SEPOLIA_CONTRACTS.md +0 -175
- 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/SUPER_PAYMASTER_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/SimpleAccountABI.md +0 -3
- package/docs/api/@aastar/core/variables/SimpleAccountArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/SimpleAccountFactoryABI.md +0 -3
- package/docs/api/@aastar/core/variables/SimpleAccountFactoryArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/SuperPaymasterABI.md +0 -3
- package/docs/api/@aastar/core/variables/SuperPaymasterArtifact.md +0 -13
- 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/XPNTS_FACTORY_ADDRESS.md +0 -3
- package/docs/api/@aastar/core/variables/xPNTsFactoryABI.md +0 -3
- package/docs/api/@aastar/core/variables/xPNTsFactoryArtifact.md +0 -13
- package/docs/api/@aastar/core/variables/xPNTsTokenABI.md +0 -3
- package/docs/api/@aastar/core/variables/xPNTsTokenArtifact.md +0 -13
- package/docs/api/@aastar/paymaster/README.md +0 -23
- package/docs/api/@aastar/paymaster/classes/PaymasterClient.md +0 -388
- package/docs/api/@aastar/paymaster/classes/PaymasterOperator.md +0 -451
- package/docs/api/@aastar/paymaster/classes/SuperPaymasterAdminClient.md +0 -189
- package/docs/api/@aastar/paymaster/classes/SuperPaymasterClient.md +0 -55
- package/docs/api/@aastar/paymaster/functions/buildPaymasterData.md +0 -34
- package/docs/api/@aastar/paymaster/functions/buildSuperPaymasterData.md +0 -30
- package/docs/api/@aastar/paymaster/functions/checkEligibility.md +0 -28
- package/docs/api/@aastar/paymaster/functions/formatUserOpV07.md +0 -15
- 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/functions/getUserOpHashV07.md +0 -21
- package/docs/api/@aastar/paymaster/type-aliases/GaslessReadinessReport.md +0 -55
- package/docs/api/@aastar/paymaster/type-aliases/GaslessTransactionConfig.md +0 -59
- package/docs/api/@aastar/paymaster/type-aliases/PaymasterConfig.md +0 -43
- 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 -10385
- 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/env.template +0 -30
- package/examples/l1-api-demo.ts +0 -273
- package/examples/l2-clients-demo.ts +0 -135
- package/examples/l3-community-launch.ts +0 -49
- package/examples/l3-user-onboarding.ts +0 -56
- package/examples/prepare-gasless.ts +0 -89
- 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/examples/simple-gasless-demo.ts +0 -109
- package/examples/simple-superpaymaster-demo.ts +0 -96
- 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/src/networks.ts +0 -117
- 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/l4-setup.sh +0 -1
- 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/__tests__/index.test.ts +0 -9
- package/packages/account/node_modules/.bin/tsc +0 -21
- package/packages/account/node_modules/.bin/tsserver +0 -21
- package/packages/account/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/account/package.json +0 -21
- package/packages/account/src/accounts/simple.ts +0 -84
- 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/README.md +0 -68
- package/packages/analytics/__tests__/index.test.ts +0 -25
- package/packages/analytics/data/attribution_dataset.csv +0 -29
- package/packages/analytics/data/complete_dataset.csv +0 -29
- package/packages/analytics/data/eth_price_cache.json +0 -4
- package/packages/analytics/data/full_dataset.csv +0 -11
- package/packages/analytics/data/full_dataset.json +0 -134
- package/packages/analytics/data/parsed_transactions.csv +0 -29
- package/packages/analytics/node_modules/.bin/tsc +0 -21
- package/packages/analytics/node_modules/.bin/tsserver +0 -21
- package/packages/analytics/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/analytics/package.json +0 -25
- package/packages/analytics/reports/full/attribution_analysis_20260119.md +0 -42
- package/packages/analytics/reports/full/attribution_analysis_fresh_20260119.md +0 -67
- package/packages/analytics/reports/full/competitive_analysis_20260119.md +0 -103
- package/packages/analytics/reports/full/comprehensive_analysis_20260119.md +0 -107
- package/packages/analytics/reports/full/comprehensive_analysis_v4_1_20260119.md +0 -74
- package/packages/analytics/reports/full/economic_audit_v4_2_20260119.md +0 -74
- package/packages/analytics/reports/full/profit_audit_v4_3_20260119.md +0 -74
- package/packages/analytics/reports/full/profit_audit_v4_4_20260119.md +0 -74
- package/packages/analytics/reports/full/profit_audit_v4_5_20260119.md +0 -74
- package/packages/analytics/reports/full/profit_audit_v4_6_20260119.md +0 -74
- package/packages/analytics/reports/full/profit_audit_v4_final_20260119.md +0 -74
- package/packages/analytics/reports/full/profit_audit_v4_final_v2_20260119.md +0 -74
- package/packages/analytics/reports/full/profit_audit_v4_final_v3_20260119.md +0 -74
- package/packages/analytics/reports/full/profit_audit_v4_final_v4_20260119.md +0 -75
- package/packages/analytics/reports/full/profit_audit_v4_final_v5_20260119.md +0 -76
- package/packages/analytics/reports/full/two_layer_analysis_20260119.md +0 -81
- package/packages/analytics/reports/full/two_layer_analysis_academic_20260119.md +0 -81
- package/packages/analytics/reports/full/two_layer_analysis_dynamic_20260119.md +0 -81
- package/packages/analytics/reports/full/two_layer_analysis_final_20260119.md +0 -81
- package/packages/analytics/reports/full/two_layer_analysis_final_fixed_20260119.md +0 -81
- package/packages/analytics/reports/full/two_layer_analysis_fixed_20260119.md +0 -52
- package/packages/analytics/reports/full/two_layer_analysis_normalized_20260119.md +0 -81
- package/packages/analytics/reports/full/tx_0xc30cfcbb.md +0 -39
- package/packages/analytics/src/analyzers/AttributionAnalyzer.ts +0 -124
- package/packages/analytics/src/analyzers/ComparisonAnalyzer.ts +0 -89
- package/packages/analytics/src/analyzers/TransactionAnalyzer.ts +0 -111
- package/packages/analytics/src/analyzers/TrendAnalyzer.ts +0 -107
- package/packages/analytics/src/cli-analyze-tx.ts +0 -45
- package/packages/analytics/src/cli.ts +0 -39
- package/packages/analytics/src/core/BenchmarkLoader.ts +0 -163
- package/packages/analytics/src/core/CostCalculator.ts +0 -202
- package/packages/analytics/src/core/DataCollector.ts +0 -245
- package/packages/analytics/src/gas-analyzer-v4.ts +0 -118
- package/packages/analytics/src/gas-analyzer.ts +0 -184
- package/packages/analytics/src/index.ts +0 -145
- package/packages/analytics/src/test-logparser.ts +0 -63
- package/packages/analytics/src/utils/EventDecoder.ts +0 -152
- package/packages/analytics/src/utils/LogParser.ts +0 -220
- package/packages/analytics/src/utils/PriceOracle.ts +0 -117
- package/packages/analytics/test/AttributionAnalyzer.test.ts +0 -42
- package/packages/analytics/test/CostCalculator.test.ts +0 -75
- package/packages/analytics/tsconfig.json +0 -12
- package/packages/community/__tests__/index.test.ts +0 -9
- package/packages/community/node_modules/.bin/tsc +0 -21
- package/packages/community/node_modules/.bin/tsserver +0 -21
- package/packages/community/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/community/package.json +0 -27
- package/packages/community/src/index.ts +0 -326
- package/packages/community/tsconfig.json +0 -8
- package/packages/core/__tests__/actions/account-comprehensive.test.ts +0 -92
- package/packages/core/__tests__/actions/aggregator.test.ts +0 -62
- package/packages/core/__tests__/actions/comprehensive-batch1.test.ts +0 -86
- package/packages/core/__tests__/actions/comprehensive-batch2.test.ts +0 -39
- package/packages/core/__tests__/actions/comprehensive-batch3.test.ts +0 -35
- package/packages/core/__tests__/actions/comprehensive-error.test.ts +0 -115
- package/packages/core/__tests__/actions/dvt.test.ts +0 -39
- package/packages/core/__tests__/actions/edge-cases.test.ts +0 -39
- package/packages/core/__tests__/actions/error-paths.test.ts +0 -82
- package/packages/core/__tests__/actions/factory.test.ts +0 -81
- package/packages/core/__tests__/actions/faucet.test.ts +0 -131
- package/packages/core/__tests__/actions/paymaster.test.ts +0 -116
- package/packages/core/__tests__/actions/registry.test.ts +0 -81
- package/packages/core/__tests__/actions/reputation.test.ts +0 -43
- package/packages/core/__tests__/actions/sbt.test.ts +0 -145
- package/packages/core/__tests__/actions/staking.test.ts +0 -30
- package/packages/core/__tests__/actions/superPaymaster.test.ts +0 -158
- package/packages/core/__tests__/actions/tokens-extended.test.ts +0 -18
- package/packages/core/__tests__/actions/tokens.test.ts +0 -122
- package/packages/core/__tests__/clients.test.ts +0 -77
- package/packages/core/__tests__/contracts-config.test.ts +0 -69
- package/packages/core/__tests__/index.test.ts +0 -9
- package/packages/core/__tests__/mocks/client.ts +0 -40
- package/packages/core/node_modules/.bin/tsc +0 -21
- package/packages/core/node_modules/.bin/tsserver +0 -21
- package/packages/core/node_modules/.bin/tsx +0 -21
- package/packages/core/node_modules/.bin/vite +0 -21
- package/packages/core/node_modules/.bin/vitest +0 -21
- package/packages/core/node_modules/.bin/yaml +0 -21
- package/packages/core/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/core/package.json +0 -25
- package/packages/core/src/abis/BLSAggregator.json +0 -686
- package/packages/core/src/abis/BLSValidator.json +0 -42
- package/packages/core/src/abis/DVTValidator.json +0 -368
- package/packages/core/src/abis/Eip7702Support.json +0 -24
- package/packages/core/src/abis/EntryPoint.json +0 -1382
- package/packages/core/src/abis/GToken.json +0 -513
- package/packages/core/src/abis/GTokenStaking.json +0 -949
- package/packages/core/src/abis/LegacyAccount.json +0 -625
- package/packages/core/src/abis/MySBT.json +0 -1518
- package/packages/core/src/abis/Paymaster.json +0 -1143
- package/packages/core/src/abis/PaymasterFactory.json +0 -640
- package/packages/core/src/abis/Registry.json +0 -1942
- package/packages/core/src/abis/ReputationSystem.json +0 -699
- 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 -560
- package/packages/core/src/abis/SimpleAccountFactory.json +0 -111
- 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 -1781
- package/packages/core/src/abis/UserOperationLib.json +0 -57
- package/packages/core/src/abis/aPNTs.json +0 -1160
- package/packages/core/src/abis/abi.config.json +0 -24
- package/packages/core/src/abis/index.ts +0 -91
- package/packages/core/src/abis/xPNTsFactory.json +0 -718
- package/packages/core/src/abis/xPNTsToken.json +0 -1280
- package/packages/core/src/actions/StateValidator.ts +0 -253
- package/packages/core/src/actions/account.ts +0 -190
- package/packages/core/src/actions/aggregator.ts +0 -371
- package/packages/core/src/actions/dvt.ts +0 -269
- package/packages/core/src/actions/entryPoint.ts +0 -89
- package/packages/core/src/actions/factory.ts +0 -732
- package/packages/core/src/actions/faucet.ts +0 -280
- package/packages/core/src/actions/index.ts +0 -15
- package/packages/core/src/actions/paymaster.ts +0 -780
- package/packages/core/src/actions/registry.ts +0 -961
- package/packages/core/src/actions/reputation.ts +0 -668
- package/packages/core/src/actions/sbt.ts +0 -916
- package/packages/core/src/actions/staking.ts +0 -576
- package/packages/core/src/actions/superPaymaster.ts +0 -1093
- package/packages/core/src/actions/tokens.ts +0 -481
- package/packages/core/src/branding.ts +0 -32
- package/packages/core/src/clients/BaseClient.ts +0 -78
- package/packages/core/src/clients/BundlerClient.ts +0 -132
- package/packages/core/src/clients/types.ts +0 -69
- package/packages/core/src/clients.ts +0 -13
- package/packages/core/src/communities.ts +0 -93
- package/packages/core/src/config/ContractConfigManager.ts +0 -63
- package/packages/core/src/constants.ts +0 -114
- package/packages/core/src/contract-addresses.ts +0 -118
- package/packages/core/src/contract-versions.ts +0 -374
- package/packages/core/src/contracts.ts +0 -414
- package/packages/core/src/crypto/blsSigner.ts +0 -124
- package/packages/core/src/crypto/index.ts +0 -1
- package/packages/core/src/errors/index.ts +0 -173
- package/packages/core/src/index.ts +0 -23
- package/packages/core/src/networks.ts +0 -127
- package/packages/core/src/requirementChecker.ts +0 -225
- package/packages/core/src/roles.ts +0 -244
- package/packages/core/src/utils.ts +0 -23
- package/packages/core/src/validators/index.ts +0 -88
- package/packages/core/tsconfig.json +0 -13
- package/packages/dapp/__tests__/index.test.ts +0 -9
- package/packages/dapp/node_modules/.bin/tsc +0 -21
- package/packages/dapp/node_modules/.bin/tsserver +0 -21
- package/packages/dapp/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/dapp/package.json +0 -28
- package/packages/dapp/src/index.ts +0 -4
- package/packages/dapp/src/ui/components/EvaluationPanel.tsx +0 -40
- package/packages/dapp/src/ui/hooks/useCreditScore.ts +0 -44
- package/packages/dapp/src/ui/hooks/useSuperPaymaster.ts +0 -31
- package/packages/dapp/src/ui/index.ts +0 -22
- package/packages/dapp/tsconfig.json +0 -13
- package/packages/enduser/__tests__/CommunityClient.test.ts +0 -205
- package/packages/enduser/__tests__/UserClient.test.ts +0 -294
- package/packages/enduser/__tests__/index.test.ts +0 -16
- package/packages/enduser/__tests__/mocks/client.ts +0 -22
- package/packages/enduser/node_modules/.bin/tsc +0 -21
- package/packages/enduser/node_modules/.bin/tsserver +0 -21
- package/packages/enduser/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/enduser/package.json +0 -26
- package/packages/enduser/src/CommunityClient.ts +0 -235
- package/packages/enduser/src/UserClient.ts +0 -447
- package/packages/enduser/src/index.ts +0 -2
- package/packages/enduser/src/testAccountManager.ts +0 -374
- package/packages/enduser/tsconfig.json +0 -10
- package/packages/identity/__tests__/index.test.ts +0 -9
- package/packages/identity/node_modules/.bin/tsc +0 -21
- package/packages/identity/node_modules/.bin/tsserver +0 -21
- package/packages/identity/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/identity/package.json +0 -23
- package/packages/identity/src/index.ts +0 -114
- package/packages/identity/src/mysbt.ts +0 -48
- package/packages/identity/tsconfig.json +0 -12
- package/packages/operator/__tests__/PaymasterOperatorClient.test.ts +0 -258
- package/packages/operator/__tests__/ProtocolClient.test.ts +0 -135
- package/packages/operator/__tests__/index.test.ts +0 -16
- package/packages/operator/__tests__/mocks/client.ts +0 -22
- package/packages/operator/node_modules/.bin/tsc +0 -21
- package/packages/operator/node_modules/.bin/tsserver +0 -21
- package/packages/operator/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/operator/package.json +0 -26
- package/packages/operator/src/PaymasterOperatorClient.ts +0 -454
- package/packages/operator/src/ProtocolClient.ts +0 -154
- package/packages/operator/src/index.ts +0 -2
- package/packages/operator/tsconfig.json +0 -10
- package/packages/patterns/node_modules/.bin/tsc +0 -21
- package/packages/patterns/node_modules/.bin/tsserver +0 -21
- package/packages/paymaster/__tests__/PaymasterOperator.test.ts +0 -123
- package/packages/paymaster/__tests__/index.test.ts +0 -9
- package/packages/paymaster/node_modules/.bin/tsc +0 -21
- package/packages/paymaster/node_modules/.bin/tsserver +0 -21
- package/packages/paymaster/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/paymaster/package.json +0 -23
- package/packages/paymaster/src/SuperPaymaster/index.ts +0 -168
- package/packages/paymaster/src/V4/BundlerCompat.ts +0 -47
- package/packages/paymaster/src/V4/PaymasterClient.ts +0 -490
- package/packages/paymaster/src/V4/PaymasterOperator.ts +0 -282
- package/packages/paymaster/src/V4/PaymasterUtils.ts +0 -199
- package/packages/paymaster/src/V4/SuperPaymasterClient.ts +0 -129
- package/packages/paymaster/src/V4/index.ts +0 -4
- package/packages/paymaster/src/index.ts +0 -5
- package/packages/paymaster/tsconfig.json +0 -16
- package/packages/sdk/README.md +0 -171
- package/packages/sdk/__tests__/index.test.ts +0 -9
- 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/examples/config.json +0 -1
- package/packages/sdk/examples/regression_test.ts +0 -106
- package/packages/sdk/node_modules/.bin/tsc +0 -21
- package/packages/sdk/node_modules/.bin/tsserver +0 -21
- package/packages/sdk/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/sdk/package.json +0 -34
- package/packages/sdk/src/clients/admin.ts +0 -56
- package/packages/sdk/src/clients/endUser.ts +0 -428
- package/packages/sdk/src/utils/testScenarios.ts +0 -128
- package/packages/sdk/tests/scenarios/01_onboard_community.ts +0 -62
- package/packages/sdk/tests/scenarios/02_onboard_operator.ts +0 -109
- package/packages/sdk/tests/scenarios/03_onboard_user.ts +0 -53
- package/packages/sdk/tests/scenarios/04_gasless_tx_flow.ts +0 -68
- package/packages/sdk/tests/scenarios/check_entrypoint.ts +0 -19
- package/packages/sdk/tests/scenarios/check_initialization.ts +0 -65
- package/packages/sdk/tests/scenarios/debug_addresses.ts +0 -26
- package/packages/sdk/tests/scenarios/diagnose_scenario4.ts +0 -55
- package/packages/sdk/tests/scenarios/setup.ts +0 -33
- package/packages/sdk/tests/scenarios/test_entrypoint_nonce.ts +0 -46
- package/packages/sdk/tsconfig.json +0 -12
- package/packages/tokens/__tests__/index.test.ts +0 -9
- package/packages/tokens/node_modules/.bin/tsc +0 -21
- package/packages/tokens/node_modules/.bin/tsserver +0 -21
- package/packages/tokens/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +0 -1
- package/packages/tokens/package.json +0 -23
- package/packages/tokens/src/index.ts +0 -258
- package/packages/tokens/tsconfig.json +0 -12
- package/pnpm-workspace.yaml +0 -2
- package/publish.sh +0 -30
- package/run_l4_gasless_regression.sh +0 -109
- package/run_sdk_regression.sh +0 -232
- 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 -385
- 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 -148
- package/scripts/15_test_dvt_bls_full.ts +0 -140
- 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 -207
- 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 -99
- package/scripts/analyze_abi_coverage.ts +0 -169
- package/scripts/analyze_missing_functions.ts +0 -136
- package/scripts/canary-bundler.ts +0 -47
- package/scripts/check-admin.ts +0 -95
- package/scripts/check-chainlink.ts +0 -28
- package/scripts/check-jason-status.ts +0 -85
- package/scripts/check-roles.ts +0 -36
- package/scripts/clear-nonce.ts +0 -47
- package/scripts/collect_industry_baseline.ts +0 -236
- package/scripts/complete-jack-superpaymaster.ts +0 -171
- package/scripts/complete_env_config.ts +0 -97
- package/scripts/deploy-sync.ts +0 -104
- package/scripts/deploy_and_init_v3.sh +0 -134
- package/scripts/deploy_anvil_accounts.ts +0 -144
- package/scripts/deploy_jason_pm.ts +0 -114
- package/scripts/deploy_paymaster_v4.ts +0 -139
- package/scripts/deploy_test_accounts.ts +0 -401
- package/scripts/deprecated/check_aa_entrypoint.ts +0 -29
- package/scripts/deprecated/check_paymaster_deposits.ts +0 -45
- package/scripts/deprecated/debug_aoa_function.ts +0 -28
- package/scripts/deprecated/debug_aoa_issue.ts +0 -16
- package/scripts/deprecated/debug_pimlico_aa23.ts +0 -40
- package/scripts/deprecated/debug_summary.ts +0 -34
- package/scripts/deprecated/deploy_v07_aa.ts +0 -99
- package/scripts/deprecated/fix_all_issues.ts +0 -61
- package/scripts/deprecated/fund_bpnts.ts +0 -52
- package/scripts/deprecated/get_factory_addresses.ts +0 -28
- package/scripts/deprecated/recheck_pim.ts +0 -34
- package/scripts/dev_tools/extract_abis.sh +0 -151
- package/scripts/dev_tools/extract_addresses_to_env.sh +0 -67
- package/scripts/dev_tools/final_safe_harmonize.py +0 -77
- package/scripts/dev_tools/safe_harmonize.py +0 -107
- package/scripts/dev_tools/surgical_harmonize.py +0 -83
- 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/fund-jack.ts +0 -38
- package/scripts/generate_env_from_deployment.ts +0 -109
- package/scripts/inspect-anni-token.ts +0 -116
- package/scripts/inspect-factory.ts +0 -83
- package/scripts/l4-debug-bob.ts +0 -62
- package/scripts/l4-paymasterv4-transfer-test.ts +0 -220
- package/scripts/l4-setup.ts +0 -1347
- package/scripts/l4-state.json +0 -82
- package/scripts/manual-update-price.ts +0 -39
- package/scripts/phase1_verify_contracts.ts +0 -207
- package/scripts/pre_test_sync.ts +0 -83
- package/scripts/prepare_sepolia_resources.ts +0 -154
- package/scripts/publish_all.sh +0 -39
- package/scripts/query-jack-token.ts +0 -22
- package/scripts/quick_setup.ts +0 -124
- package/scripts/quick_setup_account.ts +0 -80
- package/scripts/run_automated_experiment.sh +0 -121
- package/scripts/run_daily_experiment.ts +0 -70
- package/scripts/run_full_regression.sh +0 -38
- package/scripts/run_l4_gasless_regression.sh +0 -32
- package/scripts/run_sdk_experiment.sh +0 -13
- package/scripts/run_sdk_regression-v2.sh +0 -38
- package/scripts/sdk_regression_v2.ts +0 -148
- package/scripts/security_audit.sh +0 -172
- package/scripts/setup-bbq-community.ts +0 -187
- package/scripts/setup-dancing-community.ts +0 -223
- package/scripts/setup_test_accounts.ts +0 -88
- package/scripts/setup_test_environment.ts +0 -147
- package/scripts/sync_anvil_config.cjs +0 -44
- package/scripts/sync_config_to_env.ts +0 -88
- package/scripts/sync_contract_addresses.ts +0 -186
- package/scripts/sync_sepolia_config.cjs +0 -90
- package/scripts/sync_sepolia_config.mjs +0 -74
- package/scripts/test-brown-v4-deploy.ts +0 -90
- package/scripts/test-faucet-and-gasless.ts +0 -150
- package/scripts/test-jack-gasless.ts +0 -119
- package/scripts/test-jack-registration.ts +0 -133
- package/scripts/test-jack-superpaymaster-api.ts +0 -112
- package/scripts/test-kms-gasless.ts +0 -352
- package/scripts/update-price-dvt.ts +0 -53
- package/scripts/update_env_from_config.ts +0 -83
- package/scripts/v2_regression/00_validate_env.ts +0 -101
- package/scripts/v2_regression/01_setup_and_fund.ts +0 -132
- package/scripts/v2_regression/02_operator_onboarding.ts +0 -300
- package/scripts/v2_regression/03_community_registry.ts +0 -173
- package/scripts/v2_regression/04_enduser_flow.ts +0 -174
- package/scripts/v2_regression/05_admin_audit.ts +0 -157
- package/scripts/v2_regression/README.md +0 -161
- package/scripts/validate_env.ts +0 -112
- package/scripts/verify-bob-token.ts +0 -41
- package/scripts/verify-tx-status.ts +0 -81
- package/scripts/verify_onchain_milestone.ts +0 -114
- package/scripts/verify_phase1.ts +0 -66
- package/scripts/verify_phase2.ts +0 -66
- package/sdk-abi-coverage.sh +0 -1
- package/sdk-build-and-test.sh +0 -1
- package/sdk-test-coverage.sh +0 -1
- package/sdk_experiment_data.csv +0 -4
- package/simple-test-paymaster.sh +0 -2
- package/simple-test-superpaymaster.sh +0 -3
- package/tests/check-aa-balance.ts +0 -31
- package/tests/l1-regression.test.ts +0 -437
- package/tests/l4-test-anni-gasless.ts +0 -517
- package/tests/l4-test-jason1-gasless.ts +0 -158
- package/tests/l4-test-jason2-gasless.ts +0 -180
- package/tests/l4-test-pmv4-deposit.ts +0 -111
- package/tests/l4-test-pmv4-gasless.ts +0 -166
- package/tests/l4-test-pmv4-submit.ts +0 -223
- package/tests/regression/README.md +0 -168
- package/tests/regression/config.ts +0 -217
- package/tests/regression/display-versions.ts +0 -85
- package/tests/regression/index.ts +0 -67
- package/tests/regression/l1-tests.ts +0 -248
- package/tests/regression/l2-tests.ts +0 -227
- package/tests/regression/l3-tests.ts +0 -28
- package/tests/regression/l4-comprehensive-gasless.ts +0 -478
- package/tests/regression/l4-gasless.ts +0 -999
- package/tests/regression/l4-reputation-tiers.ts +0 -102
- package/tests/regression/l4-runner.ts +0 -52
- package/tests/reports/phase1_contract_verification.md +0 -45
- package/tests/test-bundler-compat.ts +0 -132
- package/tests/test-candide-bundler.ts +0 -117
- package/tests/test-candide-paymaster.ts +0 -101
- package/tests/test-candide-sdk.ts +0 -116
- package/tests/test-candide-simple.ts +0 -204
- package/tests/test-pimlico-complete.ts +0 -134
- package/tests/utils/contractVerifier.ts +0 -237
- package/tests/utils/userOpHelper.ts +0 -194
- package/tsconfig.build.json +0 -23
- package/tsconfig.json +0 -27
- package/typedoc.json +0 -25
- package/update-version.sh +0 -20
- package/vitest.config.ts +0 -17
|
@@ -0,0 +1,66 @@
|
|
|
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 PaymasterActions } from '@aastar/core';
|
|
3
|
+
export type OperatorClient = Client<Transport, Chain, Account | undefined> & PublicActions<Transport, Chain, Account | undefined> & WalletActions<Chain, Account | undefined> & RegistryActions & SuperPaymasterActions & PaymasterActions & StakingActions & {
|
|
4
|
+
/**
|
|
5
|
+
* High-level API: Setup operator with automatic funding and onboarding
|
|
6
|
+
*/
|
|
7
|
+
setup: (args: {
|
|
8
|
+
stakeAmount: bigint;
|
|
9
|
+
depositAmount: bigint;
|
|
10
|
+
roleId: Hex;
|
|
11
|
+
roleData?: Hex;
|
|
12
|
+
}) => Promise<{
|
|
13
|
+
txs: Hash[];
|
|
14
|
+
}>;
|
|
15
|
+
deployPaymasterV4: (args?: {
|
|
16
|
+
version?: string;
|
|
17
|
+
initData?: Hex;
|
|
18
|
+
}) => Promise<Hash>;
|
|
19
|
+
/**
|
|
20
|
+
* Orchestrates the full onboarding flow:
|
|
21
|
+
* 1. Approve GToken (Stake)
|
|
22
|
+
* 2. Register Role (Stake Lock)
|
|
23
|
+
* 3. Approve aPNTs (Deposit)
|
|
24
|
+
* 4. Deposit aPNTs (SuperPaymaster)
|
|
25
|
+
*/
|
|
26
|
+
onboardOperator: (args: {
|
|
27
|
+
stakeAmount: bigint;
|
|
28
|
+
depositAmount: bigint;
|
|
29
|
+
roleId: Hex;
|
|
30
|
+
roleData?: Hex;
|
|
31
|
+
}) => Promise<Hash[]>;
|
|
32
|
+
/** @deprecated Use onboardOperator */
|
|
33
|
+
onboardToSuperPaymaster: (args: {
|
|
34
|
+
stakeAmount: bigint;
|
|
35
|
+
depositAmount: bigint;
|
|
36
|
+
roleId: Hex;
|
|
37
|
+
}) => Promise<Hash[]>;
|
|
38
|
+
configureOperator: (args: {
|
|
39
|
+
xPNTsToken: Address;
|
|
40
|
+
treasury: Address;
|
|
41
|
+
exchangeRate: bigint;
|
|
42
|
+
account?: Account | Address;
|
|
43
|
+
}) => Promise<Hash>;
|
|
44
|
+
getOperatorStatus: (accountAddress: Address) => Promise<{
|
|
45
|
+
type: 'super' | 'v4' | null;
|
|
46
|
+
superPaymaster: {
|
|
47
|
+
hasRole: boolean;
|
|
48
|
+
isConfigured: boolean;
|
|
49
|
+
balance: bigint;
|
|
50
|
+
exchangeRate: bigint;
|
|
51
|
+
treasury: Address;
|
|
52
|
+
} | null;
|
|
53
|
+
paymasterV4: {
|
|
54
|
+
address: Address;
|
|
55
|
+
balance: bigint;
|
|
56
|
+
} | null;
|
|
57
|
+
}>;
|
|
58
|
+
};
|
|
59
|
+
export declare function createOperatorClient({ chain, transport, account, addresses }: {
|
|
60
|
+
chain: Chain;
|
|
61
|
+
transport: Transport;
|
|
62
|
+
account?: Account;
|
|
63
|
+
addresses?: {
|
|
64
|
+
[key: string]: Address;
|
|
65
|
+
};
|
|
66
|
+
}): OperatorClient;
|
|
@@ -1,105 +1,40 @@
|
|
|
1
|
-
import { createClient,
|
|
2
|
-
|
|
3
|
-
import {
|
|
4
|
-
stakingActions,
|
|
5
|
-
registryActions,
|
|
6
|
-
RegistryABI,
|
|
7
|
-
superPaymasterActions,
|
|
8
|
-
|
|
9
|
-
paymasterActions,
|
|
10
|
-
PaymasterFactoryABI,
|
|
11
|
-
type StakingActions,
|
|
12
|
-
type RegistryActions,
|
|
13
|
-
type SuperPaymasterActions,
|
|
14
|
-
type PaymasterActions,
|
|
15
|
-
CORE_ADDRESSES,
|
|
16
|
-
TEST_TOKEN_ADDRESSES,
|
|
17
|
-
TEST_ACCOUNT_ADDRESSES
|
|
18
|
-
} from '@aastar/core';
|
|
1
|
+
import { createClient, erc20Abi, parseAbi, publicActions, walletActions, keccak256, stringToBytes } from 'viem';
|
|
2
|
+
import { stakingActions, registryActions, RegistryABI, superPaymasterActions, paymasterActions, PaymasterFactoryABI, CORE_ADDRESSES, TEST_TOKEN_ADDRESSES, TEST_ACCOUNT_ADDRESSES } from '@aastar/core';
|
|
19
3
|
import { RoleDataFactory } from '../utils/roleData.js';
|
|
20
4
|
import { decodeContractError } from '../errors/decoder.js';
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
* High-level API: Setup operator with automatic funding and onboarding
|
|
25
|
-
*/
|
|
26
|
-
setup: (args: { stakeAmount: bigint, depositAmount: bigint, roleId: Hex, roleData?: Hex }) => Promise<{ txs: Hash[] }>;
|
|
27
|
-
deployPaymasterV4: (args?: { version?: string, initData?: Hex }) => Promise<Hash>;
|
|
28
|
-
/**
|
|
29
|
-
* Orchestrates the full onboarding flow:
|
|
30
|
-
* 1. Approve GToken (Stake)
|
|
31
|
-
* 2. Register Role (Stake Lock)
|
|
32
|
-
* 3. Approve aPNTs (Deposit)
|
|
33
|
-
* 4. Deposit aPNTs (SuperPaymaster)
|
|
34
|
-
*/
|
|
35
|
-
onboardOperator: (args: { stakeAmount: bigint, depositAmount: bigint, roleId: Hex, roleData?: Hex }) => Promise<Hash[]>;
|
|
36
|
-
/** @deprecated Use onboardOperator */
|
|
37
|
-
onboardToSuperPaymaster: (args: { stakeAmount: bigint, depositAmount: bigint, roleId: Hex }) => Promise<Hash[]>
|
|
38
|
-
configureOperator: (args: { xPNTsToken: Address, treasury: Address, exchangeRate: bigint, account?: Account | Address }) => Promise<Hash>
|
|
39
|
-
getOperatorStatus: (accountAddress: Address) => Promise<{
|
|
40
|
-
type: 'super' | 'v4' | null;
|
|
41
|
-
superPaymaster: {
|
|
42
|
-
hasRole: boolean;
|
|
43
|
-
isConfigured: boolean;
|
|
44
|
-
balance: bigint;
|
|
45
|
-
exchangeRate: bigint;
|
|
46
|
-
treasury: Address;
|
|
47
|
-
} | null;
|
|
48
|
-
paymasterV4: {
|
|
49
|
-
address: Address;
|
|
50
|
-
balance: bigint;
|
|
51
|
-
} | null;
|
|
52
|
-
}>
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
export function createOperatorClient({
|
|
57
|
-
chain,
|
|
58
|
-
transport,
|
|
59
|
-
account,
|
|
60
|
-
addresses
|
|
61
|
-
}: {
|
|
62
|
-
chain: Chain,
|
|
63
|
-
transport: Transport,
|
|
64
|
-
account?: Account,
|
|
65
|
-
addresses?: { [key: string]: Address }
|
|
66
|
-
}): OperatorClient {
|
|
67
|
-
const client = createClient({
|
|
68
|
-
chain,
|
|
5
|
+
export function createOperatorClient({ chain, transport, account, addresses }) {
|
|
6
|
+
const client = createClient({
|
|
7
|
+
chain,
|
|
69
8
|
transport,
|
|
70
9
|
account
|
|
71
10
|
})
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
11
|
+
.extend(publicActions)
|
|
12
|
+
.extend(walletActions);
|
|
75
13
|
const usedAddresses = { ...CORE_ADDRESSES, ...TEST_TOKEN_ADDRESSES, ...TEST_ACCOUNT_ADDRESSES, ...addresses };
|
|
76
|
-
|
|
77
|
-
const
|
|
78
|
-
const
|
|
79
|
-
const
|
|
80
|
-
const pmV4Actions = paymasterActions(usedAddresses.paymasterV4)(client as any);
|
|
81
|
-
|
|
14
|
+
const spActions = superPaymasterActions(usedAddresses.superPaymaster)(client);
|
|
15
|
+
const regActions = registryActions(usedAddresses.registry)(client);
|
|
16
|
+
const stkActions = stakingActions(usedAddresses.gTokenStaking)(client);
|
|
17
|
+
const pmV4Actions = paymasterActions(usedAddresses.paymasterV4)(client);
|
|
82
18
|
const actions = {
|
|
83
19
|
...stkActions,
|
|
84
20
|
...spActions,
|
|
85
21
|
...pmV4Actions,
|
|
86
22
|
...regActions,
|
|
87
|
-
|
|
88
|
-
async setup(args: { stakeAmount: bigint, depositAmount: bigint, roleId: Hex, roleData?: Hex }) {
|
|
23
|
+
async setup(args) {
|
|
89
24
|
console.log('⚙️ Setting up operator...');
|
|
90
|
-
const txs = await
|
|
25
|
+
const txs = await this._onboardOperator(args);
|
|
91
26
|
console.log(`✅ Operator setup complete! Transactions: ${txs.length}`);
|
|
92
27
|
return { txs };
|
|
93
28
|
},
|
|
94
|
-
async onboardOperator(args
|
|
29
|
+
async onboardOperator(args) {
|
|
95
30
|
return this.onboardFully(args);
|
|
96
31
|
},
|
|
97
|
-
async onboardFully(args
|
|
98
|
-
return
|
|
32
|
+
async onboardFully(args) {
|
|
33
|
+
return this._onboardOperator(args);
|
|
99
34
|
},
|
|
100
|
-
async deployPaymasterV4({ version = 'v4.1', initData = '0x' }
|
|
35
|
+
async deployPaymasterV4({ version = 'v4.1', initData = '0x' } = {}) {
|
|
101
36
|
console.log(` SDK: Deploying Paymaster V4 (${version})...`);
|
|
102
|
-
const tx = await
|
|
37
|
+
const tx = await client.writeContract({
|
|
103
38
|
address: usedAddresses.paymasterFactory,
|
|
104
39
|
abi: PaymasterFactoryABI,
|
|
105
40
|
functionName: 'deployPaymaster',
|
|
@@ -107,29 +42,27 @@ export function createOperatorClient({
|
|
|
107
42
|
account,
|
|
108
43
|
chain
|
|
109
44
|
});
|
|
110
|
-
await
|
|
45
|
+
await client.waitForTransactionReceipt({ hash: tx });
|
|
111
46
|
return tx;
|
|
112
47
|
},
|
|
113
|
-
async _onboardOperator({ stakeAmount, depositAmount, roleId, roleData }
|
|
114
|
-
const txs
|
|
115
|
-
const accountToUse = account;
|
|
116
|
-
if (!accountToUse)
|
|
117
|
-
|
|
48
|
+
async _onboardOperator({ stakeAmount, depositAmount, roleId, roleData }) {
|
|
49
|
+
const txs = [];
|
|
50
|
+
const accountToUse = account;
|
|
51
|
+
if (!accountToUse)
|
|
52
|
+
throw new Error("Account required for onboarding");
|
|
118
53
|
try {
|
|
119
54
|
// 1. Fetch Entry Burn & Approve GToken
|
|
120
55
|
console.log(' SDK: Fetching role config for entry burn...');
|
|
121
|
-
const roleConfig = await
|
|
56
|
+
const roleConfig = await client.readContract({
|
|
122
57
|
address: usedAddresses.registry,
|
|
123
58
|
abi: RegistryABI,
|
|
124
59
|
functionName: 'roleConfigs',
|
|
125
60
|
args: [roleId]
|
|
126
|
-
})
|
|
127
|
-
|
|
128
|
-
const entryBurn = roleConfig[1];
|
|
61
|
+
});
|
|
62
|
+
const entryBurn = roleConfig[1];
|
|
129
63
|
const totalStakeNeeded = stakeAmount + entryBurn;
|
|
130
|
-
|
|
131
64
|
console.log(` SDK: Approving GToken (Stake: ${stakeAmount}, Burn: ${entryBurn})...`);
|
|
132
|
-
const approveGToken = await
|
|
65
|
+
const approveGToken = await client.writeContract({
|
|
133
66
|
address: usedAddresses.gToken,
|
|
134
67
|
abi: erc20Abi,
|
|
135
68
|
functionName: 'approve',
|
|
@@ -137,50 +70,51 @@ export function createOperatorClient({
|
|
|
137
70
|
account: accountToUse,
|
|
138
71
|
chain
|
|
139
72
|
});
|
|
140
|
-
await
|
|
73
|
+
await client.waitForTransactionReceipt({ hash: approveGToken });
|
|
141
74
|
txs.push(approveGToken);
|
|
142
|
-
|
|
143
75
|
// 2. Register Role
|
|
144
|
-
let data
|
|
76
|
+
let data;
|
|
145
77
|
if (roleData && roleData !== '0x') {
|
|
146
78
|
data = roleData;
|
|
147
|
-
}
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
148
81
|
console.log(` SDK: Auto-generating roleData for roleId ${roleId}...`);
|
|
149
82
|
if (roleId === keccak256(stringToBytes('COMMUNITY'))) {
|
|
150
83
|
data = RoleDataFactory.community();
|
|
151
|
-
}
|
|
84
|
+
}
|
|
85
|
+
else if (roleId === keccak256(stringToBytes('ENDUSER'))) {
|
|
152
86
|
data = RoleDataFactory.endUser();
|
|
153
|
-
}
|
|
87
|
+
}
|
|
88
|
+
else if (roleId === keccak256(stringToBytes('PAYMASTER_SUPER'))) {
|
|
154
89
|
data = RoleDataFactory.paymasterSuper();
|
|
155
|
-
}
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
156
92
|
data = RoleDataFactory.paymasterSuper();
|
|
157
93
|
}
|
|
158
94
|
}
|
|
159
|
-
|
|
160
95
|
console.log(` SDK: Checking if role already granted...`);
|
|
161
|
-
const hasRoleResult = await
|
|
96
|
+
const hasRoleResult = await client.readContract({
|
|
162
97
|
address: usedAddresses.registry,
|
|
163
98
|
abi: RegistryABI,
|
|
164
99
|
functionName: 'hasRole',
|
|
165
|
-
args: [roleId, accountToUse
|
|
166
|
-
})
|
|
167
|
-
|
|
100
|
+
args: [roleId, accountToUse.address]
|
|
101
|
+
});
|
|
168
102
|
if (hasRoleResult) {
|
|
169
103
|
console.log(` ℹ️ Role already granted, skipping registration`);
|
|
170
|
-
}
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
171
106
|
console.log(` SDK: Registering role ${roleId}...`);
|
|
172
107
|
const registerTx = await actions.registerRoleSelf({
|
|
173
108
|
roleId,
|
|
174
|
-
data,
|
|
109
|
+
data,
|
|
175
110
|
account: accountToUse
|
|
176
111
|
});
|
|
177
|
-
await
|
|
112
|
+
await client.waitForTransactionReceipt({ hash: registerTx });
|
|
178
113
|
txs.push(registerTx);
|
|
179
114
|
}
|
|
180
|
-
|
|
181
115
|
if (depositAmount > 0n) {
|
|
182
116
|
console.log(' SDK: Depositing aPNTs via depositFor...');
|
|
183
|
-
const depositTx = await
|
|
117
|
+
const depositTx = await client.writeContract({
|
|
184
118
|
address: usedAddresses.superPaymaster,
|
|
185
119
|
abi: parseAbi(['function depositFor(address targetOperator, uint256 amount) external']),
|
|
186
120
|
functionName: 'depositFor',
|
|
@@ -188,51 +122,48 @@ export function createOperatorClient({
|
|
|
188
122
|
account: accountToUse,
|
|
189
123
|
chain
|
|
190
124
|
});
|
|
191
|
-
await
|
|
125
|
+
await client.waitForTransactionReceipt({ hash: depositTx });
|
|
192
126
|
txs.push(depositTx);
|
|
193
127
|
}
|
|
194
|
-
|
|
195
128
|
return txs;
|
|
196
|
-
}
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
197
131
|
const decodedMsg = decodeContractError(error);
|
|
198
132
|
throw decodedMsg ? new Error(`Onboarding Failed: ${decodedMsg}`) : error;
|
|
199
133
|
}
|
|
200
134
|
},
|
|
201
|
-
async onboardToSuperPaymaster(args
|
|
135
|
+
async onboardToSuperPaymaster(args) {
|
|
202
136
|
return this.onboardOperator(args);
|
|
203
137
|
},
|
|
204
|
-
async configureOperator({ xPNTsToken, treasury, exchangeRate, account: accountOverride }
|
|
205
|
-
const tx = await spActions.configureOperator({
|
|
206
|
-
xPNTsToken,
|
|
207
|
-
opTreasury: treasury,
|
|
138
|
+
async configureOperator({ xPNTsToken, treasury, exchangeRate, account: accountOverride }) {
|
|
139
|
+
const tx = await spActions.configureOperator({
|
|
140
|
+
xPNTsToken,
|
|
141
|
+
opTreasury: treasury,
|
|
208
142
|
exchangeRate,
|
|
209
143
|
account: accountOverride || account
|
|
210
144
|
});
|
|
211
|
-
await
|
|
145
|
+
await client.waitForTransactionReceipt({ hash: tx });
|
|
212
146
|
return tx;
|
|
213
147
|
},
|
|
214
|
-
async getOperatorStatus(accountAddress
|
|
148
|
+
async getOperatorStatus(accountAddress) {
|
|
215
149
|
try {
|
|
216
150
|
const hasRole = await client.readContract({
|
|
217
151
|
address: usedAddresses.registry,
|
|
218
152
|
abi: RegistryABI,
|
|
219
153
|
functionName: 'hasRole',
|
|
220
154
|
args: [keccak256(stringToBytes('PAYMASTER_SUPER')), accountAddress]
|
|
221
|
-
})
|
|
222
|
-
|
|
223
|
-
let operatorType: 'super' | 'v4' | null = null;
|
|
155
|
+
});
|
|
156
|
+
let operatorType = null;
|
|
224
157
|
let superPaymasterInfo = null;
|
|
225
158
|
let paymasterV4Info = null;
|
|
226
|
-
|
|
227
159
|
if (hasRole && usedAddresses.superPaymaster) {
|
|
228
160
|
const pmAbi = parseAbi(['function operators(address) view returns (uint128 balance, uint96 exchangeRate, bool isConfigured, bool isPaused, address token, uint32 reputation, address treasury, uint256 spent, uint256 txSponsored)']);
|
|
229
161
|
const operatorData = await client.readContract({
|
|
230
|
-
address: usedAddresses.superPaymaster
|
|
162
|
+
address: usedAddresses.superPaymaster,
|
|
231
163
|
abi: pmAbi,
|
|
232
164
|
functionName: 'operators',
|
|
233
165
|
args: [accountAddress]
|
|
234
|
-
})
|
|
235
|
-
|
|
166
|
+
});
|
|
236
167
|
if (operatorData && operatorData[2]) { // isConfigured
|
|
237
168
|
operatorType = 'super';
|
|
238
169
|
superPaymasterInfo = {
|
|
@@ -244,7 +175,6 @@ export function createOperatorClient({
|
|
|
244
175
|
};
|
|
245
176
|
}
|
|
246
177
|
}
|
|
247
|
-
|
|
248
178
|
// 检查 Paymaster V4 (Direct)
|
|
249
179
|
if (usedAddresses.paymasterFactory && usedAddresses.paymasterFactory !== '0x0000000000000000000000000000000000000000') {
|
|
250
180
|
try {
|
|
@@ -254,8 +184,7 @@ export function createOperatorClient({
|
|
|
254
184
|
abi: factoryAbi,
|
|
255
185
|
functionName: 'getPaymasterByOperator',
|
|
256
186
|
args: [accountAddress]
|
|
257
|
-
})
|
|
258
|
-
|
|
187
|
+
});
|
|
259
188
|
if (pmAddr !== '0x0000000000000000000000000000000000000000') {
|
|
260
189
|
operatorType = operatorType || 'v4';
|
|
261
190
|
paymasterV4Info = {
|
|
@@ -263,18 +192,18 @@ export function createOperatorClient({
|
|
|
263
192
|
balance: await client.getBalance({ address: pmAddr })
|
|
264
193
|
};
|
|
265
194
|
}
|
|
266
|
-
}
|
|
195
|
+
}
|
|
196
|
+
catch (e) {
|
|
267
197
|
console.warn(` ⚠️ Failed to fetch V4 info from factory ${usedAddresses.paymasterFactory}:`, e);
|
|
268
198
|
}
|
|
269
199
|
}
|
|
270
|
-
|
|
271
200
|
return { type: operatorType, superPaymaster: superPaymasterInfo, paymasterV4: paymasterV4Info };
|
|
272
|
-
}
|
|
201
|
+
}
|
|
202
|
+
catch (error) {
|
|
273
203
|
console.error('Error in getOperatorStatus:', error);
|
|
274
204
|
return { type: null, superPaymaster: null, paymasterV4: null };
|
|
275
205
|
}
|
|
276
206
|
}
|
|
277
207
|
};
|
|
278
|
-
|
|
279
|
-
return Object.assign(client, actions) as unknown as OperatorClient;
|
|
208
|
+
return Object.assign(client, actions);
|
|
280
209
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { describe, it, expect, vi } from 'vitest';
|
|
2
|
+
import { createOperatorClient } from './operator.js';
|
|
3
|
+
import { mainnet } from 'viem/chains';
|
|
4
|
+
import { http, keccak256, stringToBytes } 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
|
+
registryHasRole: vi.fn().mockResolvedValue(false),
|
|
11
|
+
registryRegisterRoleSelf: vi.fn().mockResolvedValue('0xhash')
|
|
12
|
+
}))),
|
|
13
|
+
stakingActions: vi.fn(() => vi.fn(() => ({
|
|
14
|
+
// any staking methods if needed
|
|
15
|
+
}))),
|
|
16
|
+
superPaymasterActions: vi.fn(() => vi.fn(() => ({
|
|
17
|
+
superPaymasterDepositFor: vi.fn().mockResolvedValue('0xhash'),
|
|
18
|
+
superPaymasterOperators: vi.fn().mockResolvedValue([1000n, 1000n, true, false]),
|
|
19
|
+
superPaymasterGetDeposit: vi.fn().mockResolvedValue(555n)
|
|
20
|
+
}))),
|
|
21
|
+
paymasterV4Actions: vi.fn(() => vi.fn(() => ({
|
|
22
|
+
// pmv4 methods
|
|
23
|
+
}))),
|
|
24
|
+
tokenActions: vi.fn(() => vi.fn(() => ({
|
|
25
|
+
tokenApprove: vi.fn().mockResolvedValue('0xhash')
|
|
26
|
+
}))),
|
|
27
|
+
};
|
|
28
|
+
});
|
|
29
|
+
describe('OperatorClient', () => {
|
|
30
|
+
const MOCK_ADDR = '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266';
|
|
31
|
+
it('should create operator client', () => {
|
|
32
|
+
const client = createOperatorClient({ chain: mainnet, transport: http() });
|
|
33
|
+
expect(client.setup).toBeDefined();
|
|
34
|
+
});
|
|
35
|
+
describe('onboardFully', () => {
|
|
36
|
+
it('should complete onboarding flow', async () => {
|
|
37
|
+
const client = createOperatorClient({
|
|
38
|
+
chain: mainnet,
|
|
39
|
+
transport: http(),
|
|
40
|
+
account: { address: MOCK_ADDR }
|
|
41
|
+
});
|
|
42
|
+
// Mock base client methods
|
|
43
|
+
client.readContract = vi.fn().mockResolvedValue([0n, 0n, 0n]);
|
|
44
|
+
client.waitForTransactionReceipt = vi.fn().mockResolvedValue({ logs: [] });
|
|
45
|
+
const results = await client.onboardFully({
|
|
46
|
+
stakeAmount: 100n,
|
|
47
|
+
depositAmount: 200n,
|
|
48
|
+
roleId: keccak256(stringToBytes('PAYMASTER_SUPER'))
|
|
49
|
+
});
|
|
50
|
+
expect(results).toHaveLength(3);
|
|
51
|
+
expect(client.tokenApprove).toHaveBeenCalled();
|
|
52
|
+
expect(client.registryRegisterRoleSelf).toHaveBeenCalled();
|
|
53
|
+
expect(client.superPaymasterDepositFor).toHaveBeenCalled();
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
describe('Advanced Setup', () => {
|
|
57
|
+
it('should call configureOperator', async () => {
|
|
58
|
+
const client = createOperatorClient({ chain: mainnet, transport: http() });
|
|
59
|
+
client.configureOperator = vi.fn().mockResolvedValue('0xhash');
|
|
60
|
+
const hash = await client.configureOperator({
|
|
61
|
+
xPNTsToken: MOCK_ADDR,
|
|
62
|
+
treasury: MOCK_ADDR,
|
|
63
|
+
exchangeRate: 100n
|
|
64
|
+
});
|
|
65
|
+
expect(hash).toBe('0xhash');
|
|
66
|
+
});
|
|
67
|
+
it('should onboard to Super Paymaster', async () => {
|
|
68
|
+
const client = createOperatorClient({
|
|
69
|
+
chain: mainnet,
|
|
70
|
+
transport: http(),
|
|
71
|
+
account: { address: MOCK_ADDR }
|
|
72
|
+
});
|
|
73
|
+
client.onboardFully = vi.fn().mockResolvedValue([]);
|
|
74
|
+
// onboardToSuperPaymaster is an internal action alias in OperatorClient
|
|
75
|
+
await client.onboardToSuperPaymaster({ stakeAmount: 100n, depositAmount: 200n, roleId: '0x1' });
|
|
76
|
+
expect(client.onboardFully).toHaveBeenCalled();
|
|
77
|
+
});
|
|
78
|
+
it('should deploy PaymasterV4', async () => {
|
|
79
|
+
const client = createOperatorClient({ chain: mainnet, transport: http(), account: { address: MOCK_ADDR } });
|
|
80
|
+
client.writeContract = vi.fn().mockResolvedValue('0xdeployhash');
|
|
81
|
+
client.waitForTransactionReceipt = vi.fn().mockResolvedValue({});
|
|
82
|
+
const hash = await client.deployPaymasterV4({ version: 'v4.2' });
|
|
83
|
+
expect(hash).toBe('0xdeployhash');
|
|
84
|
+
});
|
|
85
|
+
it('should validate inputs in configureOperator', async () => {
|
|
86
|
+
const opClient = createOperatorClient({
|
|
87
|
+
account: { address: MOCK_ADDR },
|
|
88
|
+
chain: mainnet,
|
|
89
|
+
transport: http()
|
|
90
|
+
});
|
|
91
|
+
// No need to mock internal configureOperator for validation testing
|
|
92
|
+
// as validation happens before internal call.
|
|
93
|
+
await expect(opClient.configureOperator({
|
|
94
|
+
xPNTsToken: '0xInvalid',
|
|
95
|
+
treasury: '0x123',
|
|
96
|
+
exchangeRate: 100n
|
|
97
|
+
})).rejects.toThrow('xPNTs Token must be a valid Ethereum address');
|
|
98
|
+
await expect(opClient.configureOperator({
|
|
99
|
+
xPNTsToken: MOCK_ADDR,
|
|
100
|
+
treasury: '0xInvalid',
|
|
101
|
+
exchangeRate: 100n
|
|
102
|
+
})).rejects.toThrow('Treasury must be a valid Ethereum address');
|
|
103
|
+
});
|
|
104
|
+
it('should check readiness', async () => {
|
|
105
|
+
const opClient = createOperatorClient({
|
|
106
|
+
account: { address: MOCK_ADDR },
|
|
107
|
+
chain: mainnet,
|
|
108
|
+
transport: http()
|
|
109
|
+
});
|
|
110
|
+
// Global mock for registryActions.hasRole returns false
|
|
111
|
+
// Global mock for superPaymasterActions.operators returns [1000n, 1000n, true, false]
|
|
112
|
+
const status = await opClient.checkReadiness();
|
|
113
|
+
expect(status.isRegistered).toBe(false); // mocked val
|
|
114
|
+
expect(status.isConfigured).toBe(true); // mocked val (index 2)
|
|
115
|
+
expect(status.collateralBalance).toBe(1000n); // mocked val (index 0)
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
describe('Operator Status and Queries', () => {
|
|
119
|
+
it('should get operator status', async () => {
|
|
120
|
+
const client = createOperatorClient({ chain: mainnet, transport: http() });
|
|
121
|
+
client.readContract = vi.fn()
|
|
122
|
+
.mockResolvedValueOnce(true) // hasRole
|
|
123
|
+
.mockResolvedValueOnce([1000n, 100n, true, false, 0n, 0n, MOCK_ADDR]); // operator data
|
|
124
|
+
const status = await client.getOperatorStatus(MOCK_ADDR);
|
|
125
|
+
expect(status.type).toBe('super');
|
|
126
|
+
expect(status.superPaymaster?.isConfigured).toBe(true);
|
|
127
|
+
});
|
|
128
|
+
it('should check if address is operator', async () => {
|
|
129
|
+
const client = createOperatorClient({ chain: mainnet, transport: http() });
|
|
130
|
+
const result = await client.isOperator(MOCK_ADDR);
|
|
131
|
+
expect(result).toBe(true); // from mocked operators
|
|
132
|
+
});
|
|
133
|
+
it('should get deposit details', async () => {
|
|
134
|
+
const client = createOperatorClient({ chain: mainnet, transport: http() });
|
|
135
|
+
const details = await client.getDepositDetails();
|
|
136
|
+
expect(details.deposit).toBe(555n); // from mocked getDeposit
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
});
|