@aastar/sdk 0.14.3 → 0.16.6

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 (712) hide show
  1. package/.eslintrc.cjs +30 -0
  2. package/README.md +148 -19
  3. package/abis/BLSAggregator.json +13 -13
  4. package/abis/BLSValidator.json +13 -0
  5. package/abis/DVTValidator.json +13 -0
  6. package/abis/GToken.json +57 -26
  7. package/abis/GTokenStaking.json +13 -39
  8. package/abis/MySBT.json +0 -39
  9. package/abis/Paymaster.json +0 -13
  10. package/abis/PaymasterFactory.json +26 -39
  11. package/abis/PaymasterV4_2.json +68 -58
  12. package/abis/Registry.json +57 -16
  13. package/abis/ReputationSystem.json +182 -0
  14. package/abis/SuperPaymaster.json +169 -0
  15. package/abis/aPNTs.json +13 -26
  16. package/abis/xPNTsFactory.json +13 -26
  17. package/abis/xPNTsToken.json +13 -26
  18. package/config.anvil.json +1 -0
  19. package/config.sepolia.json +1 -0
  20. package/config.test.json +27 -0
  21. package/docs/ABI_Change_Tracking_Workflow.md +41 -0
  22. package/docs/ABI_MAINTENANCE_PLAN.md +132 -0
  23. package/docs/API_REFERENCE.md +169 -9
  24. package/docs/Configuration_Sync.md +47 -0
  25. package/docs/DEMO_REFACTOR_PLAN.md +289 -0
  26. package/docs/ENV_SEPOLIA_UPDATE.md +68 -0
  27. package/docs/Faucet_Gasless_Plan.md +56 -0
  28. package/docs/L2_BUSINESS_CLIENTS_PLAN.md +394 -0
  29. package/docs/L4_Manual_Test_CheatSheet.md +215 -0
  30. package/docs/SDK_ABI_COVERAGE.md +839 -0
  31. package/docs/SDK_COVERAGE_STRATEGY.md +397 -0
  32. package/docs/SDK_REGRESSION_AND_API_PLAN.md +98 -0
  33. package/docs/SDK_STAGE3_PLAN.md +151 -0
  34. package/docs/STAGE3.md +191 -0
  35. package/docs/TESTER_GUIDE_GASLESS.md +663 -0
  36. package/docs/Verifier_L4_Gasless_Plan.md +454 -0
  37. package/docs/api/@aastar/account.md +235 -0
  38. package/docs/api/@aastar/analytics.md +219 -0
  39. package/docs/api/@aastar/core.md +26830 -0
  40. package/docs/api/@aastar/dapp.md +130 -0
  41. package/docs/api/@aastar/identity.md +482 -0
  42. package/docs/api/@aastar/paymaster.md +1387 -0
  43. package/docs/api/@aastar/sdk/README.md +155 -0
  44. package/docs/api/@aastar/sdk/node.md +4044 -0
  45. package/docs/api/@aastar/tokens.md +1971 -0
  46. package/docs/api/README.md +8 -4
  47. package/docs/changelog.md +99 -0
  48. package/docs/examples/README.md +18 -0
  49. package/docs/guide/concepts/account-abstraction.md +95 -0
  50. package/docs/guide/concepts/rainbow-bridge.md +68 -0
  51. package/docs/guide/concepts/reputation.md +95 -0
  52. package/docs/guide/concepts/superpaymaster.md +141 -0
  53. package/docs/guide/use-cases/community-management.md +141 -0
  54. package/docs/guide/use-cases/gasless-transactions.md +71 -0
  55. package/docs/guide/use-cases/operator-staking.md +84 -0
  56. package/docs/guide/use-cases/yop.md +72 -0
  57. package/docs/refactor/2026-01-13-221242-trae-refactor.md +224 -0
  58. package/docs/refactor/2026-01-13-audit-analysis.md +96 -0
  59. package/docs/refactor/2026-01-13-audit-report-v0.16.2.md +76 -0
  60. package/docs/refactor/2026-01-13-audit-report-v0.17.0.md +74 -0
  61. package/docs/refactor/2026-01-13-cursor-refactor.md +511 -0
  62. package/docs/refactor/2026-01-13-refactor-plan.md +88 -0
  63. package/docs/refactor/2026-01-13-refactor-response-plan.md +77 -0
  64. package/docs/refactor/2026-01-13-refactor-review.md +39 -0
  65. package/docs/refactor/2026-01-13-sdk-enhancement-plan.md +120 -0
  66. package/docs/refactor/2026-01-14-audit-response.md +242 -0
  67. package/docs/refactor/2026-01-14-audit-summary.md +133 -0
  68. package/docs/refactor/cursor-2026-01-13-14-00-audit-report.md +267 -0
  69. package/env.template +32 -0
  70. package/examples/l1-api-demo.ts +184 -0
  71. package/examples/l2-clients-demo.ts +138 -0
  72. package/examples/l3-user-onboarding.ts +74 -0
  73. package/examples/prepare-gasless.ts +89 -0
  74. package/examples/simple-gasless-demo.ts +80 -0
  75. package/examples/simple-superpaymaster-demo.ts +96 -0
  76. package/l4-setup.sh +11 -0
  77. package/package.json +12 -8
  78. package/packages/account/package.json +6 -3
  79. package/packages/account/src/accounts/simple.test.ts +93 -0
  80. package/packages/account/src/eoa.test.ts +37 -0
  81. package/packages/account/src/eoa.ts +4 -2
  82. package/packages/account/src/index.test.ts +34 -0
  83. package/packages/account/tsconfig.json +0 -1
  84. package/packages/analytics/package.json +12 -5
  85. package/packages/analytics/tsconfig.json +0 -5
  86. package/packages/core/package.json +16 -6
  87. package/packages/core/scripts/audit-abi-coverage.ts +165 -0
  88. package/packages/core/scripts/debug-regex.ts +36 -0
  89. package/packages/core/src/abis/.abi-hashes.json +26 -0
  90. package/packages/core/src/abis/BLSAggregator.json +686 -572
  91. package/packages/core/src/abis/BLSValidator.json +42 -26
  92. package/packages/core/src/abis/DVTValidator.json +368 -370
  93. package/packages/core/src/abis/EntryPoint.json +1382 -1379
  94. package/packages/core/src/abis/GToken.json +513 -523
  95. package/packages/core/src/abis/GTokenStaking.json +949 -931
  96. package/packages/core/src/abis/MySBT.json +1518 -1586
  97. package/packages/core/src/abis/Paymaster.json +1143 -1205
  98. package/packages/core/src/abis/PaymasterFactory.json +640 -650
  99. package/packages/core/src/abis/Registry.json +1942 -1636
  100. package/packages/core/src/abis/ReputationSystem.json +699 -477
  101. package/packages/core/src/abis/SimpleAccount.json +560 -625
  102. package/packages/core/src/abis/SimpleAccountFactory.json +111 -108
  103. package/packages/core/src/abis/SuperPaymaster.json +1781 -1399
  104. package/packages/core/src/abis/abi.config.json +24 -0
  105. package/packages/core/src/abis/index.ts +74 -38
  106. package/packages/core/src/abis/xPNTsFactory.json +718 -728
  107. package/packages/core/src/abis/xPNTsToken.json +1280 -1173
  108. package/packages/core/src/actions/StateValidator.test.ts +175 -0
  109. package/packages/{sdk/src/utils/validation.ts → core/src/actions/StateValidator.ts} +22 -125
  110. package/packages/core/src/actions/account.test.ts +155 -0
  111. package/packages/core/src/actions/account.ts +179 -0
  112. package/packages/core/src/actions/aggregator.test.ts +88 -0
  113. package/packages/core/src/actions/dvt.test.ts +124 -0
  114. package/packages/core/src/actions/entryPoint.test.ts +176 -0
  115. package/packages/core/src/actions/entryPoint.ts +266 -0
  116. package/packages/core/src/actions/factory.test.ts +250 -0
  117. package/packages/core/src/actions/factory.ts +586 -14
  118. package/packages/core/src/actions/faucet.test.ts +202 -0
  119. package/packages/core/src/actions/faucet.ts +421 -0
  120. package/packages/core/src/actions/gtokenExtended.test.ts +162 -0
  121. package/packages/core/src/actions/gtokenExtended.ts +153 -0
  122. package/packages/core/src/actions/index.ts +8 -0
  123. package/packages/core/src/actions/paymasterV4.test.ts +209 -0
  124. package/packages/core/src/actions/paymasterV4.ts +330 -138
  125. package/packages/core/src/actions/registry.test.ts +443 -0
  126. package/packages/core/src/actions/registry.ts +768 -28
  127. package/packages/core/src/actions/reputation.test.ts +225 -0
  128. package/packages/core/src/actions/reputation.ts +351 -0
  129. package/packages/core/src/actions/sbt.test.ts +322 -0
  130. package/packages/core/src/actions/sbt.ts +614 -30
  131. package/packages/core/src/actions/staking.test.ts +273 -0
  132. package/packages/core/src/actions/staking.ts +350 -8
  133. package/packages/core/src/actions/superPaymaster.test.ts +356 -0
  134. package/packages/core/src/actions/superPaymaster.ts +746 -35
  135. package/packages/core/src/actions/tokens.test.ts +60 -0
  136. package/packages/core/src/actions/tokens.ts +482 -20
  137. package/packages/core/src/actions/validators.test.ts +239 -0
  138. package/packages/core/src/actions/validators.ts +590 -0
  139. package/packages/core/src/clients/BaseClient.ts +78 -0
  140. package/packages/core/src/clients/types.ts +69 -0
  141. package/packages/core/src/clients.ts +1 -1
  142. package/packages/core/src/communities.ts +2 -2
  143. package/packages/core/src/config/ContractConfigManager.ts +63 -0
  144. package/packages/core/src/constants.ts +64 -0
  145. package/packages/core/src/contract-addresses.ts +42 -18
  146. package/packages/core/src/contracts.test.ts +58 -0
  147. package/packages/core/src/contracts.ts +2 -2
  148. package/packages/core/src/index.ts +4 -1
  149. package/packages/core/src/requirementChecker.test.ts +71 -0
  150. package/packages/core/src/requirementChecker.ts +1 -39
  151. package/packages/core/src/roles.test.ts +34 -0
  152. package/packages/core/src/roles.ts +61 -50
  153. package/packages/core/src/utils/validation.test.ts +50 -0
  154. package/packages/core/src/utils/validation.ts +66 -0
  155. package/packages/core/tsconfig.json +2 -2
  156. package/packages/core/vitest.config.ts +14 -0
  157. package/packages/dapp/package.json +6 -3
  158. package/packages/dapp/src/ui/hooks/useCreditScore.ts +1 -1
  159. package/packages/dapp/tsconfig.json +0 -1
  160. package/packages/identity/package.json +6 -3
  161. package/packages/identity/src/index.ts +49 -17
  162. package/packages/identity/tsconfig.json +0 -1
  163. package/packages/paymaster/package.json +6 -3
  164. package/packages/paymaster/src/SuperPaymaster/index.ts +2 -2
  165. package/packages/paymaster/src/V4/PaymasterClient.test.ts +114 -0
  166. package/packages/paymaster/src/V4/PaymasterClient.ts +385 -0
  167. package/packages/paymaster/src/V4/PaymasterOperator.test.ts +80 -0
  168. package/packages/paymaster/src/V4/PaymasterOperator.ts +282 -0
  169. package/packages/paymaster/src/V4/PaymasterUtils.test.ts +54 -0
  170. package/packages/paymaster/src/V4/PaymasterUtils.ts +185 -0
  171. package/packages/paymaster/src/V4/SuperPaymasterClient.test.ts +79 -0
  172. package/packages/paymaster/src/V4/SuperPaymasterClient.ts +123 -0
  173. package/packages/paymaster/src/V4/index.ts +4 -123
  174. package/packages/paymaster/tsconfig.json +0 -1
  175. package/packages/sdk/aastar/tsconfig.json +0 -1
  176. package/packages/sdk/coverage_output.txt +393 -0
  177. package/packages/sdk/coverage_output_final.txt +739 -0
  178. package/packages/sdk/coverage_output_final_v2.txt +722 -0
  179. package/packages/sdk/coverage_output_final_v3.txt +722 -0
  180. package/packages/sdk/package.json +14 -2
  181. package/packages/sdk/src/clients/ExperimentClient.test.ts +65 -0
  182. package/packages/sdk/src/clients/ExperimentClient.ts +80 -0
  183. package/packages/sdk/src/clients/admin.test.ts +98 -0
  184. package/packages/sdk/src/clients/admin.ts +108 -8
  185. package/packages/sdk/src/clients/clients.test.ts +104 -0
  186. package/packages/sdk/src/clients/community.test.ts +118 -0
  187. package/packages/sdk/src/clients/community.ts +175 -241
  188. package/packages/sdk/src/clients/endUser.test.ts +221 -0
  189. package/packages/sdk/src/clients/endUser.ts +430 -52
  190. package/packages/sdk/src/clients/operator.test.ts +162 -0
  191. package/packages/sdk/src/clients/operator.ts +168 -90
  192. package/packages/sdk/src/errors/AAStarError.test.ts +92 -0
  193. package/packages/sdk/src/errors/AAStarError.ts +70 -0
  194. package/packages/sdk/src/errors/decoder.test.ts +107 -0
  195. package/packages/sdk/src/errors/decoder.ts +84 -41
  196. package/packages/sdk/src/index.ts +11 -8
  197. package/packages/sdk/src/node/index.ts +8 -0
  198. package/packages/sdk/src/types/result.ts +29 -0
  199. package/packages/sdk/src/utils/errorHandler.test.ts +102 -0
  200. package/packages/sdk/src/utils/eventDecoder.test.ts +56 -0
  201. package/packages/sdk/src/utils/eventDecoder.ts +66 -0
  202. package/packages/sdk/src/utils/funding.test.ts +117 -0
  203. package/packages/sdk/src/utils/keys.test.ts +105 -0
  204. package/packages/sdk/src/utils/keys.ts +15 -0
  205. package/packages/sdk/src/utils/roleData.test.ts +85 -0
  206. package/packages/sdk/src/utils/roleData.ts +15 -26
  207. package/packages/sdk/src/utils/testScenarios.test.ts +79 -0
  208. package/packages/sdk/src/utils/testScenarios.ts +128 -0
  209. package/packages/sdk/src/utils/userOp.test.ts +190 -0
  210. package/packages/sdk/src/utils/userOp.ts +265 -0
  211. package/packages/sdk/tests/scenarios/01_onboard_community.ts +62 -0
  212. package/packages/sdk/tests/scenarios/02_onboard_operator.ts +109 -0
  213. package/packages/sdk/tests/scenarios/03_onboard_user.ts +53 -0
  214. package/packages/sdk/tests/scenarios/04_gasless_tx_flow.ts +68 -0
  215. package/packages/sdk/tests/scenarios/check_entrypoint.ts +19 -0
  216. package/packages/sdk/tests/scenarios/check_initialization.ts +65 -0
  217. package/packages/sdk/tests/scenarios/debug_addresses.ts +26 -0
  218. package/packages/sdk/tests/scenarios/diagnose_scenario4.ts +55 -0
  219. package/packages/sdk/tests/scenarios/setup.ts +33 -0
  220. package/packages/sdk/tests/scenarios/test_entrypoint_nonce.ts +46 -0
  221. package/packages/sdk/tsconfig.json +0 -1
  222. package/packages/tokens/package.json +6 -3
  223. package/packages/tokens/src/index.ts +92 -64
  224. package/packages/tokens/tsconfig.json +0 -1
  225. package/run_l4_gasless_regression.sh +79 -0
  226. package/run_sdk_regression.sh +200 -175
  227. package/scripts/00_utils.ts +1 -1
  228. package/scripts/01_prepare_all.ts +149 -198
  229. package/scripts/02_test_eoa.ts +27 -24
  230. package/scripts/03_test_standard_aa.ts +48 -153
  231. package/scripts/04_test_paymaster_v4.ts +41 -198
  232. package/scripts/05_test_superpaymaster.ts +40 -362
  233. package/scripts/09_local_test_community_lifecycle.ts +4 -3
  234. package/scripts/11_test_core_flows_full.ts +75 -197
  235. package/scripts/15_test_bls_full.ts +25 -2
  236. package/scripts/15_test_dvt_bls_full.ts +11 -4
  237. package/scripts/18_test_lifecycle_completion.ts +2 -2
  238. package/scripts/19_sdk_experiment_runner.ts +41 -16
  239. package/scripts/20_sdk_full_capability.ts +75 -77
  240. package/scripts/99_bug_hunting_fast.ts +55 -172
  241. package/scripts/analyze_abi_coverage.ts +169 -0
  242. package/scripts/check-admin.ts +95 -0
  243. package/scripts/check-jason-status.ts +184 -0
  244. package/scripts/check-roles.ts +36 -0
  245. package/scripts/clear-nonce.ts +47 -0
  246. package/scripts/complete-jack-superpaymaster.ts +171 -0
  247. package/scripts/debug-addr.ts +43 -0
  248. package/scripts/debug-community-registration.ts +92 -0
  249. package/scripts/debug-deploy-v4.ts +116 -0
  250. package/scripts/debug-paymaster.ts +127 -0
  251. package/scripts/debug-register-role.ts +101 -0
  252. package/scripts/debug-version.ts +71 -0
  253. package/scripts/deploy-sync.ts +104 -0
  254. package/scripts/deprecated/check_aa_entrypoint.ts +29 -0
  255. package/scripts/deprecated/check_paymaster_deposits.ts +45 -0
  256. package/scripts/deprecated/debug_aoa_function.ts +28 -0
  257. package/scripts/deprecated/debug_aoa_issue.ts +16 -0
  258. package/scripts/deprecated/debug_pimlico_aa23.ts +40 -0
  259. package/scripts/deprecated/debug_summary.ts +34 -0
  260. package/scripts/deprecated/deploy_v07_aa.ts +99 -0
  261. package/scripts/deprecated/fix_all_issues.ts +61 -0
  262. package/scripts/deprecated/fund_bpnts.ts +52 -0
  263. package/scripts/deprecated/get_factory_addresses.ts +28 -0
  264. package/scripts/deprecated/recheck_pim.ts +34 -0
  265. package/{extract_abis.sh → scripts/dev_tools/extract_abis.sh} +13 -2
  266. package/scripts/extract-docs.sh +78 -9
  267. package/scripts/fund-jack.ts +38 -0
  268. package/scripts/inspect-anni-token.ts +116 -0
  269. package/scripts/inspect-factory.ts +83 -0
  270. package/scripts/l4-paymasterv4-transfer-test.ts +228 -0
  271. package/scripts/l4-setup.ts +453 -0
  272. package/scripts/l4-state.json +80 -0
  273. package/scripts/phase1_verify_contracts.ts +207 -0
  274. package/scripts/pre_test_sync.ts +83 -0
  275. package/scripts/prepare_sepolia_resources.ts +154 -0
  276. package/scripts/query-jack-token.ts +22 -0
  277. package/scripts/quick_setup_account.ts +80 -0
  278. package/scripts/run_l4_gasless_regression.sh +32 -0
  279. package/scripts/run_sdk_experiment.sh +13 -0
  280. package/scripts/run_sdk_regression-v2.sh +38 -0
  281. package/scripts/sdk_regression_v2.ts +162 -0
  282. package/scripts/setup-bbq-community.ts +187 -0
  283. package/scripts/setup-dancing-community.ts +223 -0
  284. package/scripts/setup_test_accounts.ts +88 -0
  285. package/scripts/setup_test_environment.ts +147 -0
  286. package/scripts/sync_anvil_config.cjs +44 -0
  287. package/scripts/sync_contract_addresses.ts +186 -0
  288. package/scripts/sync_sepolia_config.cjs +90 -0
  289. package/scripts/sync_sepolia_config.mjs +74 -0
  290. package/scripts/test-brown-v4-deploy.ts +90 -0
  291. package/scripts/test-faucet-and-gasless.ts +170 -0
  292. package/scripts/test-jack-gasless.ts +119 -0
  293. package/scripts/test-jack-registration.ts +133 -0
  294. package/scripts/test-jack-superpaymaster-api.ts +112 -0
  295. package/scripts/test-kms-gasless.ts +138 -0
  296. package/scripts/test_groups.ts +63 -192
  297. package/scripts/test_new_sdk_apis_sepolia.ts +78 -0
  298. package/scripts/update_env_from_config.ts +83 -0
  299. package/scripts/v2_regression/00_validate_env.ts +28 -4
  300. package/scripts/v2_regression/02_operator_onboarding.ts +15 -141
  301. package/scripts/v2_regression/03_community_registry.ts +23 -57
  302. package/scripts/v2_regression/04_enduser_flow.ts +15 -48
  303. package/scripts/verify-tx-status.ts +81 -0
  304. package/scripts/verify_onchain_milestone.ts +114 -0
  305. package/scripts/verify_phase1.ts +66 -0
  306. package/scripts/verify_phase2.ts +66 -0
  307. package/sdk_experiment_data.csv +2 -0
  308. package/simple-test-paymaster.sh +2 -0
  309. package/simple-test-superpaymaster.sh +1 -0
  310. package/tests/l1-regression.test.ts +458 -0
  311. package/tests/l4-test-anni-gasless.ts +105 -0
  312. package/tests/l4-test-jason1-gasless.ts +150 -0
  313. package/tests/l4-test-jason2-gasless.ts +174 -0
  314. package/tests/l4-test-pmv4-deposit.ts +111 -0
  315. package/tests/l4-test-pmv4-gasless.ts +166 -0
  316. package/tests/l4-test-pmv4-submit.ts +223 -0
  317. package/tests/regression/README.md +168 -0
  318. package/tests/regression/config.ts +215 -0
  319. package/tests/regression/display-versions.ts +85 -0
  320. package/tests/regression/index.ts +67 -0
  321. package/tests/regression/l1-tests.ts +267 -0
  322. package/tests/regression/l2-tests.ts +171 -0
  323. package/tests/regression/l3-tests.ts +125 -0
  324. package/tests/regression/l4-gasless.ts +897 -0
  325. package/tests/regression/l4-runner.ts +52 -0
  326. package/tests/reports/phase1_contract_verification.md +45 -0
  327. package/tests/utils/contractVerifier.ts +237 -0
  328. package/tests/utils/userOpHelper.ts +194 -0
  329. package/tsconfig.json +32 -6
  330. package/typedoc.json +39 -5
  331. package/vitest.config.ts +16 -0
  332. package/.eslintrc.js +0 -28
  333. package/docs/STAGE_3_SCENARIO_EXP_PLAN.md +0 -77
  334. package/docs/api/@aastar/account/README.md +0 -15
  335. package/docs/api/@aastar/account/classes/UserOpClient.md +0 -87
  336. package/docs/api/@aastar/account/functions/createEOAWalletClient.md +0 -21
  337. package/docs/api/@aastar/account/functions/getUserOpHash.md +0 -23
  338. package/docs/api/@aastar/account/functions/packUserOpLimits.md +0 -19
  339. package/docs/api/@aastar/account/functions/toSimpleSmartAccount.md +0 -83
  340. package/docs/api/@aastar/account/type-aliases/EOAWalletClient.md +0 -37
  341. package/docs/api/@aastar/account/type-aliases/SimpleSmartAccount.md +0 -39
  342. package/docs/api/@aastar/core/README.md +0 -136
  343. package/docs/api/@aastar/core/classes/BLSSigner.md +0 -147
  344. package/docs/api/@aastar/core/enumerations/NodeType.md +0 -33
  345. package/docs/api/@aastar/core/functions/aggregatorActions.md +0 -2714
  346. package/docs/api/@aastar/core/functions/createAAStarPublicClient.md +0 -3105
  347. package/docs/api/@aastar/core/functions/dvtActions.md +0 -2714
  348. package/docs/api/@aastar/core/functions/factoryActions.md +0 -2714
  349. package/docs/api/@aastar/core/functions/getAddressUrl.md +0 -32
  350. package/docs/api/@aastar/core/functions/getAllCommunityConfigs.md +0 -9
  351. package/docs/api/@aastar/core/functions/getAllV2Contracts.md +0 -20
  352. package/docs/api/@aastar/core/functions/getBlockExplorer.md +0 -26
  353. package/docs/api/@aastar/core/functions/getChainId.md +0 -26
  354. package/docs/api/@aastar/core/functions/getCommunities.md +0 -76
  355. package/docs/api/@aastar/core/functions/getCommunity.md +0 -32
  356. package/docs/api/@aastar/core/functions/getCommunityConfig.md +0 -15
  357. package/docs/api/@aastar/core/functions/getContract.md +0 -37
  358. package/docs/api/@aastar/core/functions/getContractNetworks.md +0 -18
  359. package/docs/api/@aastar/core/functions/getContracts.md +0 -178
  360. package/docs/api/@aastar/core/functions/getCoreContracts.md +0 -55
  361. package/docs/api/@aastar/core/functions/getDeploymentDate.md +0 -32
  362. package/docs/api/@aastar/core/functions/getEntryPoint.md +0 -25
  363. package/docs/api/@aastar/core/functions/getNetwork.md +0 -26
  364. package/docs/api/@aastar/core/functions/getPaymasterV4_1.md +0 -25
  365. package/docs/api/@aastar/core/functions/getRpcUrl.md +0 -25
  366. package/docs/api/@aastar/core/functions/getSimpleAccountFactory.md +0 -25
  367. package/docs/api/@aastar/core/functions/getSuperPaymasterV2.md +0 -25
  368. package/docs/api/@aastar/core/functions/getTestAccounts.md +0 -30
  369. package/docs/api/@aastar/core/functions/getTestTokenContracts.md +0 -38
  370. package/docs/api/@aastar/core/functions/getTokenContracts.md +0 -31
  371. package/docs/api/@aastar/core/functions/getTxUrl.md +0 -32
  372. package/docs/api/@aastar/core/functions/getV2ContractByAddress.md +0 -28
  373. package/docs/api/@aastar/core/functions/getV2ContractByName.md +0 -28
  374. package/docs/api/@aastar/core/functions/getV2ContractsByDate.md +0 -26
  375. package/docs/api/@aastar/core/functions/isContractNetworkSupported.md +0 -27
  376. package/docs/api/@aastar/core/functions/isRegisteredCommunity.md +0 -15
  377. package/docs/api/@aastar/core/functions/isV2Contract.md +0 -27
  378. package/docs/api/@aastar/core/functions/paymasterV4Actions.md +0 -2719
  379. package/docs/api/@aastar/core/functions/registryActions.md +0 -2720
  380. package/docs/api/@aastar/core/functions/reputationActions.md +0 -2720
  381. package/docs/api/@aastar/core/functions/sbtActions.md +0 -2720
  382. package/docs/api/@aastar/core/functions/stakingActions.md +0 -2720
  383. package/docs/api/@aastar/core/functions/superPaymasterActions.md +0 -2720
  384. package/docs/api/@aastar/core/functions/tokenActions.md +0 -2714
  385. package/docs/api/@aastar/core/interfaces/CommunityConfig.md +0 -81
  386. package/docs/api/@aastar/core/interfaces/ContractVersion.md +0 -63
  387. package/docs/api/@aastar/core/type-aliases/AggregatorActions.md +0 -79
  388. package/docs/api/@aastar/core/type-aliases/ContractCategory.md +0 -5
  389. package/docs/api/@aastar/core/type-aliases/ContractNetwork.md +0 -5
  390. package/docs/api/@aastar/core/type-aliases/DVTActions.md +0 -139
  391. package/docs/api/@aastar/core/type-aliases/FactoryActions.md +0 -99
  392. package/docs/api/@aastar/core/type-aliases/NetworkContracts.md +0 -5
  393. package/docs/api/@aastar/core/type-aliases/PaymasterV4Actions.md +0 -422
  394. package/docs/api/@aastar/core/type-aliases/RegistryActions.md +0 -263
  395. package/docs/api/@aastar/core/type-aliases/ReputationActions.md +0 -47
  396. package/docs/api/@aastar/core/type-aliases/RoleConfig.md +0 -83
  397. package/docs/api/@aastar/core/type-aliases/SBTActions.md +0 -203
  398. package/docs/api/@aastar/core/type-aliases/StakingActions.md +0 -179
  399. package/docs/api/@aastar/core/type-aliases/SuperPaymasterActions.md +0 -219
  400. package/docs/api/@aastar/core/type-aliases/SupportedNetwork.md +0 -3
  401. package/docs/api/@aastar/core/type-aliases/TokenActions.md +0 -151
  402. package/docs/api/@aastar/core/variables/AASTAR_COMMUNITY.md +0 -8
  403. package/docs/api/@aastar/core/variables/ALL_ADDRESSES.md +0 -71
  404. package/docs/api/@aastar/core/variables/BLSAggregatorABI.md +0 -3
  405. package/docs/api/@aastar/core/variables/BLSHelpers.md +0 -91
  406. package/docs/api/@aastar/core/variables/BPS_DENOMINATOR.md +0 -5
  407. package/docs/api/@aastar/core/variables/BRANDING.md +0 -67
  408. package/docs/api/@aastar/core/variables/BREAD_COMMUNITY.md +0 -8
  409. package/docs/api/@aastar/core/variables/COMMUNITIES.md +0 -5
  410. package/docs/api/@aastar/core/variables/COMMUNITY_OWNERS.md +0 -15
  411. package/docs/api/@aastar/core/variables/CONTRACTS.md +0 -163
  412. package/docs/api/@aastar/core/variables/CONTRACT_METADATA.md +0 -67
  413. package/docs/api/@aastar/core/variables/CORE_ADDRESSES.md +0 -35
  414. package/docs/api/@aastar/core/variables/DEFAULT_APNTS_PRICE_USD.md +0 -5
  415. package/docs/api/@aastar/core/variables/DEFAULT_GAS_TOKEN_MINT_AMOUNT.md +0 -5
  416. package/docs/api/@aastar/core/variables/DEFAULT_USDT_MINT_AMOUNT.md +0 -5
  417. package/docs/api/@aastar/core/variables/DVTValidatorABI.md +0 -3
  418. package/docs/api/@aastar/core/variables/EntryPointABI.md +0 -3
  419. package/docs/api/@aastar/core/variables/FAUCET_API_URL.md +0 -5
  420. package/docs/api/@aastar/core/variables/GTokenABI.md +0 -3
  421. package/docs/api/@aastar/core/variables/GTokenStakingABI.md +0 -3
  422. package/docs/api/@aastar/core/variables/LINKS.md +0 -33
  423. package/docs/api/@aastar/core/variables/MAX_SERVICE_FEE.md +0 -5
  424. package/docs/api/@aastar/core/variables/MONITORING_ADDRESSES.md +0 -15
  425. package/docs/api/@aastar/core/variables/MySBTABI.md +0 -3
  426. package/docs/api/@aastar/core/variables/NETWORKS.md +0 -79
  427. package/docs/api/@aastar/core/variables/NODE_STAKE_AMOUNTS.md +0 -31
  428. package/docs/api/@aastar/core/variables/OFFICIAL_ADDRESSES.md +0 -11
  429. package/docs/api/@aastar/core/variables/PAYMASTER_ADDRESSES.md +0 -15
  430. package/docs/api/@aastar/core/variables/PaymasterABI.md +0 -3
  431. package/docs/api/@aastar/core/variables/PaymasterFactoryABI.md +0 -3
  432. package/docs/api/@aastar/core/variables/PaymasterV4ABI.md +0 -3
  433. package/docs/api/@aastar/core/variables/ROLE_ANODE.md +0 -3
  434. package/docs/api/@aastar/core/variables/ROLE_COMMUNITY.md +0 -3
  435. package/docs/api/@aastar/core/variables/ROLE_ENDUSER.md +0 -5
  436. package/docs/api/@aastar/core/variables/ROLE_KMS.md +0 -3
  437. package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_AOA.md +0 -3
  438. package/docs/api/@aastar/core/variables/ROLE_PAYMASTER_SUPER.md +0 -3
  439. package/docs/api/@aastar/core/variables/RegistryABI.md +0 -3
  440. package/docs/api/@aastar/core/variables/ReputationSystemABI.md +0 -3
  441. package/docs/api/@aastar/core/variables/ReputationSystemV3ABI.md +0 -3
  442. package/docs/api/@aastar/core/variables/SEPOLIA_CONTRACTS.md +0 -159
  443. package/docs/api/@aastar/core/variables/SEPOLIA_V2_VERSIONS.md +0 -67
  444. package/docs/api/@aastar/core/variables/SERVICE_FEE_RATE.md +0 -5
  445. package/docs/api/@aastar/core/variables/Simple7702AccountABI.md +0 -3
  446. package/docs/api/@aastar/core/variables/SimpleAccountABI.md +0 -3
  447. package/docs/api/@aastar/core/variables/SimpleAccountFactoryABI.md +0 -3
  448. package/docs/api/@aastar/core/variables/SimpleAccountFactoryV08ABI.md +0 -3
  449. package/docs/api/@aastar/core/variables/SimpleAccountV08ABI.md +0 -3
  450. package/docs/api/@aastar/core/variables/SuperPaymasterABI.md +0 -3
  451. package/docs/api/@aastar/core/variables/SuperPaymasterV3ABI.md +0 -3
  452. package/docs/api/@aastar/core/variables/TEST_ACCOUNT_ADDRESSES.md +0 -11
  453. package/docs/api/@aastar/core/variables/TEST_ACCOUNT_POOL_SIZE.md +0 -5
  454. package/docs/api/@aastar/core/variables/TEST_COMMUNITIES.md +0 -19
  455. package/docs/api/@aastar/core/variables/TEST_TOKEN_ADDRESSES.md +0 -19
  456. package/docs/api/@aastar/core/variables/TOKEN_ADDRESSES.md +0 -11
  457. package/docs/api/@aastar/core/variables/V2_SUMMARY.md +0 -39
  458. package/docs/api/@aastar/core/variables/xPNTsFactoryABI.md +0 -3
  459. package/docs/api/@aastar/core/variables/xPNTsTokenABI.md +0 -3
  460. package/docs/api/@aastar/paymaster/README.md +0 -14
  461. package/docs/api/@aastar/paymaster/classes/SuperPaymasterClient.md +0 -163
  462. package/docs/api/@aastar/paymaster/functions/checkEligibility.md +0 -28
  463. package/docs/api/@aastar/paymaster/functions/getPaymasterV4Middleware.md +0 -32
  464. package/docs/api/@aastar/paymaster/functions/getSuperPaymasterMiddleware.md +0 -32
  465. package/docs/api/@aastar/paymaster/type-aliases/PaymasterConfig.md +0 -35
  466. package/docs/api/@aastar/paymaster/type-aliases/PaymasterV4MiddlewareConfig.md +0 -35
  467. package/docs/api/@aastar/tokens/README.md +0 -3
  468. package/docs/api/@aastar/tokens/classes/FinanceClient.md +0 -8653
  469. package/ext/permissionless.js/.changeset/README.md +0 -8
  470. package/ext/permissionless.js/.changeset/config.json +0 -11
  471. package/ext/permissionless.js/.env-example +0 -2
  472. package/ext/permissionless.js/.github/actions/install-dependencies/action.yml +0 -17
  473. package/ext/permissionless.js/.github/dependabot.yaml +0 -10
  474. package/ext/permissionless.js/.github/workflows/canary.yml +0 -49
  475. package/ext/permissionless.js/.github/workflows/on-pull-request.yml +0 -61
  476. package/ext/permissionless.js/.github/workflows/on-push-to-main.yml +0 -59
  477. package/ext/permissionless.js/.github/workflows/prune-tags.yml +0 -92
  478. package/ext/permissionless.js/.github/workflows/verify.yml +0 -114
  479. package/ext/permissionless.js/.size-limit.json +0 -13
  480. package/ext/permissionless.js/LICENSE +0 -21
  481. package/ext/permissionless.js/assets/banner.png +0 -0
  482. package/ext/permissionless.js/biome.json +0 -46
  483. package/ext/permissionless.js/bun.lock +0 -2340
  484. package/ext/permissionless.js/bun.lockb +0 -0
  485. package/ext/permissionless.js/package.json +0 -82
  486. package/ext/permissionless.js/packages/mock-paymaster/CHANGELOG.md +0 -31
  487. package/ext/permissionless.js/packages/mock-paymaster/constants.ts +0 -84
  488. package/ext/permissionless.js/packages/mock-paymaster/helpers/abi.ts +0 -1048
  489. package/ext/permissionless.js/packages/mock-paymaster/helpers/erc20-utils.ts +0 -105
  490. package/ext/permissionless.js/packages/mock-paymaster/helpers/schema.ts +0 -307
  491. package/ext/permissionless.js/packages/mock-paymaster/helpers/utils.ts +0 -78
  492. package/ext/permissionless.js/packages/mock-paymaster/index.ts +0 -63
  493. package/ext/permissionless.js/packages/mock-paymaster/package.json +0 -33
  494. package/ext/permissionless.js/packages/mock-paymaster/relay.ts +0 -424
  495. package/ext/permissionless.js/packages/mock-paymaster/setup.ts +0 -163
  496. package/ext/permissionless.js/packages/mock-paymaster/singletonPaymasters.ts +0 -230
  497. package/ext/permissionless.js/packages/permissionless/CHANGELOG.md +0 -893
  498. package/ext/permissionless.js/packages/permissionless/README.md +0 -122
  499. package/ext/permissionless.js/packages/permissionless/accounts/biconomy/abi/BiconomySmartAccountAbi.ts +0 -128
  500. package/ext/permissionless.js/packages/permissionless/accounts/biconomy/toBiconomySmartAccount.ts +0 -374
  501. package/ext/permissionless.js/packages/permissionless/accounts/decodeCalls.test.ts +0 -505
  502. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/abi/EtherspotBootstrapAbi.ts +0 -94
  503. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/constants.ts +0 -27
  504. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/toEtherspotSmartAccount.ts +0 -369
  505. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/getInitMSAData.ts +0 -56
  506. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/getNonceKey.ts +0 -21
  507. package/ext/permissionless.js/packages/permissionless/accounts/etherspot/utils/wrapMessageHash.ts +0 -43
  508. package/ext/permissionless.js/packages/permissionless/accounts/index.ts +0 -86
  509. package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelAccountAbi.ts +0 -87
  510. package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3AccountAbi.ts +0 -813
  511. package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3FactoryAbi.ts +0 -12
  512. package/ext/permissionless.js/packages/permissionless/accounts/kernel/abi/KernelV3MetaFactoryAbi.ts +0 -17
  513. package/ext/permissionless.js/packages/permissionless/accounts/kernel/constants.ts +0 -14
  514. package/ext/permissionless.js/packages/permissionless/accounts/kernel/to7702KernelSmartAccount.ts +0 -63
  515. package/ext/permissionless.js/packages/permissionless/accounts/kernel/toEcdsaKernelSmartAccount.ts +0 -62
  516. package/ext/permissionless.js/packages/permissionless/accounts/kernel/toKernelSmartAccount.ts +0 -984
  517. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/decodeCallData.ts +0 -43
  518. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/encodeCallData.ts +0 -57
  519. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/getNonceKey.ts +0 -33
  520. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/isKernelV2.ts +0 -6
  521. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/isWebAuthnAccount.ts +0 -8
  522. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/signMessage.ts +0 -115
  523. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/signTypedData.ts +0 -97
  524. package/ext/permissionless.js/packages/permissionless/accounts/kernel/utils/wrapMessageHash.ts +0 -44
  525. package/ext/permissionless.js/packages/permissionless/accounts/light/toLightSmartAccount.ts +0 -496
  526. package/ext/permissionless.js/packages/permissionless/accounts/nexus/toNexusSmartAccount.ts +0 -351
  527. package/ext/permissionless.js/packages/permissionless/accounts/safe/index.ts +0 -14
  528. package/ext/permissionless.js/packages/permissionless/accounts/safe/signUserOperation.test.ts +0 -275
  529. package/ext/permissionless.js/packages/permissionless/accounts/safe/signUserOperation.ts +0 -316
  530. package/ext/permissionless.js/packages/permissionless/accounts/safe/toSafeSmartAccount.ts +0 -1980
  531. package/ext/permissionless.js/packages/permissionless/accounts/simple/to7702SimpleSmartAccount.ts +0 -51
  532. package/ext/permissionless.js/packages/permissionless/accounts/simple/toSimpleSmartAccount.ts +0 -585
  533. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/toThirdwebSmartAccount.ts +0 -221
  534. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/decodeCallData.ts +0 -87
  535. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/encodeCallData.ts +0 -81
  536. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/getAccountAddress.ts +0 -48
  537. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/getFactoryData.ts +0 -40
  538. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/signMessage.ts +0 -33
  539. package/ext/permissionless.js/packages/permissionless/accounts/thirdweb/utils/signTypedData.ts +0 -67
  540. package/ext/permissionless.js/packages/permissionless/accounts/trust/toTrustSmartAccount.ts +0 -232
  541. package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/decodeCallData.ts +0 -87
  542. package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/encodeCallData.ts +0 -81
  543. package/ext/permissionless.js/packages/permissionless/accounts/trust/utils/getFactoryData.ts +0 -51
  544. package/ext/permissionless.js/packages/permissionless/actions/erc7579/accountId.test.ts +0 -39
  545. package/ext/permissionless.js/packages/permissionless/actions/erc7579/accountId.ts +0 -93
  546. package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModule.test.ts +0 -216
  547. package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModule.ts +0 -99
  548. package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModules.test.ts +0 -237
  549. package/ext/permissionless.js/packages/permissionless/actions/erc7579/installModules.ts +0 -96
  550. package/ext/permissionless.js/packages/permissionless/actions/erc7579/isModuleInstalled.test.ts +0 -72
  551. package/ext/permissionless.js/packages/permissionless/actions/erc7579/isModuleInstalled.ts +0 -132
  552. package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsExecutionMode.test.ts +0 -108
  553. package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsExecutionMode.ts +0 -158
  554. package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsModule.test.ts +0 -35
  555. package/ext/permissionless.js/packages/permissionless/actions/erc7579/supportsModule.ts +0 -120
  556. package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModule.test.ts +0 -129
  557. package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModule.ts +0 -98
  558. package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModules.test.ts +0 -117
  559. package/ext/permissionless.js/packages/permissionless/actions/erc7579/uninstallModules.ts +0 -87
  560. package/ext/permissionless.js/packages/permissionless/actions/erc7579.ts +0 -103
  561. package/ext/permissionless.js/packages/permissionless/actions/etherspot/getUserOperationGasPrice.ts +0 -32
  562. package/ext/permissionless.js/packages/permissionless/actions/etherspot.ts +0 -4
  563. package/ext/permissionless.js/packages/permissionless/actions/index.ts +0 -9
  564. package/ext/permissionless.js/packages/permissionless/actions/package.json +0 -6
  565. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/getCredentials.ts +0 -47
  566. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/startAuthentication.ts +0 -39
  567. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/startRegistration.ts +0 -126
  568. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/verifyAuthentication.ts +0 -142
  569. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer/verifyRegistration.ts +0 -132
  570. package/ext/permissionless.js/packages/permissionless/actions/passkeyServer.ts +0 -17
  571. package/ext/permissionless.js/packages/permissionless/actions/pimlico/estimateErc20PaymasterCost.ts +0 -102
  572. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getTokenQuotes.test.ts +0 -90
  573. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getTokenQuotes.ts +0 -77
  574. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationGasPrice.test.ts +0 -82
  575. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationGasPrice.ts +0 -67
  576. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationStatus.test.ts +0 -199
  577. package/ext/permissionless.js/packages/permissionless/actions/pimlico/getUserOperationStatus.ts +0 -49
  578. package/ext/permissionless.js/packages/permissionless/actions/pimlico/sendCompressedUserOperation.ts +0 -59
  579. package/ext/permissionless.js/packages/permissionless/actions/pimlico/sponsorUserOperation.test.ts +0 -236
  580. package/ext/permissionless.js/packages/permissionless/actions/pimlico/sponsorUserOperation.ts +0 -151
  581. package/ext/permissionless.js/packages/permissionless/actions/pimlico/validateSponsorshipPolicies.test.ts +0 -153
  582. package/ext/permissionless.js/packages/permissionless/actions/pimlico/validateSponsorshipPolicies.ts +0 -74
  583. package/ext/permissionless.js/packages/permissionless/actions/pimlico.ts +0 -38
  584. package/ext/permissionless.js/packages/permissionless/actions/public/getAccountNonce.test.ts +0 -96
  585. package/ext/permissionless.js/packages/permissionless/actions/public/getAccountNonce.ts +0 -75
  586. package/ext/permissionless.js/packages/permissionless/actions/public/getSenderAddress.test.ts +0 -154
  587. package/ext/permissionless.js/packages/permissionless/actions/public/getSenderAddress.ts +0 -129
  588. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/getCallsStatus.test.ts +0 -255
  589. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/getCallsStatus.ts +0 -91
  590. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendCalls.test.ts +0 -571
  591. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendCalls.ts +0 -38
  592. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendTransaction.test.ts +0 -416
  593. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/sendTransaction.ts +0 -133
  594. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signMessage.test.ts +0 -219
  595. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signMessage.ts +0 -73
  596. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signTypedData.test.ts +0 -228
  597. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/signTypedData.ts +0 -157
  598. package/ext/permissionless.js/packages/permissionless/actions/smartAccount/writeContract.ts +0 -70
  599. package/ext/permissionless.js/packages/permissionless/actions/smartAccount.ts +0 -7
  600. package/ext/permissionless.js/packages/permissionless/clients/createSmartAccountClient.ts +0 -181
  601. package/ext/permissionless.js/packages/permissionless/clients/decorators/passkeyServer.ts +0 -57
  602. package/ext/permissionless.js/packages/permissionless/clients/decorators/pimlico.ts +0 -189
  603. package/ext/permissionless.js/packages/permissionless/clients/decorators/smartAccount.ts +0 -350
  604. package/ext/permissionless.js/packages/permissionless/clients/index.ts +0 -2
  605. package/ext/permissionless.js/packages/permissionless/clients/passkeyServer.ts +0 -69
  606. package/ext/permissionless.js/packages/permissionless/clients/pimlico.ts +0 -124
  607. package/ext/permissionless.js/packages/permissionless/errors/index.ts +0 -17
  608. package/ext/permissionless.js/packages/permissionless/experimental/pimlico/index.ts +0 -1
  609. package/ext/permissionless.js/packages/permissionless/experimental/pimlico/utils/prepareUserOperationForErc20Paymaster.test.ts +0 -523
  610. package/ext/permissionless.js/packages/permissionless/experimental/pimlico/utils/prepareUserOperationForErc20Paymaster.ts +0 -369
  611. package/ext/permissionless.js/packages/permissionless/index.ts +0 -3
  612. package/ext/permissionless.js/packages/permissionless/package.json +0 -102
  613. package/ext/permissionless.js/packages/permissionless/types/etherspot.ts +0 -12
  614. package/ext/permissionless.js/packages/permissionless/types/package.json +0 -6
  615. package/ext/permissionless.js/packages/permissionless/types/passkeyServer.ts +0 -125
  616. package/ext/permissionless.js/packages/permissionless/types/pimlico.ts +0 -151
  617. package/ext/permissionless.js/packages/permissionless/utils/decode7579Calls.ts +0 -133
  618. package/ext/permissionless.js/packages/permissionless/utils/decodeNonce.test.ts +0 -40
  619. package/ext/permissionless.js/packages/permissionless/utils/decodeNonce.ts +0 -10
  620. package/ext/permissionless.js/packages/permissionless/utils/deepHexlify.test.ts +0 -57
  621. package/ext/permissionless.js/packages/permissionless/utils/deepHexlify.ts +0 -35
  622. package/ext/permissionless.js/packages/permissionless/utils/encode7579Calls.test.ts +0 -69
  623. package/ext/permissionless.js/packages/permissionless/utils/encode7579Calls.ts +0 -114
  624. package/ext/permissionless.js/packages/permissionless/utils/encodeInstallModule.ts +0 -91
  625. package/ext/permissionless.js/packages/permissionless/utils/encodeNonce.test.ts +0 -38
  626. package/ext/permissionless.js/packages/permissionless/utils/encodeNonce.ts +0 -8
  627. package/ext/permissionless.js/packages/permissionless/utils/encodeUninstallModule.ts +0 -88
  628. package/ext/permissionless.js/packages/permissionless/utils/erc20AllowanceOverride.test.ts +0 -59
  629. package/ext/permissionless.js/packages/permissionless/utils/erc20AllowanceOverride.ts +0 -66
  630. package/ext/permissionless.js/packages/permissionless/utils/erc20BalanceOverride.test.ts +0 -57
  631. package/ext/permissionless.js/packages/permissionless/utils/erc20BalanceOverride.ts +0 -49
  632. package/ext/permissionless.js/packages/permissionless/utils/getAddressFromInitCodeOrPaymasterAndData.test.ts +0 -31
  633. package/ext/permissionless.js/packages/permissionless/utils/getAddressFromInitCodeOrPaymasterAndData.ts +0 -13
  634. package/ext/permissionless.js/packages/permissionless/utils/getEstimationCallData.ts +0 -297
  635. package/ext/permissionless.js/packages/permissionless/utils/getPackedUserOperation.test.ts +0 -204
  636. package/ext/permissionless.js/packages/permissionless/utils/getPackedUserOperation.ts +0 -122
  637. package/ext/permissionless.js/packages/permissionless/utils/getRequiredPrefund.test.ts +0 -90
  638. package/ext/permissionless.js/packages/permissionless/utils/getRequiredPrefund.ts +0 -56
  639. package/ext/permissionless.js/packages/permissionless/utils/index.ts +0 -43
  640. package/ext/permissionless.js/packages/permissionless/utils/isSmartAccountDeployed.ts +0 -13
  641. package/ext/permissionless.js/packages/permissionless/utils/ox.ts +0 -48
  642. package/ext/permissionless.js/packages/permissionless/utils/toOwner.ts +0 -89
  643. package/ext/permissionless.js/packages/permissionless/vitest.config.ts +0 -31
  644. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/biconomy.ts +0 -22
  645. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/etherspot.ts +0 -12
  646. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/kernel.ts +0 -63
  647. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/light.ts +0 -10
  648. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/nexus.ts +0 -16
  649. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/safe.ts +0 -75
  650. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/simple.ts +0 -16
  651. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/thirdweb.ts +0 -7
  652. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/accounts/trust.ts +0 -26
  653. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/core.ts +0 -24
  654. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/constants/index.ts +0 -10
  655. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/index.ts +0 -783
  656. package/ext/permissionless.js/packages/permissionless-test/mock-aa-infra/alto/instance.ts +0 -290
  657. package/ext/permissionless.js/packages/permissionless-test/src/testWithRpc.ts +0 -128
  658. package/ext/permissionless.js/packages/permissionless-test/src/types.ts +0 -12
  659. package/ext/permissionless.js/packages/permissionless-test/src/utils.ts +0 -1091
  660. package/ext/permissionless.js/packages/wagmi/CHANGELOG.md +0 -53
  661. package/ext/permissionless.js/packages/wagmi/README.md +0 -93
  662. package/ext/permissionless.js/packages/wagmi/context.ts +0 -22
  663. package/ext/permissionless.js/packages/wagmi/hooks/useAvailableCapabilities.ts +0 -43
  664. package/ext/permissionless.js/packages/wagmi/hooks/useSendTransaction.ts +0 -164
  665. package/ext/permissionless.js/packages/wagmi/hooks/useWaitForTransactionReceipt.ts +0 -427
  666. package/ext/permissionless.js/packages/wagmi/index.ts +0 -15
  667. package/ext/permissionless.js/packages/wagmi/package.json +0 -26
  668. package/ext/permissionless.js/packages/wagmi/utils/observe.ts +0 -76
  669. package/ext/permissionless.js/packages/wagmi-demo/README.md +0 -1
  670. package/ext/permissionless.js/packages/wagmi-demo/biome.json +0 -13
  671. package/ext/permissionless.js/packages/wagmi-demo/index.html +0 -12
  672. package/ext/permissionless.js/packages/wagmi-demo/package.json +0 -16
  673. package/ext/permissionless.js/packages/wagmi-demo/src/App.tsx +0 -98
  674. package/ext/permissionless.js/packages/wagmi-demo/src/PasskeyServerDemo.tsx +0 -286
  675. package/ext/permissionless.js/packages/wagmi-demo/src/PasskeysDemo.tsx +0 -457
  676. package/ext/permissionless.js/packages/wagmi-demo/src/index.css +0 -21
  677. package/ext/permissionless.js/packages/wagmi-demo/src/main.tsx +0 -275
  678. package/ext/permissionless.js/packages/wagmi-demo/src/vite-env.d.ts +0 -1
  679. package/ext/permissionless.js/packages/wagmi-demo/src/wagmi.ts +0 -33
  680. package/ext/permissionless.js/packages/wagmi-demo/tsconfig.json +0 -25
  681. package/ext/permissionless.js/packages/wagmi-demo/tsconfig.node.json +0 -12
  682. package/ext/permissionless.js/packages/wagmi-demo/vite.config.ts +0 -7
  683. package/ext/permissionless.js/tsconfig/tsconfig.base.json +0 -42
  684. package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.cjs.json +0 -11
  685. package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.esm.json +0 -9
  686. package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.json +0 -17
  687. package/ext/permissionless.js/tsconfig/tsconfig.mock-paymaster.types.json +0 -13
  688. package/ext/permissionless.js/tsconfig/tsconfig.permissionless.cjs.json +0 -11
  689. package/ext/permissionless.js/tsconfig/tsconfig.permissionless.esm.json +0 -9
  690. package/ext/permissionless.js/tsconfig/tsconfig.permissionless.json +0 -18
  691. package/ext/permissionless.js/tsconfig/tsconfig.permissionless.types.json +0 -13
  692. package/ext/permissionless.js/tsconfig/tsconfig.wagmi.esm.json +0 -8
  693. package/ext/permissionless.js/tsconfig/tsconfig.wagmi.json +0 -19
  694. package/ext/permissionless.js/tsconfig/tsconfig.wagmi.types.json +0 -12
  695. package/packages/community/package.json +0 -22
  696. package/packages/community/src/index.ts +0 -306
  697. package/packages/community/tsconfig.json +0 -8
  698. package/packages/core/src/abis/PaymasterV4_2.json +0 -1183
  699. package/packages/core/src/abis/aPNTs.json +0 -1173
  700. package/packages/core/src/contract-versions.ts +0 -374
  701. package/packages/enduser/package.json +0 -21
  702. package/packages/enduser/src/index.ts +0 -138
  703. package/packages/enduser/tsconfig.json +0 -8
  704. package/packages/operator/package.json +0 -21
  705. package/packages/operator/src/index.ts +0 -172
  706. package/packages/operator/tsconfig.json +0 -8
  707. package/run_full_regression.sh +0 -215
  708. package/scripts/validate_environment.ts +0 -140
  709. /package/{extract_addresses_to_env.sh → scripts/dev_tools/extract_addresses_to_env.sh} +0 -0
  710. /package/{final_safe_harmonize.py → scripts/dev_tools/final_safe_harmonize.py} +0 -0
  711. /package/{safe_harmonize.py → scripts/dev_tools/safe_harmonize.py} +0 -0
  712. /package/{surgical_harmonize.py → scripts/dev_tools/surgical_harmonize.py} +0 -0
