@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.
Files changed (958) hide show
  1. package/README.md +100 -120
  2. package/dist/account/src/accounts/simple.d.ts +18 -0
  3. package/{packages/account/src/accounts/simple.ts → dist/account/src/accounts/simple.js} +12 -47
  4. package/dist/account/src/eoa.d.ts +10 -0
  5. package/dist/account/src/eoa.js +21 -0
  6. package/dist/account/src/index.d.ts +19 -0
  7. package/dist/account/src/index.js +49 -0
  8. package/dist/core/src/abis/BLSAggregator.json +686 -0
  9. package/dist/core/src/abis/BLSValidator.json +42 -0
  10. package/dist/core/src/abis/DVTValidator.json +368 -0
  11. package/dist/core/src/abis/EntryPoint.json +1382 -0
  12. package/dist/core/src/abis/GToken.json +513 -0
  13. package/dist/core/src/abis/GTokenStaking.json +949 -0
  14. package/dist/core/src/abis/MySBT.json +1518 -0
  15. package/dist/core/src/abis/Paymaster.json +1143 -0
  16. package/dist/core/src/abis/PaymasterFactory.json +640 -0
  17. package/dist/core/src/abis/Registry.json +1942 -0
  18. package/dist/core/src/abis/ReputationSystem.json +699 -0
  19. package/dist/core/src/abis/SimpleAccount.json +560 -0
  20. package/dist/core/src/abis/SimpleAccountFactory.json +111 -0
  21. package/dist/core/src/abis/SuperPaymaster.json +1781 -0
  22. package/dist/core/src/abis/index.d.ts +1126 -0
  23. package/dist/core/src/abis/index.js +91 -0
  24. package/dist/core/src/abis/xPNTsFactory.json +718 -0
  25. package/dist/core/src/abis/xPNTsToken.json +1280 -0
  26. package/dist/core/src/actions/StateValidator.d.ts +68 -0
  27. package/dist/core/src/actions/StateValidator.js +187 -0
  28. package/dist/core/src/actions/account.d.ts +55 -0
  29. package/dist/core/src/actions/account.js +133 -0
  30. package/dist/core/src/actions/aggregator.d.ts +17 -0
  31. package/dist/core/src/actions/aggregator.js +31 -0
  32. package/dist/core/src/actions/dvt.d.ts +30 -0
  33. package/dist/core/src/actions/dvt.js +41 -0
  34. package/dist/core/src/actions/entryPoint.d.ts +90 -0
  35. package/dist/core/src/actions/entryPoint.js +211 -0
  36. package/dist/core/src/actions/factory.d.ts +215 -0
  37. package/dist/core/src/actions/factory.js +442 -0
  38. package/dist/core/src/actions/faucet.d.ts +48 -0
  39. package/dist/core/src/actions/faucet.js +337 -0
  40. package/dist/core/src/actions/gtokenExtended.d.ts +39 -0
  41. package/dist/core/src/actions/gtokenExtended.js +115 -0
  42. package/{packages/core/src/actions/index.ts → dist/core/src/actions/index.d.ts} +5 -0
  43. package/dist/core/src/actions/index.js +17 -0
  44. package/dist/core/src/actions/paymasterV4.d.ts +170 -0
  45. package/dist/core/src/actions/paymasterV4.js +334 -0
  46. package/dist/core/src/actions/registry.d.ts +246 -0
  47. package/dist/core/src/actions/registry.js +667 -0
  48. package/dist/core/src/actions/reputation.d.ts +129 -0
  49. package/dist/core/src/actions/reputation.js +281 -0
  50. package/dist/core/src/actions/sbt.d.ts +191 -0
  51. package/dist/core/src/actions/sbt.js +533 -0
  52. package/dist/core/src/actions/staking.d.ts +132 -0
  53. package/dist/core/src/actions/staking.js +330 -0
  54. package/dist/core/src/actions/superPaymaster.d.ts +237 -0
  55. package/dist/core/src/actions/superPaymaster.js +644 -0
  56. package/dist/core/src/actions/tokens.d.ts +229 -0
  57. package/dist/core/src/actions/tokens.js +415 -0
  58. package/dist/core/src/branding.d.ts +30 -0
  59. package/dist/core/src/branding.js +30 -0
  60. package/dist/core/src/clients/BaseClient.d.ts +25 -0
  61. package/dist/core/src/clients/BaseClient.js +66 -0
  62. package/dist/core/src/clients/types.d.ts +60 -0
  63. package/dist/core/src/clients/types.js +1 -0
  64. package/dist/core/src/clients.d.ts +5 -0
  65. package/dist/core/src/clients.js +11 -0
  66. package/dist/core/src/communities.d.ts +52 -0
  67. package/dist/core/src/communities.js +73 -0
  68. package/dist/core/src/config/ContractConfigManager.d.ts +20 -0
  69. package/dist/core/src/config/ContractConfigManager.js +48 -0
  70. package/dist/core/src/constants.d.ts +88 -0
  71. package/dist/core/src/constants.js +125 -0
  72. package/dist/core/src/contract-addresses.d.ts +110 -0
  73. package/dist/core/src/contract-addresses.js +99 -0
  74. package/dist/core/src/contracts.d.ts +424 -0
  75. package/dist/core/src/contracts.js +343 -0
  76. package/dist/core/src/crypto/blsSigner.d.ts +64 -0
  77. package/{packages/core/src/crypto/blsSigner.ts → dist/core/src/crypto/blsSigner.js} +23 -49
  78. package/dist/core/src/crypto/index.js +1 -0
  79. package/dist/core/src/index.d.ts +21 -0
  80. package/{packages/core/src/index.ts → dist/core/src/index.js} +4 -2
  81. package/dist/core/src/networks.d.ts +127 -0
  82. package/{ext/aastar-shared-config/src/networks.ts → dist/core/src/networks.js} +34 -33
  83. package/dist/core/src/requirementChecker.d.ts +38 -0
  84. package/{packages/core/src/requirementChecker.ts → dist/core/src/requirementChecker.js} +27 -113
  85. package/dist/core/src/roles.d.ts +204 -0
  86. package/dist/core/src/roles.js +211 -0
  87. package/dist/core/src/utils/validation.d.ts +24 -0
  88. package/dist/core/src/utils/validation.js +56 -0
  89. package/{packages/dapp/src/index.ts → dist/dapp/src/index.d.ts} +0 -1
  90. package/dist/dapp/src/index.js +3 -0
  91. package/dist/dapp/src/ui/hooks/useCreditScore.d.ts +13 -0
  92. package/{packages/dapp/src/ui/hooks/useCreditScore.ts → dist/dapp/src/ui/hooks/useCreditScore.js} +10 -22
  93. package/dist/dapp/src/ui/hooks/useSuperPaymaster.d.ts +8 -0
  94. package/{packages/dapp/src/ui/hooks/useSuperPaymaster.ts → dist/dapp/src/ui/hooks/useSuperPaymaster.js} +9 -17
  95. package/dist/dapp/src/ui/index.d.ts +4 -0
  96. package/{packages/dapp/src/ui/index.ts → dist/dapp/src/ui/index.js} +3 -8
  97. package/dist/identity/src/index.d.ts +46 -0
  98. package/dist/identity/src/index.js +94 -0
  99. package/dist/identity/src/mysbt.d.ts +13 -0
  100. package/{packages/identity/src/mysbt.ts → dist/identity/src/mysbt.js} +9 -20
  101. package/dist/paymaster/src/SuperPaymaster/index.d.ts +44 -0
  102. package/{packages/paymaster/src/SuperPaymaster/index.ts → dist/paymaster/src/SuperPaymaster/index.js} +29 -64
  103. package/dist/paymaster/src/V4/PaymasterClient.d.ts +79 -0
  104. package/dist/paymaster/src/V4/PaymasterClient.js +315 -0
  105. package/dist/paymaster/src/V4/PaymasterOperator.d.ts +41 -0
  106. package/dist/paymaster/src/V4/PaymasterOperator.js +241 -0
  107. package/dist/paymaster/src/V4/PaymasterUtils.d.ts +55 -0
  108. package/dist/paymaster/src/V4/PaymasterUtils.js +124 -0
  109. package/dist/paymaster/src/V4/SuperPaymasterClient.d.ts +21 -0
  110. package/dist/paymaster/src/V4/SuperPaymasterClient.js +73 -0
  111. package/dist/paymaster/src/V4/index.d.ts +4 -0
  112. package/dist/paymaster/src/V4/index.js +4 -0
  113. package/dist/paymaster/src/index.d.ts +2 -0
  114. package/{packages/paymaster/src/index.ts → dist/paymaster/src/index.js} +0 -1
  115. package/dist/sdk/src/clients/ExperimentClient.d.ts +34 -0
  116. package/dist/sdk/src/clients/ExperimentClient.js +58 -0
  117. package/dist/sdk/src/clients/ExperimentClient.test.d.ts +1 -0
  118. package/dist/sdk/src/clients/ExperimentClient.test.js +53 -0
  119. package/dist/sdk/src/clients/admin.d.ts +57 -0
  120. package/dist/sdk/src/clients/admin.js +105 -0
  121. package/dist/sdk/src/clients/admin.test.d.ts +1 -0
  122. package/dist/sdk/src/clients/admin.test.js +79 -0
  123. package/dist/sdk/src/clients/clients.test.d.ts +1 -0
  124. package/dist/sdk/src/clients/clients.test.js +91 -0
  125. package/dist/sdk/src/clients/community.d.ts +48 -0
  126. package/dist/sdk/src/clients/community.js +244 -0
  127. package/dist/sdk/src/clients/community.test.d.ts +1 -0
  128. package/dist/sdk/src/clients/community.test.js +99 -0
  129. package/dist/sdk/src/clients/endUser.d.ts +95 -0
  130. package/dist/sdk/src/clients/endUser.js +388 -0
  131. package/dist/sdk/src/clients/endUser.test.d.ts +1 -0
  132. package/dist/sdk/src/clients/endUser.test.js +188 -0
  133. package/dist/sdk/src/clients/operator.d.ts +96 -0
  134. package/dist/sdk/src/clients/operator.js +247 -0
  135. package/dist/sdk/src/clients/operator.test.d.ts +1 -0
  136. package/dist/sdk/src/clients/operator.test.js +139 -0
  137. package/dist/sdk/src/errors/AAStarError.d.ts +26 -0
  138. package/dist/sdk/src/errors/AAStarError.js +32 -0
  139. package/dist/sdk/src/errors/AAStarError.test.d.ts +1 -0
  140. package/dist/sdk/src/errors/AAStarError.test.js +74 -0
  141. package/dist/sdk/src/errors/decoder.d.ts +1 -0
  142. package/dist/sdk/src/errors/decoder.js +83 -0
  143. package/dist/sdk/src/errors/decoder.test.d.ts +1 -0
  144. package/dist/sdk/src/errors/decoder.test.js +90 -0
  145. package/dist/sdk/src/index.d.ts +16 -0
  146. package/dist/sdk/src/index.js +20 -0
  147. package/dist/sdk/src/node/index.d.ts +7 -0
  148. package/dist/sdk/src/node/index.js +7 -0
  149. package/dist/sdk/src/types/result.d.ts +15 -0
  150. package/dist/sdk/src/types/result.js +23 -0
  151. package/dist/sdk/src/utils/errorHandler.d.ts +40 -0
  152. package/{packages/sdk/src/utils/errorHandler.ts → dist/sdk/src/utils/errorHandler.js} +22 -75
  153. package/dist/sdk/src/utils/errorHandler.test.d.ts +1 -0
  154. package/dist/sdk/src/utils/errorHandler.test.js +89 -0
  155. package/dist/sdk/src/utils/eventDecoder.d.ts +7 -0
  156. package/dist/sdk/src/utils/eventDecoder.js +54 -0
  157. package/dist/sdk/src/utils/eventDecoder.test.d.ts +1 -0
  158. package/dist/sdk/src/utils/eventDecoder.test.js +48 -0
  159. package/dist/sdk/src/utils/funding.d.ts +115 -0
  160. package/{packages/sdk/src/utils/funding.ts → dist/sdk/src/utils/funding.js} +27 -119
  161. package/dist/sdk/src/utils/funding.test.d.ts +1 -0
  162. package/dist/sdk/src/utils/funding.test.js +105 -0
  163. package/dist/sdk/src/utils/keys.d.ts +73 -0
  164. package/{packages/sdk/src/utils/keys.ts → dist/sdk/src/utils/keys.js} +22 -44
  165. package/dist/sdk/src/utils/keys.test.d.ts +1 -0
  166. package/dist/sdk/src/utils/keys.test.js +81 -0
  167. package/dist/sdk/src/utils/roleData.d.ts +66 -0
  168. package/{packages/sdk/src/utils/roleData.ts → dist/sdk/src/utils/roleData.js} +36 -72
  169. package/dist/sdk/src/utils/roleData.test.d.ts +1 -0
  170. package/dist/sdk/src/utils/roleData.test.js +74 -0
  171. package/dist/sdk/src/utils/testScenarios.d.ts +33 -0
  172. package/dist/sdk/src/utils/testScenarios.js +85 -0
  173. package/dist/sdk/src/utils/testScenarios.test.d.ts +1 -0
  174. package/dist/sdk/src/utils/testScenarios.test.js +68 -0
  175. package/dist/sdk/src/utils/userOp.d.ts +78 -0
  176. package/dist/sdk/src/utils/userOp.js +195 -0
  177. package/dist/sdk/src/utils/userOp.test.d.ts +1 -0
  178. package/dist/sdk/src/utils/userOp.test.js +152 -0
  179. package/dist/tokens/src/index.d.ts +56 -0
  180. package/dist/tokens/src/index.js +230 -0
  181. package/examples/regression_test.d.ts +2 -0
  182. package/examples/regression_test.d.ts.map +1 -0
  183. package/examples/regression_test.js +89 -0
  184. package/examples/regression_test.js.map +1 -0
  185. package/package.json +40 -54
  186. package/scripts/v2_regression/00_validate_env.ts +28 -4
  187. package/scripts/v2_regression/01_setup_and_fund.ts +1 -1
  188. package/scripts/v2_regression/02_operator_onboarding.ts +16 -142
  189. package/scripts/v2_regression/03_community_registry.ts +24 -58
  190. package/scripts/v2_regression/04_enduser_flow.ts +16 -49
  191. package/scripts/v2_regression/05_admin_audit.ts +1 -1
  192. package/.eslintrc.js +0 -28
  193. package/.gitmodules +0 -9
  194. package/aastar-sdk.code-workspace +0 -14
  195. package/abis/BLSAggregator.json +0 -572
  196. package/abis/BLSValidator.json +0 -26
  197. package/abis/DVTValidator.json +0 -370
  198. package/abis/Eip7702Support.json +0 -24
  199. package/abis/EntryPoint.json +0 -1379
  200. package/abis/GToken.json +0 -479
  201. package/abis/GTokenStaking.json +0 -944
  202. package/abis/LegacyAccount.json +0 -625
  203. package/abis/MySBT.json +0 -1586
  204. package/abis/Paymaster.json +0 -1205
  205. package/abis/PaymasterFactory.json +0 -650
  206. package/abis/PaymasterV4_2.json +0 -1183
  207. package/abis/Registry.json +0 -1636
  208. package/abis/ReputationSystem.json +0 -477
  209. package/abis/SenderCreator.json +0 -99
  210. package/abis/Simple7702Account.json +0 -395
  211. package/abis/SimpleAccount.json +0 -625
  212. package/abis/SimpleAccountFactory.json +0 -108
  213. package/abis/SimpleAccountFactoryV08.json +0 -87
  214. package/abis/SimpleAccountV08.json +0 -557
  215. package/abis/SuperPaymaster.json +0 -1399
  216. package/abis/UserOperationLib.json +0 -57
  217. package/abis/aPNTs.json +0 -1173
  218. package/abis/xPNTsFactory.json +0 -728
  219. package/abis/xPNTsToken.json +0 -1173
  220. package/config/networks/README.md +0 -54
  221. package/config/networks/mainnet.env.example +0 -39
  222. package/config/networks/optimism-sepolia.env.example +0 -35
  223. package/config/networks/optimism.env.example +0 -36
  224. package/config/networks/sepolia.env.example +0 -36
  225. package/data/experiment_data.csv +0 -36
  226. package/data/industry_baseline_2025-12-23.json +0 -154
  227. package/data/industry_baseline_latest.json +0 -154
  228. package/docs/API_REFERENCE.md +0 -796
  229. package/docs/DAO_Mining_Distribution_Plan.md +0 -522
  230. package/docs/DOCUMENTATION_PLAN.md +0 -455
  231. package/docs/Plan.md +0 -266
  232. package/docs/Regression_Testing_Guide.md +0 -70
  233. package/docs/SDK_Optimization_Evaluation_Plan.md +0 -51
  234. package/docs/SEPOLIA_ENV_REFERENCE.md +0 -51
  235. package/docs/STAGE_3_SCENARIO_EXP_PLAN.md +0 -77
  236. package/docs/Script_Comparison_Report.md +0 -91
  237. package/docs/Sepolia_Latest_Deployment.md +0 -117
  238. package/docs/TEST_COVERAGE_MATRIX.md +0 -72
  239. package/docs/TODO_SDK_COVERAGE.md +0 -55
  240. package/docs/USER_CASE_DESIGN.md +0 -110
  241. package/docs/api/@aastar/account/README.md +0 -15
  242. package/docs/api/@aastar/account/classes/UserOpClient.md +0 -87
  243. package/docs/api/@aastar/account/functions/createEOAWalletClient.md +0 -21
  244. package/docs/api/@aastar/account/functions/getUserOpHash.md +0 -23
  245. package/docs/api/@aastar/account/functions/packUserOpLimits.md +0 -19
  246. package/docs/api/@aastar/account/functions/toSimpleSmartAccount.md +0 -83
  247. package/docs/api/@aastar/account/type-aliases/EOAWalletClient.md +0 -37
  248. package/docs/api/@aastar/account/type-aliases/SimpleSmartAccount.md +0 -39
  249. package/docs/api/@aastar/core/README.md +0 -136
  250. package/docs/api/@aastar/core/classes/BLSSigner.md +0 -147
  251. package/docs/api/@aastar/core/enumerations/NodeType.md +0 -33
  252. package/docs/api/@aastar/core/functions/aggregatorActions.md +0 -2714
  253. package/docs/api/@aastar/core/functions/createAAStarPublicClient.md +0 -3105
  254. package/docs/api/@aastar/core/functions/dvtActions.md +0 -2714
  255. package/docs/api/@aastar/core/functions/factoryActions.md +0 -2714
  256. package/docs/api/@aastar/core/functions/getAddressUrl.md +0 -32
  257. package/docs/api/@aastar/core/functions/getAllCommunityConfigs.md +0 -9
  258. package/docs/api/@aastar/core/functions/getAllV2Contracts.md +0 -20
  259. package/docs/api/@aastar/core/functions/getBlockExplorer.md +0 -26
  260. package/docs/api/@aastar/core/functions/getChainId.md +0 -26
  261. package/docs/api/@aastar/core/functions/getCommunities.md +0 -76
  262. package/docs/api/@aastar/core/functions/getCommunity.md +0 -32
  263. package/docs/api/@aastar/core/functions/getCommunityConfig.md +0 -15
  264. package/docs/api/@aastar/core/functions/getContract.md +0 -37
  265. package/docs/api/@aastar/core/functions/getContractNetworks.md +0 -18
  266. package/docs/api/@aastar/core/functions/getContracts.md +0 -178
  267. package/docs/api/@aastar/core/functions/getCoreContracts.md +0 -55
  268. package/docs/api/@aastar/core/functions/getDeploymentDate.md +0 -32
  269. package/docs/api/@aastar/core/functions/getEntryPoint.md +0 -25
  270. package/docs/api/@aastar/core/functions/getNetwork.md +0 -26
  271. package/docs/api/@aastar/core/functions/getPaymasterV4_1.md +0 -25
  272. package/docs/api/@aastar/core/functions/getRpcUrl.md +0 -25
  273. package/docs/api/@aastar/core/functions/getSimpleAccountFactory.md +0 -25
  274. package/docs/api/@aastar/core/functions/getSuperPaymasterV2.md +0 -25
  275. package/docs/api/@aastar/core/functions/getTestAccounts.md +0 -30
  276. package/docs/api/@aastar/core/functions/getTestTokenContracts.md +0 -38
  277. package/docs/api/@aastar/core/functions/getTokenContracts.md +0 -31
  278. package/docs/api/@aastar/core/functions/getTxUrl.md +0 -32
  279. package/docs/api/@aastar/core/functions/getV2ContractByAddress.md +0 -28
  280. package/docs/api/@aastar/core/functions/getV2ContractByName.md +0 -28
  281. package/docs/api/@aastar/core/functions/getV2ContractsByDate.md +0 -26
  282. package/docs/api/@aastar/core/functions/isContractNetworkSupported.md +0 -27
  283. package/docs/api/@aastar/core/functions/isRegisteredCommunity.md +0 -15
  284. package/docs/api/@aastar/core/functions/isV2Contract.md +0 -27
  285. package/docs/api/@aastar/core/functions/paymasterV4Actions.md +0 -2719
  286. package/docs/api/@aastar/core/functions/registryActions.md +0 -2720
  287. package/docs/api/@aastar/core/functions/reputationActions.md +0 -2720
  288. package/docs/api/@aastar/core/functions/sbtActions.md +0 -2720
  289. package/docs/api/@aastar/core/functions/stakingActions.md +0 -2720
  290. package/docs/api/@aastar/core/functions/superPaymasterActions.md +0 -2720
  291. package/docs/api/@aastar/core/functions/tokenActions.md +0 -2714
  292. package/docs/api/@aastar/core/interfaces/CommunityConfig.md +0 -81
  293. package/docs/api/@aastar/core/interfaces/ContractVersion.md +0 -63
  294. package/docs/api/@aastar/core/type-aliases/AggregatorActions.md +0 -79
  295. package/docs/api/@aastar/core/type-aliases/ContractCategory.md +0 -5
  296. package/docs/api/@aastar/core/type-aliases/ContractNetwork.md +0 -5
  297. package/docs/api/@aastar/core/type-aliases/DVTActions.md +0 -139
  298. package/docs/api/@aastar/core/type-aliases/FactoryActions.md +0 -99
  299. package/docs/api/@aastar/core/type-aliases/NetworkContracts.md +0 -5
  300. package/docs/api/@aastar/core/type-aliases/PaymasterV4Actions.md +0 -422
  301. package/docs/api/@aastar/core/type-aliases/RegistryActions.md +0 -263
  302. package/docs/api/@aastar/core/type-aliases/ReputationActions.md +0 -47
  303. package/docs/api/@aastar/core/type-aliases/RoleConfig.md +0 -83
  304. package/docs/api/@aastar/core/type-aliases/SBTActions.md +0 -203
  305. package/docs/api/@aastar/core/type-aliases/StakingActions.md +0 -179
  306. package/docs/api/@aastar/core/type-aliases/SuperPaymasterActions.md +0 -219
  307. package/docs/api/@aastar/core/type-aliases/SupportedNetwork.md +0 -3
  308. package/docs/api/@aastar/core/type-aliases/TokenActions.md +0 -151
  309. package/docs/api/@aastar/core/variables/AASTAR_COMMUNITY.md +0 -8
  310. package/docs/api/@aastar/core/variables/ALL_ADDRESSES.md +0 -71
  311. package/docs/api/@aastar/core/variables/BLSAggregatorABI.md +0 -3
  312. package/docs/api/@aastar/core/variables/BLSHelpers.md +0 -91
  313. package/docs/api/@aastar/core/variables/BPS_DENOMINATOR.md +0 -5
  314. package/docs/api/@aastar/core/variables/BRANDING.md +0 -67
  315. package/docs/api/@aastar/core/variables/BREAD_COMMUNITY.md +0 -8
  316. package/docs/api/@aastar/core/variables/COMMUNITIES.md +0 -5
  317. package/docs/api/@aastar/core/variables/COMMUNITY_OWNERS.md +0 -15
  318. package/docs/api/@aastar/core/variables/CONTRACTS.md +0 -163
  319. package/docs/api/@aastar/core/variables/CONTRACT_METADATA.md +0 -67
  320. package/docs/api/@aastar/core/variables/CORE_ADDRESSES.md +0 -35
  321. package/docs/api/@aastar/core/variables/DEFAULT_APNTS_PRICE_USD.md +0 -5
  322. package/docs/api/@aastar/core/variables/DEFAULT_GAS_TOKEN_MINT_AMOUNT.md +0 -5
  323. package/docs/api/@aastar/core/variables/DEFAULT_USDT_MINT_AMOUNT.md +0 -5
  324. package/docs/api/@aastar/core/variables/DVTValidatorABI.md +0 -3
  325. package/docs/api/@aastar/core/variables/EntryPointABI.md +0 -3
  326. package/docs/api/@aastar/core/variables/FAUCET_API_URL.md +0 -5
  327. package/docs/api/@aastar/core/variables/GTokenABI.md +0 -3
  328. package/docs/api/@aastar/core/variables/GTokenStakingABI.md +0 -3
  329. package/docs/api/@aastar/core/variables/LINKS.md +0 -33
  330. package/docs/api/@aastar/core/variables/MAX_SERVICE_FEE.md +0 -5
  331. package/docs/api/@aastar/core/variables/MONITORING_ADDRESSES.md +0 -15
  332. package/docs/api/@aastar/core/variables/MySBTABI.md +0 -3
  333. package/docs/api/@aastar/core/variables/NETWORKS.md +0 -79
  334. package/docs/api/@aastar/core/variables/NODE_STAKE_AMOUNTS.md +0 -31
  335. package/docs/api/@aastar/core/variables/OFFICIAL_ADDRESSES.md +0 -11
  336. package/docs/api/@aastar/core/variables/PAYMASTER_ADDRESSES.md +0 -15
  337. package/docs/api/@aastar/core/variables/PaymasterABI.md +0 -3
  338. package/docs/api/@aastar/core/variables/PaymasterFactoryABI.md +0 -3
  339. package/docs/api/@aastar/core/variables/PaymasterV4ABI.md +0 -3
  340. package/docs/api/@aastar/core/variables/ROLE_ANODE.md +0 -3
  341. package/docs/api/@aastar/core/variables/ROLE_COMMUNITY.md +0 -3
  342. package/docs/api/@aastar/core/variables/ROLE_ENDUSER.md +0 -5
  343. package/docs/api/@aastar/core/variables/ROLE_KMS.md +0 -3
  344. package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_AOA.md +0 -3
  345. package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_SUPER.md +0 -3
  346. package/docs/api/@aastar/core/variables/RegistryABI.md +0 -3
  347. package/docs/api/@aastar/core/variables/ReputationSystemABI.md +0 -3
  348. package/docs/api/@aastar/core/variables/ReputationSystemV3ABI.md +0 -3
  349. package/docs/api/@aastar/core/variables/SEPOLIA_CONTRACTS.md +0 -159
  350. package/docs/api/@aastar/core/variables/SEPOLIA_V2_VERSIONS.md +0 -67
  351. package/docs/api/@aastar/core/variables/SERVICE_FEE_RATE.md +0 -5
  352. package/docs/api/@aastar/core/variables/Simple7702AccountABI.md +0 -3
  353. package/docs/api/@aastar/core/variables/SimpleAccountABI.md +0 -3
  354. package/docs/api/@aastar/core/variables/SimpleAccountFactoryABI.md +0 -3
  355. package/docs/api/@aastar/core/variables/SimpleAccountFactoryV08ABI.md +0 -3
  356. package/docs/api/@aastar/core/variables/SimpleAccountV08ABI.md +0 -3
  357. package/docs/api/@aastar/core/variables/SuperPaymasterABI.md +0 -3
  358. package/docs/api/@aastar/core/variables/SuperPaymasterV3ABI.md +0 -3
  359. package/docs/api/@aastar/core/variables/TEST_ACCOUNT_ADDRESSES.md +0 -11
  360. package/docs/api/@aastar/core/variables/TEST_ACCOUNT_POOL_SIZE.md +0 -5
  361. package/docs/api/@aastar/core/variables/TEST_COMMUNITIES.md +0 -19
  362. package/docs/api/@aastar/core/variables/TEST_TOKEN_ADDRESSES.md +0 -19
  363. package/docs/api/@aastar/core/variables/TOKEN_ADDRESSES.md +0 -11
  364. package/docs/api/@aastar/core/variables/V2_SUMMARY.md +0 -39
  365. package/docs/api/@aastar/core/variables/xPNTsFactoryABI.md +0 -3
  366. package/docs/api/@aastar/core/variables/xPNTsTokenABI.md +0 -3
  367. package/docs/api/@aastar/paymaster/README.md +0 -14
  368. package/docs/api/@aastar/paymaster/classes/SuperPaymasterClient.md +0 -163
  369. package/docs/api/@aastar/paymaster/functions/checkEligibility.md +0 -28
  370. package/docs/api/@aastar/paymaster/functions/getPaymasterV4Middleware.md +0 -32
  371. package/docs/api/@aastar/paymaster/functions/getSuperPaymasterMiddleware.md +0 -32
  372. package/docs/api/@aastar/paymaster/type-aliases/PaymasterConfig.md +0 -35
  373. package/docs/api/@aastar/paymaster/type-aliases/PaymasterV4MiddlewareConfig.md +0 -35
  374. package/docs/api/@aastar/tokens/README.md +0 -3
  375. package/docs/api/@aastar/tokens/classes/FinanceClient.md +0 -8653
  376. package/docs/api/README.md +0 -6
  377. package/docs/examples/community-flow.md +0 -28
  378. package/docs/examples/enduser-flow.md +0 -24
  379. package/docs/examples/index.md +0 -18
  380. package/docs/examples/multi-chain.md +0 -31
  381. package/docs/examples/operator-flow.md +0 -28
  382. package/docs/guide/CLI_GUIDE.md +0 -65
  383. package/docs/guide/DOCUMENTATION_PLAN.md +0 -455
  384. package/docs/guide/Security-solution.md +0 -106
  385. package/docs/guide/TEST_COMMANDS.md +0 -320
  386. package/docs/guide/getting-started.md +0 -133
  387. package/docs/guide/installation.md +0 -40
  388. package/docs/guide/paper-data-collection.md +0 -69
  389. package/docs/guide/quick-start.md +0 -52
  390. package/docs/guide/task_breakdown.md +0 -121
  391. package/docs/old-solution.md +0 -1078
  392. package/docs/paper-data-collection.md +0 -69
  393. package/docs/technical_plan.md +0 -510
  394. package/docs/zh/examples/community-flow.md +0 -38
  395. package/docs/zh/examples/complete-workflow.md +0 -10
  396. package/docs/zh/examples/enduser-flow.md +0 -33
  397. package/docs/zh/examples/index.md +0 -18
  398. package/docs/zh/examples/multi-chain.md +0 -46
  399. package/docs/zh/examples/operator-flow.md +0 -37
  400. package/docs/zh/guide/CLI_GUIDE.md +0 -48
  401. package/docs/zh/guide/DOCUMENTATION_PLAN.md +0 -455
  402. package/docs/zh/guide/Plan.md +0 -266
  403. package/docs/zh/guide/SDK_Optimization_Evaluation_Plan.md +0 -51
  404. package/docs/zh/guide/Security-solution.md +0 -106
  405. package/docs/zh/guide/TEST_COMMANDS.md +0 -125
  406. package/docs/zh/guide/TEST_COVERAGE_MATRIX.md +0 -72
  407. package/docs/zh/guide/concepts/account-abstraction.md +0 -95
  408. package/docs/zh/guide/concepts/rainbow-bridge.md +0 -68
  409. package/docs/zh/guide/concepts/reputation.md +0 -95
  410. package/docs/zh/guide/concepts/superpaymaster.md +0 -141
  411. package/docs/zh/guide/getting-started.md +0 -133
  412. package/docs/zh/guide/installation.md +0 -107
  413. package/docs/zh/guide/old-solution.md +0 -1078
  414. package/docs/zh/guide/paper-data-collection.md +0 -69
  415. package/docs/zh/guide/quick-start.md +0 -134
  416. package/docs/zh/guide/sdk-readme.md +0 -253
  417. package/docs/zh/guide/task_breakdown.md +0 -76
  418. package/docs/zh/guide/technical_plan.md +0 -510
  419. package/docs/zh/guide/use-cases/community-management.md +0 -141
  420. package/docs/zh/guide/use-cases/gasless-transactions.md +0 -71
  421. package/docs/zh/guide/use-cases/operator-staking.md +0 -84
  422. package/docs/zh/guide/use-cases/yop.md +0 -72
  423. package/examples/sdk-demo/DEVELOPER_GUIDE.md +0 -159
  424. package/examples/sdk-demo/README.md +0 -30
  425. package/examples/sdk-demo/usage.ts +0 -137
  426. package/ext/aastar-shared-config/.env.example +0 -6
  427. package/ext/aastar-shared-config/.github/workflows/check-secrets.yml +0 -257
  428. package/ext/aastar-shared-config/AGENTS.md +0 -21
  429. package/ext/aastar-shared-config/CHANGELOG.md +0 -99
  430. package/ext/aastar-shared-config/LICENSE +0 -21
  431. package/ext/aastar-shared-config/QUICK_START.md +0 -215
  432. package/ext/aastar-shared-config/README.md +0 -412
  433. package/ext/aastar-shared-config/SHARED_CONFIG_SUMMARY.md +0 -273
  434. package/ext/aastar-shared-config/check-locker-status.mjs +0 -7
  435. package/ext/aastar-shared-config/favicon.ico +0 -0
  436. package/ext/aastar-shared-config/generate-comparison-table.sh +0 -67
  437. package/ext/aastar-shared-config/package.json +0 -46
  438. package/ext/aastar-shared-config/pnpm-lock.yaml +0 -1182
  439. package/ext/aastar-shared-config/src/abis/BLSAggregator.json +0 -1
  440. package/ext/aastar-shared-config/src/abis/DVTValidator.json +0 -1
  441. package/ext/aastar-shared-config/src/abis/GToken.json +0 -1
  442. package/ext/aastar-shared-config/src/abis/GTokenStaking.json +0 -1
  443. package/ext/aastar-shared-config/src/abis/MySBT.json +0 -1
  444. package/ext/aastar-shared-config/src/abis/PaymasterFactory.json +0 -1
  445. package/ext/aastar-shared-config/src/abis/PaymasterV4.json +0 -1098
  446. package/ext/aastar-shared-config/src/abis/Registry.json +0 -1
  447. package/ext/aastar-shared-config/src/abis/SimpleAccount.json +0 -557
  448. package/ext/aastar-shared-config/src/abis/SimpleAccountFactory.json +0 -87
  449. package/ext/aastar-shared-config/src/abis/SuperPaymasterV2.json +0 -1
  450. package/ext/aastar-shared-config/src/abis/index.ts +0 -45
  451. package/ext/aastar-shared-config/src/abis/xPNTsFactory.json +0 -1
  452. package/ext/aastar-shared-config/src/abis/xPNTsToken.json +0 -1
  453. package/ext/aastar-shared-config/src/branding.ts +0 -32
  454. package/ext/aastar-shared-config/src/communities.ts +0 -93
  455. package/ext/aastar-shared-config/src/constants.ts +0 -67
  456. package/ext/aastar-shared-config/src/contract-addresses.ts +0 -95
  457. package/ext/aastar-shared-config/src/contract-versions.ts +0 -374
  458. package/ext/aastar-shared-config/src/contracts.ts +0 -414
  459. package/ext/aastar-shared-config/src/index.ts +0 -14
  460. package/ext/aastar-shared-config/sync-abis.sh +0 -92
  461. package/ext/aastar-shared-config/sync-versions.mjs +0 -150
  462. package/ext/aastar-shared-config/tsconfig.json +0 -18
  463. package/ext/aastar-shared-config/tsup.config.ts +0 -10
  464. package/ext/aastar-shared-config/verify-all.sh +0 -207
  465. package/ext/aastar-shared-config/verify-contracts.sh +0 -85
  466. package/ext/aastar-shared-config/verify-mysbt-v243.mjs +0 -27
  467. package/ext/aastar-shared-config/verify-onchain-versions.mjs +0 -93
  468. package/ext/permissionless.js/.changeset/README.md +0 -8
  469. package/ext/permissionless.js/.changeset/config.json +0 -11
  470. package/ext/permissionless.js/.env-example +0 -2
  471. package/ext/permissionless.js/.github/actions/install-dependencies/action.yml +0 -17
  472. package/ext/permissionless.js/.github/dependabot.yaml +0 -10
  473. package/ext/permissionless.js/.github/workflows/canary.yml +0 -49
  474. package/ext/permissionless.js/.github/workflows/on-pull-request.yml +0 -61
  475. package/ext/permissionless.js/.github/workflows/on-push-to-main.yml +0 -59
  476. package/ext/permissionless.js/.github/workflows/prune-tags.yml +0 -92
  477. package/ext/permissionless.js/.github/workflows/verify.yml +0 -114
  478. package/ext/permissionless.js/.size-limit.json +0 -13
  479. package/ext/permissionless.js/LICENSE +0 -21
  480. package/ext/permissionless.js/assets/banner.png +0 -0
  481. package/ext/permissionless.js/biome.json +0 -46
  482. package/ext/permissionless.js/bun.lock +0 -2340
  483. package/ext/permissionless.js/bun.lockb +0 -0
  484. package/ext/permissionless.js/package.json +0 -82
  485. package/ext/permissionless.js/packages/mock-paymaster/CHANGELOG.md +0 -31
  486. package/ext/permissionless.js/packages/mock-paymaster/constants.ts +0 -84
  487. package/ext/permissionless.js/packages/mock-paymaster/helpers/abi.ts +0 -1048
  488. package/ext/permissionless.js/packages/mock-paymaster/helpers/erc20-utils.ts +0 -105
  489. package/ext/permissionless.js/packages/mock-paymaster/helpers/schema.ts +0 -307
  490. package/ext/permissionless.js/packages/mock-paymaster/helpers/utils.ts +0 -78
  491. package/ext/permissionless.js/packages/mock-paymaster/index.ts +0 -63
  492. package/ext/permissionless.js/packages/mock-paymaster/package.json +0 -33
  493. package/ext/permissionless.js/packages/mock-paymaster/relay.ts +0 -424
  494. package/ext/permissionless.js/packages/mock-paymaster/setup.ts +0 -163
  495. package/ext/permissionless.js/packages/mock-paymaster/singletonPaymasters.ts +0 -230
  496. package/ext/permissionless.js/packages/permissionless/CHANGELOG.md +0 -893
  497. package/ext/permissionless.js/packages/permissionless/README.md +0 -122
  498. package/ext/permissionless.js/packages/permissionless/accounts/biconomy/abi/BiconomySmartAccountAbi.ts +0 -128
  499. package/ext/permissionless.js/packages/permissionless/accounts/biconomy/toBiconomySmartAccount.ts +0 -374
  500. package/ext/permissionless.js/packages/permissionless/accounts/decodeCalls.test.ts +0 -505
  501. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/abi/EtherspotBootstrapAbi.ts +0 -94
  502. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/constants.ts +0 -27
  503. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/toEtherspotSmartAccount.ts +0 -369
  504. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/getInitMSAData.ts +0 -56
  505. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/getNonceKey.ts +0 -21
  506. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/wrapMessageHash.ts +0 -43
  507. package/ext/permissionless.js/packages/permissionless/accounts/index.ts +0 -86
  508. package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelAccountAbi.ts +0 -87
  509. package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3AccountAbi.ts +0 -813
  510. package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3FactoryAbi.ts +0 -12
  511. package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3MetaFactoryAbi.ts +0 -17
  512. package/ext/permissionless.js/packages/permissionless/accounts/kernel/constants.ts +0 -14
  513. package/ext/permissionless.js/packages/permissionless/accounts/kernel/to7702KernelSmartAccount.ts +0 -63
  514. package/ext/permissionless.js/packages/permissionless/accounts/kernel/toEcdsaKernelSmartAccount.ts +0 -62
  515. package/ext/permissionless.js/packages/permissionless/accounts/kernel/toKernelSmartAccount.ts +0 -984
  516. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/decodeCallData.ts +0 -43
  517. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/encodeCallData.ts +0 -57
  518. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/getNonceKey.ts +0 -33
  519. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/isKernelV2.ts +0 -6
  520. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/isWebAuthnAccount.ts +0 -8
  521. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/signMessage.ts +0 -115
  522. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/signTypedData.ts +0 -97
  523. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/wrapMessageHash.ts +0 -44
  524. package/ext/permissionless.js/packages/permissionless/accounts/light/toLightSmartAccount.ts +0 -496
  525. package/ext/permissionless.js/packages/permissionless/accounts/nexus/toNexusSmartAccount.ts +0 -351
  526. package/ext/permissionless.js/packages/permissionless/accounts/safe/index.ts +0 -14
  527. package/ext/permissionless.js/packages/permissionless/accounts/safe/signUserOperation.test.ts +0 -275
  528. package/ext/permissionless.js/packages/permissionless/accounts/safe/signUserOperation.ts +0 -316
  529. package/ext/permissionless.js/packages/permissionless/accounts/safe/toSafeSmartAccount.ts +0 -1980
  530. package/ext/permissionless.js/packages/permissionless/accounts/simple/to7702SimpleSmartAccount.ts +0 -51
  531. package/ext/permissionless.js/packages/permissionless/accounts/simple/toSimpleSmartAccount.ts +0 -585
  532. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/toThirdwebSmartAccount.ts +0 -221
  533. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/decodeCallData.ts +0 -87
  534. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/encodeCallData.ts +0 -81
  535. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/getAccountAddress.ts +0 -48
  536. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/getFactoryData.ts +0 -40
  537. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/signMessage.ts +0 -33
  538. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/signTypedData.ts +0 -67
  539. package/ext/permissionless.js/packages/permissionless/accounts/trust/toTrustSmartAccount.ts +0 -232
  540. package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/decodeCallData.ts +0 -87
  541. package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/encodeCallData.ts +0 -81
  542. package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/getFactoryData.ts +0 -51
  543. package/ext/permissionless.js/packages/permissionless/actions/erc7579/accountId.test.ts +0 -39
  544. package/ext/permissionless.js/packages/permissionless/actions/erc7579/accountId.ts +0 -93
  545. package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModule.test.ts +0 -216
  546. package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModule.ts +0 -99
  547. package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModules.test.ts +0 -237
  548. package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModules.ts +0 -96
  549. package/ext/permissionless.js/packages/permissionless/actions/erc7579/isModuleInstalled.test.ts +0 -72
  550. package/ext/permissionless.js/packages/permissionless/actions/erc7579/isModuleInstalled.ts +0 -132
  551. package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsExecutionMode.test.ts +0 -108
  552. package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsExecutionMode.ts +0 -158
  553. package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsModule.test.ts +0 -35
  554. package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsModule.ts +0 -120
  555. package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModule.test.ts +0 -129
  556. package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModule.ts +0 -98
  557. package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModules.test.ts +0 -117
  558. package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModules.ts +0 -87
  559. package/ext/permissionless.js/packages/permissionless/actions/erc7579.ts +0 -103
  560. package/ext/permissionless.js/packages/permissionless/actions/etherspot/getUserOperationGasPrice.ts +0 -32
  561. package/ext/permissionless.js/packages/permissionless/actions/etherspot.ts +0 -4
  562. package/ext/permissionless.js/packages/permissionless/actions/index.ts +0 -9
  563. package/ext/permissionless.js/packages/permissionless/actions/package.json +0 -6
  564. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/getCredentials.ts +0 -47
  565. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/startAuthentication.ts +0 -39
  566. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/startRegistration.ts +0 -126
  567. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/verifyAuthentication.ts +0 -142
  568. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/verifyRegistration.ts +0 -132
  569. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer.ts +0 -17
  570. package/ext/permissionless.js/packages/permissionless/actions/pimlico/estimateErc20PaymasterCost.ts +0 -102
  571. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getTokenQuotes.test.ts +0 -90
  572. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getTokenQuotes.ts +0 -77
  573. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationGasPrice.test.ts +0 -82
  574. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationGasPrice.ts +0 -67
  575. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationStatus.test.ts +0 -199
  576. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationStatus.ts +0 -49
  577. package/ext/permissionless.js/packages/permissionless/actions/pimlico/sendCompressedUserOperation.ts +0 -59
  578. package/ext/permissionless.js/packages/permissionless/actions/pimlico/sponsorUserOperation.test.ts +0 -236
  579. package/ext/permissionless.js/packages/permissionless/actions/pimlico/sponsorUserOperation.ts +0 -151
  580. package/ext/permissionless.js/packages/permissionless/actions/pimlico/validateSponsorshipPolicies.test.ts +0 -153
  581. package/ext/permissionless.js/packages/permissionless/actions/pimlico/validateSponsorshipPolicies.ts +0 -74
  582. package/ext/permissionless.js/packages/permissionless/actions/pimlico.ts +0 -38
  583. package/ext/permissionless.js/packages/permissionless/actions/public/getAccountNonce.test.ts +0 -96
  584. package/ext/permissionless.js/packages/permissionless/actions/public/getAccountNonce.ts +0 -75
  585. package/ext/permissionless.js/packages/permissionless/actions/public/getSenderAddress.test.ts +0 -154
  586. package/ext/permissionless.js/packages/permissionless/actions/public/getSenderAddress.ts +0 -129
  587. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/getCallsStatus.test.ts +0 -255
  588. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/getCallsStatus.ts +0 -91
  589. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendCalls.test.ts +0 -571
  590. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendCalls.ts +0 -38
  591. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendTransaction.test.ts +0 -416
  592. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendTransaction.ts +0 -133
  593. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signMessage.test.ts +0 -219
  594. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signMessage.ts +0 -73
  595. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signTypedData.test.ts +0 -228
  596. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signTypedData.ts +0 -157
  597. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/writeContract.ts +0 -70
  598. package/ext/permissionless.js/packages/permissionless/actions/smartAccount.ts +0 -7
  599. package/ext/permissionless.js/packages/permissionless/clients/createSmartAccountClient.ts +0 -181
  600. package/ext/permissionless.js/packages/permissionless/clients/decorators/passkeyServer.ts +0 -57
  601. package/ext/permissionless.js/packages/permissionless/clients/decorators/pimlico.ts +0 -189
  602. package/ext/permissionless.js/packages/permissionless/clients/decorators/smartAccount.ts +0 -350
  603. package/ext/permissionless.js/packages/permissionless/clients/index.ts +0 -2
  604. package/ext/permissionless.js/packages/permissionless/clients/passkeyServer.ts +0 -69
  605. package/ext/permissionless.js/packages/permissionless/clients/pimlico.ts +0 -124
  606. package/ext/permissionless.js/packages/permissionless/errors/index.ts +0 -17
  607. package/ext/permissionless.js/packages/permissionless/experimental/pimlico/index.ts +0 -1
  608. package/ext/permissionless.js/packages/permissionless/experimental/pimlico/utils/prepareUserOperationForErc20Paymaster.test.ts +0 -523
  609. package/ext/permissionless.js/packages/permissionless/experimental/pimlico/utils/prepareUserOperationForErc20Paymaster.ts +0 -369
  610. package/ext/permissionless.js/packages/permissionless/index.ts +0 -3
  611. package/ext/permissionless.js/packages/permissionless/package.json +0 -102
  612. package/ext/permissionless.js/packages/permissionless/types/etherspot.ts +0 -12
  613. package/ext/permissionless.js/packages/permissionless/types/package.json +0 -6
  614. package/ext/permissionless.js/packages/permissionless/types/passkeyServer.ts +0 -125
  615. package/ext/permissionless.js/packages/permissionless/types/pimlico.ts +0 -151
  616. package/ext/permissionless.js/packages/permissionless/utils/decode7579Calls.ts +0 -133
  617. package/ext/permissionless.js/packages/permissionless/utils/decodeNonce.test.ts +0 -40
  618. package/ext/permissionless.js/packages/permissionless/utils/decodeNonce.ts +0 -10
  619. package/ext/permissionless.js/packages/permissionless/utils/deepHexlify.test.ts +0 -57
  620. package/ext/permissionless.js/packages/permissionless/utils/deepHexlify.ts +0 -35
  621. package/ext/permissionless.js/packages/permissionless/utils/encode7579Calls.test.ts +0 -69
  622. package/ext/permissionless.js/packages/permissionless/utils/encode7579Calls.ts +0 -114
  623. package/ext/permissionless.js/packages/permissionless/utils/encodeInstallModule.ts +0 -91
  624. package/ext/permissionless.js/packages/permissionless/utils/encodeNonce.test.ts +0 -38
  625. package/ext/permissionless.js/packages/permissionless/utils/encodeNonce.ts +0 -8
  626. package/ext/permissionless.js/packages/permissionless/utils/encodeUninstallModule.ts +0 -88
  627. package/ext/permissionless.js/packages/permissionless/utils/erc20AllowanceOverride.test.ts +0 -59
  628. package/ext/permissionless.js/packages/permissionless/utils/erc20AllowanceOverride.ts +0 -66
  629. package/ext/permissionless.js/packages/permissionless/utils/erc20BalanceOverride.test.ts +0 -57
  630. package/ext/permissionless.js/packages/permissionless/utils/erc20BalanceOverride.ts +0 -49
  631. package/ext/permissionless.js/packages/permissionless/utils/getAddressFromInitCodeOrPaymasterAndData.test.ts +0 -31
  632. package/ext/permissionless.js/packages/permissionless/utils/getAddressFromInitCodeOrPaymasterAndData.ts +0 -13
  633. package/ext/permissionless.js/packages/permissionless/utils/getEstimationCallData.ts +0 -297
  634. package/ext/permissionless.js/packages/permissionless/utils/getPackedUserOperation.test.ts +0 -204
  635. package/ext/permissionless.js/packages/permissionless/utils/getPackedUserOperation.ts +0 -122
  636. package/ext/permissionless.js/packages/permissionless/utils/getRequiredPrefund.test.ts +0 -90
  637. package/ext/permissionless.js/packages/permissionless/utils/getRequiredPrefund.ts +0 -56
  638. package/ext/permissionless.js/packages/permissionless/utils/index.ts +0 -43
  639. package/ext/permissionless.js/packages/permissionless/utils/isSmartAccountDeployed.ts +0 -13
  640. package/ext/permissionless.js/packages/permissionless/utils/ox.ts +0 -48
  641. package/ext/permissionless.js/packages/permissionless/utils/toOwner.ts +0 -89
  642. package/ext/permissionless.js/packages/permissionless/vitest.config.ts +0 -31
  643. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/biconomy.ts +0 -22
  644. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/etherspot.ts +0 -12
  645. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/kernel.ts +0 -63
  646. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/light.ts +0 -10
  647. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/nexus.ts +0 -16
  648. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/safe.ts +0 -75
  649. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/simple.ts +0 -16
  650. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/thirdweb.ts +0 -7
  651. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/trust.ts +0 -26
  652. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/core.ts +0 -24
  653. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/index.ts +0 -10
  654. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/index.ts +0 -783
  655. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/instance.ts +0 -290
  656. package/ext/permissionless.js/packages/permissionless-test/src/testWithRpc.ts +0 -128
  657. package/ext/permissionless.js/packages/permissionless-test/src/types.ts +0 -12
  658. package/ext/permissionless.js/packages/permissionless-test/src/utils.ts +0 -1091
  659. package/ext/permissionless.js/packages/wagmi/CHANGELOG.md +0 -53
  660. package/ext/permissionless.js/packages/wagmi/README.md +0 -93
  661. package/ext/permissionless.js/packages/wagmi/context.ts +0 -22
  662. package/ext/permissionless.js/packages/wagmi/hooks/useAvailableCapabilities.ts +0 -43
  663. package/ext/permissionless.js/packages/wagmi/hooks/useSendTransaction.ts +0 -164
  664. package/ext/permissionless.js/packages/wagmi/hooks/useWaitForTransactionReceipt.ts +0 -427
  665. package/ext/permissionless.js/packages/wagmi/index.ts +0 -15
  666. package/ext/permissionless.js/packages/wagmi/package.json +0 -26
  667. package/ext/permissionless.js/packages/wagmi/utils/observe.ts +0 -76
  668. package/ext/permissionless.js/packages/wagmi-demo/README.md +0 -1
  669. package/ext/permissionless.js/packages/wagmi-demo/biome.json +0 -13
  670. package/ext/permissionless.js/packages/wagmi-demo/index.html +0 -12
  671. package/ext/permissionless.js/packages/wagmi-demo/package.json +0 -16
  672. package/ext/permissionless.js/packages/wagmi-demo/src/App.tsx +0 -98
  673. package/ext/permissionless.js/packages/wagmi-demo/src/PasskeyServerDemo.tsx +0 -286
  674. package/ext/permissionless.js/packages/wagmi-demo/src/PasskeysDemo.tsx +0 -457
  675. package/ext/permissionless.js/packages/wagmi-demo/src/index.css +0 -21
  676. package/ext/permissionless.js/packages/wagmi-demo/src/main.tsx +0 -275
  677. package/ext/permissionless.js/packages/wagmi-demo/src/vite-env.d.ts +0 -1
  678. package/ext/permissionless.js/packages/wagmi-demo/src/wagmi.ts +0 -33
  679. package/ext/permissionless.js/packages/wagmi-demo/tsconfig.json +0 -25
  680. package/ext/permissionless.js/packages/wagmi-demo/tsconfig.node.json +0 -12
  681. package/ext/permissionless.js/packages/wagmi-demo/vite.config.ts +0 -7
  682. package/ext/permissionless.js/tsconfig/tsconfig.base.json +0 -42
  683. package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.cjs.json +0 -11
  684. package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.esm.json +0 -9
  685. package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.json +0 -17
  686. package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.types.json +0 -13
  687. package/ext/permissionless.js/tsconfig/tsconfig.permissionless.cjs.json +0 -11
  688. package/ext/permissionless.js/tsconfig/tsconfig.permissionless.esm.json +0 -9
  689. package/ext/permissionless.js/tsconfig/tsconfig.permissionless.json +0 -18
  690. package/ext/permissionless.js/tsconfig/tsconfig.permissionless.types.json +0 -13
  691. package/ext/permissionless.js/tsconfig/tsconfig.wagmi.esm.json +0 -8
  692. package/ext/permissionless.js/tsconfig/tsconfig.wagmi.json +0 -19
  693. package/ext/permissionless.js/tsconfig/tsconfig.wagmi.types.json +0 -12
  694. package/extract_abis.sh +0 -140
  695. package/extract_addresses_to_env.sh +0 -67
  696. package/final_safe_harmonize.py +0 -77
  697. package/lib/SHARED_CONFIG_REFERENCE.md +0 -133
  698. package/lib/shared-config/.env.example +0 -6
  699. package/lib/shared-config/.github/workflows/check-secrets.yml +0 -257
  700. package/lib/shared-config/AGENTS.md +0 -21
  701. package/lib/shared-config/CHANGELOG.md +0 -99
  702. package/lib/shared-config/LICENSE +0 -21
  703. package/lib/shared-config/QUICK_START.md +0 -215
  704. package/lib/shared-config/README.md +0 -412
  705. package/lib/shared-config/SHARED_CONFIG_SUMMARY.md +0 -273
  706. package/lib/shared-config/check-locker-status.mjs +0 -7
  707. package/lib/shared-config/favicon.ico +0 -0
  708. package/lib/shared-config/generate-comparison-table.sh +0 -67
  709. package/lib/shared-config/package.json +0 -46
  710. package/lib/shared-config/pnpm-lock.yaml +0 -1182
  711. package/lib/shared-config/src/abis/BLSAggregator.json +0 -1
  712. package/lib/shared-config/src/abis/DVTValidator.json +0 -1
  713. package/lib/shared-config/src/abis/GToken.json +0 -1
  714. package/lib/shared-config/src/abis/GTokenStaking.json +0 -1
  715. package/lib/shared-config/src/abis/MySBT.json +0 -1
  716. package/lib/shared-config/src/abis/PaymasterFactory.json +0 -1
  717. package/lib/shared-config/src/abis/PaymasterV4.json +0 -1098
  718. package/lib/shared-config/src/abis/Registry.json +0 -1
  719. package/lib/shared-config/src/abis/SimpleAccount.json +0 -557
  720. package/lib/shared-config/src/abis/SimpleAccountFactory.json +0 -87
  721. package/lib/shared-config/src/abis/SuperPaymasterV2.json +0 -1
  722. package/lib/shared-config/src/abis/index.ts +0 -45
  723. package/lib/shared-config/src/abis/xPNTsFactory.json +0 -1
  724. package/lib/shared-config/src/abis/xPNTsToken.json +0 -1
  725. package/lib/shared-config/src/branding.ts +0 -32
  726. package/lib/shared-config/src/communities.ts +0 -93
  727. package/lib/shared-config/src/constants.ts +0 -67
  728. package/lib/shared-config/src/contract-addresses.ts +0 -95
  729. package/lib/shared-config/src/contract-versions.ts +0 -374
  730. package/lib/shared-config/src/contracts.ts +0 -414
  731. package/lib/shared-config/src/index.ts +0 -14
  732. package/lib/shared-config/src/networks.ts +0 -117
  733. package/lib/shared-config/sync-abis.sh +0 -92
  734. package/lib/shared-config/sync-versions.mjs +0 -150
  735. package/lib/shared-config/tsconfig.json +0 -18
  736. package/lib/shared-config/tsup.config.ts +0 -10
  737. package/lib/shared-config/verify-all.sh +0 -207
  738. package/lib/shared-config/verify-contracts.sh +0 -85
  739. package/lib/shared-config/verify-mysbt-v243.mjs +0 -27
  740. package/lib/shared-config/verify-onchain-versions.mjs +0 -93
  741. package/packages/account/package.json +0 -20
  742. package/packages/account/src/eoa.ts +0 -31
  743. package/packages/account/src/index.ts +0 -61
  744. package/packages/account/tsconfig.json +0 -12
  745. package/packages/analytics/package.json +0 -21
  746. package/packages/analytics/src/index.ts +0 -145
  747. package/packages/analytics/tsconfig.json +0 -16
  748. package/packages/community/package.json +0 -22
  749. package/packages/community/src/index.ts +0 -306
  750. package/packages/community/tsconfig.json +0 -8
  751. package/packages/core/package.json +0 -22
  752. package/packages/core/src/abis/BLSAggregator.json +0 -572
  753. package/packages/core/src/abis/BLSValidator.json +0 -26
  754. package/packages/core/src/abis/DVTValidator.json +0 -370
  755. package/packages/core/src/abis/Eip7702Support.json +0 -24
  756. package/packages/core/src/abis/EntryPoint.json +0 -1379
  757. package/packages/core/src/abis/GToken.json +0 -523
  758. package/packages/core/src/abis/GTokenStaking.json +0 -931
  759. package/packages/core/src/abis/LegacyAccount.json +0 -625
  760. package/packages/core/src/abis/MySBT.json +0 -1586
  761. package/packages/core/src/abis/Paymaster.json +0 -1205
  762. package/packages/core/src/abis/PaymasterFactory.json +0 -650
  763. package/packages/core/src/abis/PaymasterV4_2.json +0 -1183
  764. package/packages/core/src/abis/Registry.json +0 -1636
  765. package/packages/core/src/abis/ReputationSystem.json +0 -477
  766. package/packages/core/src/abis/SenderCreator.json +0 -99
  767. package/packages/core/src/abis/Simple7702Account.json +0 -395
  768. package/packages/core/src/abis/SimpleAccount.json +0 -625
  769. package/packages/core/src/abis/SimpleAccountFactory.json +0 -108
  770. package/packages/core/src/abis/SimpleAccountFactoryV08.json +0 -87
  771. package/packages/core/src/abis/SimpleAccountV08.json +0 -557
  772. package/packages/core/src/abis/SuperPaymaster.json +0 -1399
  773. package/packages/core/src/abis/UserOperationLib.json +0 -57
  774. package/packages/core/src/abis/aPNTs.json +0 -1173
  775. package/packages/core/src/abis/index.ts +0 -68
  776. package/packages/core/src/abis/xPNTsFactory.json +0 -728
  777. package/packages/core/src/abis/xPNTsToken.json +0 -1173
  778. package/packages/core/src/actions/aggregator.ts +0 -41
  779. package/packages/core/src/actions/dvt.ts +0 -53
  780. package/packages/core/src/actions/factory.ts +0 -41
  781. package/packages/core/src/actions/paymasterV4.ts +0 -263
  782. package/packages/core/src/actions/registry.ts +0 -120
  783. package/packages/core/src/actions/reputation.ts +0 -27
  784. package/packages/core/src/actions/sbt.ts +0 -97
  785. package/packages/core/src/actions/staking.ts +0 -79
  786. package/packages/core/src/actions/superPaymaster.ts +0 -117
  787. package/packages/core/src/actions/tokens.ts +0 -65
  788. package/packages/core/src/branding.ts +0 -32
  789. package/packages/core/src/clients.ts +0 -13
  790. package/packages/core/src/communities.ts +0 -93
  791. package/packages/core/src/constants.ts +0 -81
  792. package/packages/core/src/contract-addresses.ts +0 -101
  793. package/packages/core/src/contract-versions.ts +0 -374
  794. package/packages/core/src/contracts.ts +0 -414
  795. package/packages/core/src/networks.ts +0 -127
  796. package/packages/core/src/roles.ts +0 -244
  797. package/packages/core/src/utils.ts +0 -23
  798. package/packages/core/tsconfig.json +0 -12
  799. package/packages/dapp/package.json +0 -27
  800. package/packages/dapp/src/ui/components/EvaluationPanel.tsx +0 -40
  801. package/packages/dapp/tsconfig.json +0 -13
  802. package/packages/enduser/package.json +0 -21
  803. package/packages/enduser/src/index.ts +0 -138
  804. package/packages/enduser/tsconfig.json +0 -8
  805. package/packages/identity/package.json +0 -22
  806. package/packages/identity/src/index.ts +0 -82
  807. package/packages/identity/tsconfig.json +0 -12
  808. package/packages/operator/package.json +0 -21
  809. package/packages/operator/src/index.ts +0 -172
  810. package/packages/operator/tsconfig.json +0 -8
  811. package/packages/paymaster/package.json +0 -22
  812. package/packages/paymaster/src/V4/index.ts +0 -123
  813. package/packages/paymaster/tsconfig.json +0 -12
  814. package/packages/sdk/README.md +0 -150
  815. package/packages/sdk/aastar/package.json +0 -21
  816. package/packages/sdk/aastar/src/index.ts +0 -3
  817. package/packages/sdk/aastar/tsconfig.json +0 -8
  818. package/packages/sdk/package.json +0 -32
  819. package/packages/sdk/src/clients/admin.ts +0 -54
  820. package/packages/sdk/src/clients/community.ts +0 -403
  821. package/packages/sdk/src/clients/endUser.ts +0 -173
  822. package/packages/sdk/src/clients/operator.ts +0 -277
  823. package/packages/sdk/src/errors/decoder.ts +0 -48
  824. package/packages/sdk/src/index.ts +0 -20
  825. package/packages/sdk/src/utils/validation.ts +0 -356
  826. package/packages/sdk/tsconfig.json +0 -12
  827. package/packages/tokens/package.json +0 -22
  828. package/packages/tokens/src/index.ts +0 -245
  829. package/packages/tokens/tsconfig.json +0 -12
  830. package/pnpm-workspace.yaml +0 -2
  831. package/run_full_regression.sh +0 -215
  832. package/run_sdk_regression.sh +0 -213
  833. package/safe_harmonize.py +0 -107
  834. package/scripts/00_utils.ts +0 -59
  835. package/scripts/00_verify_phase1.ts +0 -130
  836. package/scripts/01_1_prep_gtoken.ts +0 -81
  837. package/scripts/01_2_register_sbt.ts +0 -88
  838. package/scripts/01_3_prep_tokens_paymaster.ts +0 -102
  839. package/scripts/01_prepare_all.ts +0 -271
  840. package/scripts/02_test_eoa.ts +0 -50
  841. package/scripts/03_test_standard_aa.ts +0 -173
  842. package/scripts/04_0_check_deploy.ts +0 -24
  843. package/scripts/04_1_check_allowance.ts +0 -44
  844. package/scripts/04_2_construct_verify.ts +0 -96
  845. package/scripts/04_3_verify_estimate.ts +0 -66
  846. package/scripts/04_4_verify_pack.ts +0 -74
  847. package/scripts/04_test_paymaster_v4.ts +0 -217
  848. package/scripts/05_1_deposit.ts +0 -48
  849. package/scripts/05_test_superpaymaster.ts +0 -380
  850. package/scripts/06_local_test_v3_admin.ts +0 -163
  851. package/scripts/06_local_test_v3_execution.ts +0 -132
  852. package/scripts/06_local_test_v3_full.ts +0 -490
  853. package/scripts/06_local_test_v3_funding.ts +0 -124
  854. package/scripts/06_local_test_v3_reputation.ts +0 -234
  855. package/scripts/07_local_test_v3_audit.ts +0 -181
  856. package/scripts/08_local_test_registry_lifecycle.ts +0 -382
  857. package/scripts/09_local_test_community_lifecycle.ts +0 -384
  858. package/scripts/09_local_test_community_simple.ts +0 -108
  859. package/scripts/09_scenario_bread_independent.ts +0 -247
  860. package/scripts/10_scenario_super_shared.ts +0 -196
  861. package/scripts/10_test_protocol_admin_full.ts +0 -173
  862. package/scripts/11_scenario_hacker_defense.ts +0 -104
  863. package/scripts/11_test_core_flows_full.ts +0 -279
  864. package/scripts/12_test_slash_mechanism.ts +0 -205
  865. package/scripts/12_test_slash_queries.ts +0 -83
  866. package/scripts/12_test_staking_exit.ts +0 -152
  867. package/scripts/12_test_staking_slash.ts +0 -301
  868. package/scripts/12_test_tier2_slash.ts +0 -139
  869. package/scripts/13_test_sbt_burn_linkage.ts +0 -266
  870. package/scripts/14_test_credit_redesign.ts +0 -266
  871. package/scripts/15_test_bls_full.ts +0 -125
  872. package/scripts/15_test_dvt_bls_full.ts +0 -133
  873. package/scripts/17_test_cross_role_collaboration.ts +0 -95
  874. package/scripts/18_sdk_e2e_verification.ts +0 -67
  875. package/scripts/18_test_dvt_sdk_flow.ts +0 -138
  876. package/scripts/18_test_lifecycle_completion.ts +0 -144
  877. package/scripts/19_sdk_experiment_runner.ts +0 -89
  878. package/scripts/19_sdk_experiment_runner.ts.backup +0 -391
  879. package/scripts/20_sdk_full_capability.ts +0 -95
  880. package/scripts/20_test_superpaymaster_new_apis.ts +0 -193
  881. package/scripts/21_test_paymasterv4_complete.ts +0 -341
  882. package/scripts/22_test_bls_signing.ts +0 -260
  883. package/scripts/23_test_middleware.ts +0 -197
  884. package/scripts/98_edge_reentrancy.ts +0 -85
  885. package/scripts/99_bug_hunting_fast.ts +0 -216
  886. package/scripts/collect_industry_baseline.ts +0 -236
  887. package/scripts/complete_env_config.ts +0 -97
  888. package/scripts/debug_account_c.ts +0 -43
  889. package/scripts/debug_bls.ts +0 -58
  890. package/scripts/debug_config_v036.ts +0 -13
  891. package/scripts/debug_contracts.ts +0 -2
  892. package/scripts/debug_env.ts +0 -69
  893. package/scripts/debug_find_paymaster.ts +0 -98
  894. package/scripts/debug_isolated_registration.ts +0 -256
  895. package/scripts/debug_paymaster_config.ts +0 -19
  896. package/scripts/debug_pim_addr.ts +0 -23
  897. package/scripts/debug_pm_status.ts +0 -51
  898. package/scripts/debug_registry.ts +0 -39
  899. package/scripts/debug_registry_setup.ts +0 -129
  900. package/scripts/debug_sanity.ts +0 -32
  901. package/scripts/debug_shared_config.ts +0 -10
  902. package/scripts/debug_token_compat.ts +0 -51
  903. package/scripts/debug_tokens.ts +0 -41
  904. package/scripts/debug_vcheck.ts +0 -33
  905. package/scripts/deploy_and_init_v3.sh +0 -134
  906. package/scripts/deploy_anvil_accounts.ts +0 -144
  907. package/scripts/deploy_paymaster_v4.ts +0 -139
  908. package/scripts/deploy_test_accounts.ts +0 -401
  909. package/scripts/experiment/stage3/SETUP_GUIDE.md +0 -258
  910. package/scripts/experiment/stage3/archived_scripts/00_token_distribution.ts +0 -78
  911. package/scripts/experiment/stage3/archived_scripts/01_dao_launch.ts +0 -96
  912. package/scripts/experiment/stage3/archived_scripts/01b_bread_launch.ts +0 -112
  913. package/scripts/experiment/stage3/archived_scripts/02_operator_setup.ts +0 -84
  914. package/scripts/experiment/stage3/archived_scripts/02b_operator_b_setup.ts +0 -104
  915. package/scripts/experiment/stage3/archived_scripts/02c_finalize_operators.ts +0 -86
  916. package/scripts/experiment/stage3/archived_scripts/02d_operator_collateral.ts +0 -89
  917. package/scripts/experiment/stage3/archived_scripts/03_user_onboarding.ts +0 -83
  918. package/scripts/experiment/stage3/archived_scripts/03b_deploy_aa_account.ts +0 -61
  919. package/scripts/experiment/stage3/archived_scripts/03c_aa_onboarding.ts +0 -104
  920. package/scripts/experiment/stage3/archived_scripts/03d_mint_points.ts +0 -60
  921. package/scripts/experiment/stage3/archived_scripts/04_benchmarking.ts +0 -100
  922. package/scripts/experiment/stage3/archived_scripts/05_multi_op_setup.ts +0 -149
  923. package/scripts/experiment/stage3/archived_scripts/README.md +0 -58
  924. package/scripts/experiment/stage3/archived_scripts/check_roles.ts +0 -29
  925. package/scripts/experiment/stage3/archived_scripts/decode_error.ts +0 -23
  926. package/scripts/experiment/stage3/archived_scripts/fund_user.ts +0 -51
  927. package/scripts/experiment/stage3/archived_scripts/gen_b_key.ts +0 -3
  928. package/scripts/experiment/stage3/archived_scripts/gen_keys.ts +0 -4
  929. package/scripts/experiment/stage3/archived_scripts/setup.ts +0 -105
  930. package/scripts/experiment/stage3/archived_scripts/test_key.ts +0 -4
  931. package/scripts/experiment/stage3/archived_scripts/verify_state.ts +0 -59
  932. package/scripts/experiment/stage3/refactored/00_token_distribution.ts +0 -46
  933. package/scripts/experiment/stage3/refactored/02_operator_setup.ts +0 -65
  934. package/scripts/experiment/stage3/refactored/03_user_onboarding.ts +0 -68
  935. package/scripts/experiment/stage3/refactored/05_multi_op_setup.ts +0 -63
  936. package/scripts/experiment/stage3/refactored/README.md +0 -71
  937. package/scripts/extract-docs.sh +0 -72
  938. package/scripts/generate_env_from_deployment.ts +0 -109
  939. package/scripts/publish_all.sh +0 -39
  940. package/scripts/quick_setup.ts +0 -124
  941. package/scripts/run_automated_experiment.sh +0 -121
  942. package/scripts/run_daily_experiment.ts +0 -70
  943. package/scripts/security_audit.sh +0 -172
  944. package/scripts/sync_config_to_env.ts +0 -88
  945. package/scripts/test_groups.ts +0 -267
  946. package/scripts/test_multi_community_anvil.ts +0 -276
  947. package/scripts/test_new_sdk_apis_sepolia.ts +0 -115
  948. package/scripts/test_sdk_join_idempotent.ts +0 -233
  949. package/scripts/test_simple_sepolia.ts +0 -44
  950. package/scripts/v2_regression/README.md +0 -161
  951. package/scripts/validate_environment.ts +0 -140
  952. package/sdk_experiment_data.csv +0 -2
  953. package/surgical_harmonize.py +0 -83
  954. package/tsconfig.json +0 -15
  955. package/typedoc.json +0 -25
  956. /package/{packages/core/src/crypto/index.ts → dist/core/src/crypto/index.d.ts} +0 -0
  957. /package/{packages/sdk/examples → examples}/config.json +0 -0
  958. /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;