@@ -1,22 +1,122 @@
1
- import { type Address, type PublicClient, type WalletClient, type Hex, type Hash, type Account } from 'viem';
1
+ import {
2
+ type Address,
3
+ type PublicClient,
4
+ type WalletClient,
5
+ type Hex,
6
+ type Hash,
7
+ type Account,
8
+ keccak256,
9
+ toHex
10
+ } from 'viem';
2
11
  import { RegistryABI } from '../abis/index.js';
3
12
  import type { RoleConfig } from '../roles.js';
4
13
 
5
14
  export type RegistryActions = {
6
- configureRole: (args: { roleId: Hex, config: RoleConfig, account?: Account | Address }) => Promise<Hash>;
7
- registerRole: (args: { roleId: Hex, user: Address, data: Hex, account?: Account | Address }) => Promise<Hash>;
8
- registerRoleSelf: (args: { roleId: Hex, data: Hex, account?: Account | Address }) => Promise<Hash>;
9
- hasRole: (args: { user: Address, roleId: Hex }) => Promise<boolean>;
10
- unRegisterRole: (args: { user: Address, roleId: Hex, account?: Account | Address }) => Promise<Hash>;
11
- getCreditLimit: (args: { user: Address }) => Promise<bigint>;
12
- getGlobalReputation: (args: { user: Address }) => Promise<bigint>;
13
- getRoleConfig: (args: { roleId: Hex }) => Promise<any>;
14
- setBLSAggregator: (args: { aggregator: Address, account?: Account | Address }) => Promise<Hash>;
15
- batchUpdateGlobalReputation: (args: { users: Address[], scores: bigint[], epoch: bigint, proof: Hex, account?: Account | Address }) => Promise<Hash>;
15
+ // Role Management
16
+ registryConfigureRole: (args: { roleId: Hex, config: RoleConfig, account?: Account | Address }) => Promise<Hash>;
17
+ registryRegisterRole: (args: { roleId: Hex, user: Address, data: Hex, account?: Account | Address }) => Promise<Hash>;
18
+ registryRegisterRoleSelf: (args: { roleId: Hex, data: Hex, account?: Account | Address }) => Promise<Hash>;
19
+ registryHasRole: (args: { user: Address, roleId: Hex }) => Promise<boolean>;
20
+ registryUnRegisterRole: (args: { user: Address, roleId: Hex, account?: Account | Address }) => Promise<Hash>;
21
+ registryGetRoleConfig: (args: { roleId: Hex }) => Promise<any>;
22
+ registrySetRoleLockDuration: (args: { roleId: Hex, duration: bigint, account?: Account | Address }) => Promise<Hash>;
23
+ registrySetRoleOwner: (args: { roleId: Hex, newOwner: Address, account?: Account | Address }) => Promise<Hash>;
24
+
25
+ registryIsCommunityMember: (args: { community: Address, user: Address }) => Promise<boolean>;
26
+ registryCommunityByName: (args: { name: string }) => Promise<Address>;
27
+ registryCommunityByENS: (args: { ensName: string }) => Promise<Address>;
28
+ registryCommunityByNameV3: (args: { name: string }) => Promise<Address>; // Alias for V3 compatibility
29
+ registryCommunityByENSV3: (args: { ensName: string }) => Promise<Address>; // Alias for V3 compatibility
30
+ registryProposedRoleNames: (args: { roleId: Hex }) => Promise<string>;
31
+ registryExecutedProposals: (args: { proposalId: bigint }) => Promise<boolean>;
32
+
33
+ // Registry Storage Getters
34
+ registryGetAccountCommunity: (args: { account: Address }) => Promise<Address>;
35
+ registryLastReputationEpoch: () => Promise<bigint>;
36
+ registryIsReputationSource: (args: { source: Address }) => Promise<boolean>;
37
+ registryRoleCounts: (args: { roleId: Hex }) => Promise<bigint>;
38
+ registryRoleMembers: (args: { roleId: Hex, index: bigint }) => Promise<Address>;
39
+ registryRoleMemberIndex: (args: { roleId: Hex, user: Address }) => Promise<bigint>;
40
+ registryRoleMetadata: (args: { roleId: Hex, user?: Address }) => Promise<Hex>;
41
+ registryRoleStakes: (args: { roleId: Hex, user: Address }) => Promise<bigint>;
42
+ registryRoleSBTTokenIds: (args: { roleId: Hex, user: Address }) => Promise<bigint>;
43
+ registryUserRoles: (args: { user: Address, index: bigint }) => Promise<Hex>;
44
+ registryUserRoleCount: (args: { user: Address }) => Promise<bigint>;
45
+
46
+ // Reputation
47
+ registryGlobalReputation: (args: { user: Address }) => Promise<bigint>;
48
+ registryBatchUpdateGlobalReputation: (args: { users: Address[], scores: bigint[], epoch: bigint, proof: Hex, account?: Account | Address }) => Promise<Hash>;
49
+
50
+ // Blacklist Management
51
+ registryUpdateOperatorBlacklist: (args: { operator: Address, users: Address[], statuses: boolean[], proof: Hex, account?: Account | Address }) => Promise<Hash>;
52
+ registryIsOperatorBlacklisted: (args: { operator: Address }) => Promise<boolean>;
53
+
54
+ // Contract References
55
+ registrySetBLSValidator: (args: { validator: Address, account?: Account | Address }) => Promise<Hash>;
56
+ registrySetBLSAggregator: (args: { aggregator: Address, account?: Account | Address }) => Promise<Hash>;
57
+ registrySetMySBT: (args: { sbt: Address, account?: Account | Address }) => Promise<Hash>;
58
+ registrySetSuperPaymaster: (args: { paymaster: Address, account?: Account | Address }) => Promise<Hash>;
59
+ registrySetStaking: (args: { staking: Address, account?: Account | Address }) => Promise<Hash>;
60
+ registrySetReputationSource: (args: { source: Address, account?: Account | Address }) => Promise<Hash>;
61
+ registryBlsValidator: () => Promise<Address>;
62
+ registryBlsAggregator: () => Promise<Address>;
63
+ registryMySBT: () => Promise<Address>;
64
+ registrySuperPaymaster: () => Promise<Address>;
65
+ registryStaking: () => Promise<Address>;
66
+ registryReputationSource: () => Promise<Address>;
67
+
68
+ // Admin
69
+ registryTransferOwnership: (args: { newOwner: Address, account?: Account | Address }) => Promise<Hash>;
70
+ registryOwner: () => Promise<Address>;
71
+ registryRenounceOwnership: (args: { account?: Account | Address }) => Promise<Hash>;
72
+
73
+ // View Functions
74
+ registryRoleConfigs: (args: { roleId: Hex }) => Promise<any>;
75
+ registryGetRoleMemberCount: (args: { roleId: Hex }) => Promise<bigint>; // Alias for getRoleUserCount
76
+ registryLevelThresholds: (args: { level: bigint }) => Promise<bigint>;
77
+
78
+ // Role Metadata & Members
79
+ registryRoleLockDurations: (args: { roleId: Hex }) => Promise<bigint>;
80
+ registryRoleOwners: (args: { roleId: Hex }) => Promise<Address>;
81
+ registryGetRoleMembers: (args: { roleId: Hex }) => Promise<Address[]>;
82
+ registryGetRoleUserCount: (args: { roleId: Hex }) => Promise<bigint>;
83
+ registryGetUserRoles: (args: { user: Address }) => Promise<Hex[]>;
84
+
85
+ registryExitRole: (args: { roleId: Hex, account?: Account | Address }) => Promise<Hash>;
86
+ registryCalculateExitFee: (args: { roleId: Hex, amount: bigint }) => Promise<bigint>;
87
+ registryAddLevelThreshold: (args: { threshold: bigint, account?: Account | Address }) => Promise<Hash>;
88
+ registrySetLevelThreshold: (args: { index: bigint, threshold: bigint, account?: Account | Address }) => Promise<Hash>;
89
+ registryAccountToUser: (args: { account: Address }) => Promise<Address>;
90
+
91
+ // Credit & Tiers
92
+ registryGetCreditLimit: (args: { user: Address }) => Promise<bigint>;
93
+ registrySetCreditTier: (args: { level: bigint, limit: bigint, account?: Account | Address }) => Promise<Hash>;
94
+ registryCreditTierConfig: (args: { level: bigint }) => Promise<bigint>;
95
+
96
+ // Role Admin (Restored)
97
+ registryAdminConfigureRole: (args: { roleId: Hex, minStake: bigint, entryBurn: bigint, exitFeePercent: number, minExitFee: bigint, account?: Account | Address }) => Promise<Hash>;
98
+ registryCreateNewRole: (args: { roleId: Hex, config: RoleConfig, roleOwner: Address, account?: Account | Address }) => Promise<Hash>;
99
+ registrySafeMintForRole: (args: { roleId: Hex, user: Address, data: Hex, account?: Account | Address }) => Promise<Hash>;
100
+
101
+ // Constants (Role IDs)
102
+ registryROLE_COMMUNITY: () => Promise<Hex>;
103
+ registryROLE_ENDUSER: () => Promise<Hex>;
104
+ registryROLE_PAYMASTER_SUPER: () => Promise<Hex>;
105
+ registryROLE_PAYMASTER_AOA: () => Promise<Hex>;
106
+ registryROLE_DVT: () => Promise<Hex>;
107
+ registryROLE_KMS: () => Promise<Hex>;
108
+ registryROLE_ANODE: () => Promise<Hex>;
109
+ registryGTOKEN_STAKING: () => Promise<Address>;
110
+ registryMYSBT: () => Promise<Address>;
111
+ registrySUPER_PAYMASTER: () => Promise<Address>;
112
+
113
+ // Version
114
+ registryVersion: () => Promise<string>;
16
115
  };
17
116
 
18
117
  export const registryActions = (address: Address) => (client: PublicClient | WalletClient): RegistryActions => ({
19
- async configureRole({ roleId, config, account }) {
118
+ // Role Management
119
+ async registryConfigureRole({ roleId, config, account }: { roleId: Hex, config: RoleConfig, account?: Account | Address }) {
20
120
  return (client as any).writeContract({
21
121
  address,
22
122
  abi: RegistryABI,
@@ -27,7 +127,7 @@ export const registryActions = (address: Address) => (client: PublicClient | Wal
27
127
  });
28
128
  },
29
129
 
30
- async registerRole({ roleId, user, data, account }) {
130
+ async registryRegisterRole({ roleId, user, data, account }: { roleId: Hex, user: Address, data: Hex, account?: Account | Address }) {
31
131
  return (client as any).writeContract({
32
132
  address,
33
133
  abi: RegistryABI,
@@ -38,7 +138,7 @@ export const registryActions = (address: Address) => (client: PublicClient | Wal
38
138
  });
39
139
  },
40
140
 
41
- async registerRoleSelf({ roleId, data, account }) {
141
+ async registryRegisterRoleSelf({ roleId, data, account }: { roleId: Hex, data: Hex, account?: Account | Address }) {
42
142
  return (client as any).writeContract({
43
143
  address,
44
144
  abi: RegistryABI,
@@ -49,7 +149,7 @@ export const registryActions = (address: Address) => (client: PublicClient | Wal
49
149
  });
50
150
  },
51
151
 
52
- async hasRole({ user, roleId }) {
152
+ async registryHasRole({ user, roleId }: { user: Address, roleId: Hex }) {
53
153
  return (client as PublicClient).readContract({
54
154
  address,
55
155
  abi: RegistryABI,
@@ -58,7 +158,7 @@ export const registryActions = (address: Address) => (client: PublicClient | Wal
58
158
  }) as Promise<boolean>;
59
159
  },
60
160
 
61
- async unRegisterRole({ user, roleId, account }) {
161
+ async registryUnRegisterRole({ user, roleId, account }: { user: Address, roleId: Hex, account?: Account | Address }) {
62
162
  return (client as any).writeContract({
63
163
  address,
64
164
  abi: RegistryABI,
@@ -69,16 +169,44 @@ export const registryActions = (address: Address) => (client: PublicClient | Wal
69
169
  });
70
170
  },
71
171
 
72
- async getCreditLimit({ user }) {
172
+ async registryGetRoleConfig({ roleId }: { roleId: Hex }) {
73
173
  return (client as PublicClient).readContract({
74
174
  address,
75
175
  abi: RegistryABI,
76
- functionName: 'getCreditLimit',
77
- args: [user]
78
- }) as Promise<bigint>;
176
+ functionName: 'getRoleConfig',
177
+ args: [roleId]
178
+ });
179
+ },
180
+
181
+ async registrySetRoleLockDuration({ roleId, duration, account }: { roleId: Hex, duration: bigint, account?: Account | Address }) {
182
+ return (client as any).writeContract({
183
+ address,
184
+ abi: RegistryABI,
185
+ functionName: 'setRoleLockDuration',
186
+ args: [roleId, duration],
187
+ account: account as any,
188
+ chain: (client as any).chain
189
+ });
79
190
  },
80
191
 
81
- async getGlobalReputation({ user }) {
192
+ async registrySetRoleOwner({ roleId, newOwner, account }: { roleId: Hex, newOwner: Address, account?: Account | Address }) {
193
+ return (client as any).writeContract({
194
+ address,
195
+ abi: RegistryABI,
196
+ functionName: 'setRoleOwner',
197
+ args: [roleId, newOwner],
198
+ account: account as any,
199
+ chain: (client as any).chain
200
+ });
201
+ },
202
+
203
+ async registryIsCommunityMember({ community, user }: { community: Address, user: Address }) {
204
+ const ROLE_ENDUSER = await (this as any).registryROLE_ENDUSER();
205
+ return (this as any).registryHasRole({ user, roleId: ROLE_ENDUSER });
206
+ },
207
+
208
+ // Credit & Reputation
209
+ async registryGlobalReputation({ user }: { user: Address }) {
82
210
  return (client as PublicClient).readContract({
83
211
  address,
84
212
  abi: RegistryABI,
@@ -87,16 +215,51 @@ export const registryActions = (address: Address) => (client: PublicClient | Wal
87
215
  }) as Promise<bigint>;
88
216
  },
89
217
 
90
- async getRoleConfig({ roleId }) {
218
+ async registryBatchUpdateGlobalReputation({ users, scores, epoch, proof, account }: { users: Address[], scores: bigint[], epoch: bigint, proof: Hex, account?: Account | Address }) {
219
+ return (client as any).writeContract({
220
+ address,
221
+ abi: RegistryABI,
222
+ functionName: 'batchUpdateGlobalReputation',
223
+ args: [users, scores, epoch, proof],
224
+ account: account as any,
225
+ chain: (client as any).chain
226
+ });
227
+ },
228
+
229
+ // Blacklist Management
230
+ async registryUpdateOperatorBlacklist({ operator, users, statuses, proof, account }: { operator: Address, users: Address[], statuses: boolean[], proof: Hex, account?: Account | Address }) {
231
+ return (client as any).writeContract({
232
+ address,
233
+ abi: RegistryABI,
234
+ functionName: 'updateOperatorBlacklist',
235
+ args: [operator, users, statuses, proof],
236
+ account: account as any,
237
+ chain: (client as any).chain
238
+ });
239
+ },
240
+
241
+ async registryIsOperatorBlacklisted({ operator }: { operator: Address }) {
91
242
  return (client as PublicClient).readContract({
92
243
  address,
93
244
  abi: RegistryABI,
94
- functionName: 'getRoleConfig',
95
- args: [roleId]
245
+ functionName: 'isOperatorBlacklisted',
246
+ args: [operator]
247
+ }) as Promise<boolean>;
248
+ },
249
+
250
+ // Contract References
251
+ async registrySetBLSValidator({ validator, account }: { validator: Address, account?: Account | Address }) {
252
+ return (client as any).writeContract({
253
+ address,
254
+ abi: RegistryABI,
255
+ functionName: 'setBLSValidator',
256
+ args: [validator],
257
+ account: account as any,
258
+ chain: (client as any).chain
96
259
  });
97
260
  },
98
261
 
99
- async setBLSAggregator({ aggregator, account }) {
262
+ async registrySetBLSAggregator({ aggregator, account }: { aggregator: Address, account?: Account | Address }) {
100
263
  return (client as any).writeContract({
101
264
  address,
102
265
  abi: RegistryABI,
@@ -107,14 +270,591 @@ export const registryActions = (address: Address) => (client: PublicClient | Wal
107
270
  });
108
271
  },
109
272
 
110
- async batchUpdateGlobalReputation({ users, scores, epoch, proof, account }) {
273
+ async registrySetMySBT({ sbt, account }: { sbt: Address, account?: Account | Address }) {
111
274
  return (client as any).writeContract({
112
275
  address,
113
276
  abi: RegistryABI,
114
- functionName: 'batchUpdateGlobalReputation',
115
- args: [users, scores, epoch, proof],
277
+ functionName: 'setMySBT',
278
+ args: [sbt],
279
+ account: account as any,
280
+ chain: (client as any).chain
281
+ });
282
+ },
283
+
284
+ async registrySetSuperPaymaster({ paymaster, account }: { paymaster: Address, account?: Account | Address }) {
285
+ return (client as any).writeContract({
286
+ address,
287
+ abi: RegistryABI,
288
+ functionName: 'setSuperPaymaster',
289
+ args: [paymaster],
290
+ account: account as any,
291
+ chain: (client as any).chain
292
+ });
293
+ },
294
+
295
+ async registrySetStaking({ staking, account }: { staking: Address, account?: Account | Address }) {
296
+ return (client as any).writeContract({
297
+ address,
298
+ abi: RegistryABI,
299
+ functionName: 'setStaking',
300
+ args: [staking],
301
+ account: account as any,
302
+ chain: (client as any).chain
303
+ });
304
+ },
305
+
306
+ async registrySetReputationSource({ source, account }: { source: Address, account?: Account | Address }) {
307
+ return (client as any).writeContract({
308
+ address,
309
+ abi: RegistryABI,
310
+ functionName: 'setReputationSource',
311
+ args: [source],
312
+ account: account as any,
313
+ chain: (client as any).chain
314
+ });
315
+ },
316
+
317
+ async registryBlsValidator() {
318
+ return (client as PublicClient).readContract({
319
+ address,
320
+ abi: RegistryABI,
321
+ functionName: 'blsValidator',
322
+ args: []
323
+ }) as Promise<Address>;
324
+ },
325
+
326
+ async registryBlsAggregator() {
327
+ return (client as PublicClient).readContract({
328
+ address,
329
+ abi: RegistryABI,
330
+ functionName: 'blsAggregator',
331
+ args: []
332
+ }) as Promise<Address>;
333
+ },
334
+
335
+ async registryMySBT() {
336
+ return (client as PublicClient).readContract({
337
+ address,
338
+ abi: RegistryABI,
339
+ functionName: 'MYSBT',
340
+ args: []
341
+ }) as Promise<Address>;
342
+ },
343
+
344
+ async registrySuperPaymaster() {
345
+ return (client as PublicClient).readContract({
346
+ address,
347
+ abi: RegistryABI,
348
+ functionName: 'SUPER_PAYMASTER',
349
+ args: []
350
+ }) as Promise<Address>;
351
+ },
352
+
353
+ async registryStaking() {
354
+ return (client as PublicClient).readContract({
355
+ address,
356
+ abi: RegistryABI,
357
+ functionName: 'GTOKEN_STAKING',
358
+ args: []
359
+ }) as Promise<Address>;
360
+ },
361
+
362
+ async registryReputationSource() {
363
+ return (client as PublicClient).readContract({
364
+ address,
365
+ abi: RegistryABI,
366
+ functionName: 'reputationSource',
367
+ args: []
368
+ }) as Promise<Address>;
369
+ },
370
+
371
+ // Admin
372
+ async registryTransferOwnership({ newOwner, account }: { newOwner: Address, account?: Account | Address }) {
373
+ return (client as any).writeContract({
374
+ address,
375
+ abi: RegistryABI,
376
+ functionName: 'transferOwnership',
377
+ args: [newOwner],
378
+ account: account as any,
379
+ chain: (client as any).chain
380
+ });
381
+ },
382
+
383
+ async registryOwner() {
384
+ return (client as PublicClient).readContract({
385
+ address,
386
+ abi: RegistryABI,
387
+ functionName: 'owner',
388
+ args: []
389
+ }) as Promise<Address>;
390
+ },
391
+
392
+ async registryRenounceOwnership({ account }: { account?: Account | Address }) {
393
+ return (client as any).writeContract({
394
+ address,
395
+ abi: RegistryABI,
396
+ functionName: 'renounceOwnership',
397
+ args: [],
398
+ account: account as any,
399
+ chain: (client as any).chain
400
+ });
401
+ },
402
+
403
+ // View Functions
404
+ async registryRoleConfigs({ roleId }: { roleId: Hex }) {
405
+ return (client as PublicClient).readContract({
406
+ address,
407
+ abi: RegistryABI,
408
+ functionName: 'roleConfigs',
409
+ args: [roleId]
410
+ });
411
+ },
412
+
413
+ async registryRoleCounts({ roleId }: { roleId: Hex }) {
414
+ return (client as PublicClient).readContract({
415
+ address,
416
+ abi: RegistryABI,
417
+ functionName: 'roleCounts',
418
+ args: [roleId]
419
+ }) as Promise<bigint>;
420
+ },
421
+
422
+ // Alias: getRoleMemberCount maps to contract's getRoleUserCount
423
+ async registryGetRoleMemberCount({ roleId }: { roleId: Hex }) {
424
+ return (client as PublicClient).readContract({
425
+ address,
426
+ abi: RegistryABI,
427
+ functionName: 'getRoleUserCount',
428
+ args: [roleId]
429
+ }) as Promise<bigint>;
430
+ },
431
+
432
+ async registryRoleMembers({ roleId, index }: { roleId: Hex, index: bigint }) {
433
+ return (client as PublicClient).readContract({
434
+ address,
435
+ abi: RegistryABI,
436
+ functionName: 'roleMembers',
437
+ args: [roleId, index]
438
+ }) as Promise<Address>;
439
+ },
440
+
441
+ async registryUserRoles({ user, index }: { user: Address, index: bigint }) {
442
+ return (client as PublicClient).readContract({
443
+ address,
444
+ abi: RegistryABI,
445
+ functionName: 'userRoles',
446
+ args: [user, index]
447
+ }) as Promise<Hex>;
448
+ },
449
+
450
+ async registryUserRoleCount({ user }: { user: Address }) {
451
+ return (client as PublicClient).readContract({
452
+ address,
453
+ abi: RegistryABI,
454
+ functionName: 'userRoleCount',
455
+ args: [user]
456
+ }) as Promise<bigint>;
457
+ },
458
+
459
+ async registryLevelThresholds({ level }: { level: bigint }) {
460
+ return (client as PublicClient).readContract({
461
+ address,
462
+ abi: RegistryABI,
463
+ functionName: 'levelThresholds',
464
+ args: [level]
465
+ }) as Promise<bigint>;
466
+ },
467
+
468
+ async registryExecutedProposals({ proposalId }: { proposalId: bigint }) {
469
+ return (client as PublicClient).readContract({
470
+ address,
471
+ abi: RegistryABI,
472
+ functionName: 'executedProposals',
473
+ args: [proposalId]
474
+ }) as Promise<boolean>;
475
+ },
476
+
477
+ // Community lookup functions
478
+ async registryCommunityByName({ name }: { name: string }) {
479
+ return (client as PublicClient).readContract({
480
+ address,
481
+ abi: RegistryABI,
482
+ functionName: 'communityByName',
483
+ args: [name]
484
+ }) as Promise<Address>;
485
+ },
486
+
487
+ async registryCommunityByENS({ ensName }: { ensName: string }) {
488
+ return (client as PublicClient).readContract({
489
+ address,
490
+ abi: RegistryABI,
491
+ functionName: 'communityByENS',
492
+ args: [ensName]
493
+ }) as Promise<Address>;
494
+ },
495
+
496
+ async registryCommunityByNameV3({ name }: { name: string }) {
497
+ return (this as any).registryCommunityByName({ name });
498
+ },
499
+
500
+ async registryCommunityByENSV3({ ensName }: { ensName: string }) {
501
+ return (this as any).registryCommunityByENS({ ensName });
502
+ },
503
+
504
+ async registryProposedRoleNames({ roleId }: { roleId: Hex }) {
505
+ return (client as PublicClient).readContract({
506
+ address,
507
+ abi: RegistryABI,
508
+ functionName: 'proposedRoleNames',
509
+ args: [roleId]
510
+ }) as Promise<string>;
511
+ },
512
+
513
+ // Role Metadata & Members
514
+ async registryRoleLockDurations({ roleId }: { roleId: Hex }) {
515
+ return (client as PublicClient).readContract({
516
+ address,
517
+ abi: RegistryABI,
518
+ functionName: 'roleLockDurations',
519
+ args: [roleId]
520
+ }) as Promise<bigint>;
521
+ },
522
+
523
+ async registryRoleMetadata({ roleId, user }: { roleId: Hex, user?: Address }) {
524
+ return (client as PublicClient).readContract({
525
+ address,
526
+ abi: RegistryABI,
527
+ functionName: 'roleMetadata',
528
+ args: user ? [roleId, user] : [roleId]
529
+ }) as Promise<Hex>;
530
+ },
531
+
532
+ async registryRoleStakes({ roleId, user }: { roleId: Hex, user: Address }) {
533
+ return (client as PublicClient).readContract({
534
+ address,
535
+ abi: RegistryABI,
536
+ functionName: 'roleStakes',
537
+ args: [roleId, user]
538
+ }) as Promise<bigint>;
539
+ },
540
+
541
+ async registryRoleSBTTokenIds({ roleId, user }: { roleId: Hex, user: Address }) {
542
+ return (client as PublicClient).readContract({
543
+ address,
544
+ abi: RegistryABI,
545
+ functionName: 'roleSBTTokenIds',
546
+ args: [roleId, user]
547
+ }) as Promise<bigint>;
548
+ },
549
+
550
+ async registryRoleOwners({ roleId }: { roleId: Hex }) {
551
+ return (client as PublicClient).readContract({
552
+ address,
553
+ abi: RegistryABI,
554
+ functionName: 'roleOwners',
555
+ args: [roleId]
556
+ }) as Promise<Address>;
557
+ },
558
+
559
+ async registryRoleMemberIndex({ roleId, user }: { roleId: Hex, user: Address }) {
560
+ return (client as PublicClient).readContract({
561
+ address,
562
+ abi: RegistryABI,
563
+ functionName: 'roleMemberIndex',
564
+ args: [roleId, user]
565
+ }) as Promise<bigint>;
566
+ },
567
+
568
+ async registryGetRoleMembers({ roleId }: { roleId: Hex }) {
569
+ return (client as PublicClient).readContract({
570
+ address,
571
+ abi: RegistryABI,
572
+ functionName: 'getRoleMembers',
573
+ args: [roleId]
574
+ }) as Promise<Address[]>;
575
+ },
576
+
577
+ async registryGetRoleUserCount({ roleId }: { roleId: Hex }) {
578
+ return (client as PublicClient).readContract({
579
+ address,
580
+ abi: RegistryABI,
581
+ functionName: 'getRoleUserCount',
582
+ args: [roleId]
583
+ }) as Promise<bigint>;
584
+ },
585
+
586
+ async registryGetUserRoles({ user }: { user: Address }) {
587
+ return (client as PublicClient).readContract({
588
+ address,
589
+ abi: RegistryABI,
590
+ functionName: 'getUserRoles',
591
+ args: [user]
592
+ }) as Promise<Hex[]>;
593
+ },
594
+
595
+ async registryExitRole({ roleId, account }: { roleId: Hex, account?: Account | Address }) {
596
+ return (client as any).writeContract({
597
+ address,
598
+ abi: RegistryABI,
599
+ functionName: 'exitRole',
600
+ args: [roleId],
601
+ account: account as any,
602
+ chain: (client as any).chain
603
+ });
604
+ },
605
+
606
+ async registryCalculateExitFee({ roleId, amount }: { roleId: Hex, amount: bigint }) {
607
+ return (client as PublicClient).readContract({
608
+ address,
609
+ abi: RegistryABI,
610
+ functionName: 'calculateExitFee',
611
+ args: [roleId, amount]
612
+ }) as Promise<bigint>;
613
+ },
614
+
615
+ async registryAddLevelThreshold({ threshold, account }: { threshold: bigint, account?: Account | Address }) {
616
+ return (client as any).writeContract({
617
+ address,
618
+ abi: RegistryABI,
619
+ functionName: 'addLevelThreshold',
620
+ args: [threshold],
621
+ account: account as any,
622
+ chain: (client as any).chain
623
+ });
624
+ },
625
+
626
+ async registrySetLevelThreshold({ index, threshold, account }: { index: bigint, threshold: bigint, account?: Account | Address }) {
627
+ return (client as any).writeContract({
628
+ address,
629
+ abi: RegistryABI,
630
+ functionName: 'setLevelThreshold',
631
+ args: [index, threshold],
632
+ account: account as any,
633
+ chain: (client as any).chain
634
+ });
635
+ },
636
+
637
+ async registryAccountToUser({ account: userAccount }: { account: Address }) {
638
+ return (client as PublicClient).readContract({
639
+ address,
640
+ abi: RegistryABI,
641
+ functionName: 'accountToUser',
642
+ args: [userAccount]
643
+ }) as Promise<Address>;
644
+ },
645
+
646
+ // Credit & Tiers
647
+ async registryGetCreditLimit({ user }: { user: Address }) {
648
+ return (client as PublicClient).readContract({
649
+ address,
650
+ abi: RegistryABI,
651
+ functionName: 'getCreditLimit',
652
+ args: [user]
653
+ }) as Promise<bigint>;
654
+ },
655
+
656
+ async registrySetCreditTier({ level, limit, account }: { level: bigint, limit: bigint, account?: Account | Address }) {
657
+ return (client as any).writeContract({
658
+ address,
659
+ abi: RegistryABI,
660
+ functionName: 'setCreditTier',
661
+ args: [level, limit],
662
+ account: account as any,
663
+ chain: (client as any).chain
664
+ });
665
+ },
666
+
667
+ async registryCreditTierConfig({ level }: { level: bigint }) {
668
+ return (client as PublicClient).readContract({
669
+ address,
670
+ abi: RegistryABI,
671
+ functionName: 'creditTierConfig',
672
+ args: [level]
673
+ }) as Promise<bigint>;
674
+ },
675
+
676
+ // Role Admin
677
+ async registryAdminConfigureRole({ roleId, minStake, entryBurn, exitFeePercent, minExitFee, account }: { roleId: Hex, minStake: bigint, entryBurn: bigint, exitFeePercent: number, minExitFee: bigint, account?: Account | Address }) {
678
+ return (client as any).writeContract({
679
+ address,
680
+ abi: RegistryABI,
681
+ functionName: 'adminConfigureRole',
682
+ args: [roleId, minStake, entryBurn, exitFeePercent, minExitFee],
683
+ account: account as any,
684
+ chain: (client as any).chain
685
+ });
686
+ },
687
+
688
+ async registryCreateNewRole({ roleId, config, roleOwner, account }: { roleId: Hex, config: RoleConfig, roleOwner: Address, account?: Account | Address }) {
689
+ return (client as any).writeContract({
690
+ address,
691
+ abi: RegistryABI,
692
+ functionName: 'createNewRole',
693
+ args: [roleId, config, roleOwner],
694
+ account: account as any,
695
+ chain: (client as any).chain
696
+ });
697
+ },
698
+
699
+ async registrySafeMintForRole({ roleId, user, data, account }: { roleId: Hex, user: Address, data: Hex, account?: Account | Address }) {
700
+ return (client as any).writeContract({
701
+ address,
702
+ abi: RegistryABI,
703
+ functionName: 'safeMintForRole',
704
+ args: [roleId, user, data],
116
705
  account: account as any,
117
706
  chain: (client as any).chain
118
707
  });
708
+ },
709
+
710
+ async registryGetAccountCommunity({ account: userAccount }: { account: Address }) {
711
+ // Check if user has COMMUNITY role
712
+ const COMMUNITY_ROLE_ID = '0x0000000000000000000000000000000000000000000000000000000000000002' as Hex;
713
+ const hasRole = await (client as PublicClient).readContract({
714
+ address,
715
+ abi: RegistryABI,
716
+ functionName: 'hasRole',
717
+ args: [userAccount, COMMUNITY_ROLE_ID]
718
+ }) as boolean;
719
+
720
+ if (!hasRole) {
721
+ return '0x0000000000000000000000000000000000000000' as Address;
722
+ }
723
+
724
+ // Get role data which contains the community token address
725
+ const roleData = await (client as PublicClient).readContract({
726
+ address,
727
+ abi: RegistryABI,
728
+ functionName: 'getRoleData',
729
+ args: [userAccount, COMMUNITY_ROLE_ID]
730
+ }) as Hex;
731
+
732
+ // Parse community token from role data (first 20 bytes after removing 0x)
733
+ if (!roleData || roleData === '0x') {
734
+ return '0x0000000000000000000000000000000000000000' as Address;
735
+ }
736
+
737
+ // Community token is at bytes 0-19 of roleData
738
+ const tokenAddress = ('0x' + roleData.slice(2, 42)) as Address;
739
+ return tokenAddress;
740
+ },
741
+
742
+ // Constants (Role IDs)
743
+ async registryROLE_COMMUNITY() {
744
+ return (client as PublicClient).readContract({
745
+ address,
746
+ abi: RegistryABI,
747
+ functionName: 'ROLE_COMMUNITY',
748
+ args: []
749
+ }) as Promise<Hex>;
750
+ },
751
+
752
+ async registryROLE_ENDUSER() {
753
+ return (client as PublicClient).readContract({
754
+ address,
755
+ abi: RegistryABI,
756
+ functionName: 'ROLE_ENDUSER',
757
+ args: []
758
+ }) as Promise<Hex>;
759
+ },
760
+
761
+ async registryROLE_PAYMASTER_SUPER() {
762
+ return (client as PublicClient).readContract({
763
+ address,
764
+ abi: RegistryABI,
765
+ functionName: 'ROLE_PAYMASTER_SUPER',
766
+ args: []
767
+ }) as Promise<Hex>;
768
+ },
769
+
770
+ async registryROLE_PAYMASTER_AOA() {
771
+ return (client as PublicClient).readContract({
772
+ address,
773
+ abi: RegistryABI,
774
+ functionName: 'ROLE_PAYMASTER_AOA',
775
+ args: []
776
+ }) as Promise<Hex>;
777
+ },
778
+
779
+ async registryROLE_DVT() {
780
+ return (client as PublicClient).readContract({
781
+ address,
782
+ abi: RegistryABI,
783
+ functionName: 'ROLE_DVT',
784
+ args: []
785
+ }) as Promise<Hex>;
786
+ },
787
+
788
+ async registryROLE_KMS() {
789
+ return (client as PublicClient).readContract({
790
+ address,
791
+ abi: RegistryABI,
792
+ functionName: 'ROLE_KMS',
793
+ args: []
794
+ }) as Promise<Hex>;
795
+ },
796
+
797
+ async registryROLE_ANODE() {
798
+ return (client as PublicClient).readContract({
799
+ address,
800
+ abi: RegistryABI,
801
+ functionName: 'ROLE_ANODE',
802
+ args: []
803
+ }) as Promise<Hex>;
804
+ },
805
+
806
+ async registryGTOKEN_STAKING() {
807
+ return (client as PublicClient).readContract({
808
+ address,
809
+ abi: RegistryABI,
810
+ functionName: 'GTOKEN_STAKING',
811
+ args: []
812
+ }) as Promise<Address>;
813
+ },
814
+
815
+ async registryMYSBT() {
816
+ return (client as PublicClient).readContract({
817
+ address,
818
+ abi: RegistryABI,
819
+ functionName: 'MYSBT',
820
+ args: []
821
+ }) as Promise<Address>;
822
+ },
823
+
824
+ async registrySUPER_PAYMASTER() {
825
+ return (client as PublicClient).readContract({
826
+ address,
827
+ abi: RegistryABI,
828
+ functionName: 'SUPER_PAYMASTER',
829
+ args: []
830
+ }) as Promise<Address>;
831
+ },
832
+
833
+ async registryIsReputationSource({ source }: { source: Address }) {
834
+ return (client as PublicClient).readContract({
835
+ address,
836
+ abi: RegistryABI,
837
+ functionName: 'isReputationSource',
838
+ args: [source]
839
+ }) as Promise<boolean>;
840
+ },
841
+
842
+ async registryLastReputationEpoch() {
843
+ return (client as PublicClient).readContract({
844
+ address,
845
+ abi: RegistryABI,
846
+ functionName: 'lastReputationEpoch',
847
+ args: []
848
+ }) as Promise<bigint>;
849
+ },
850
+
851
+ // Version
852
+ async registryVersion() {
853
+ return (client as PublicClient).readContract({
854
+ address,
855
+ abi: RegistryABI,
856
+ functionName: 'version',
857
+ args: []
858
+ }) as Promise<string>;
119
859
  }
120
860
  });