rise-wallet 0.1.4-beta.1 → 0.2.28

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 (486) hide show
  1. package/README.md +64 -34
  2. package/dist/cli/Dialog.d.ts +34 -0
  3. package/dist/cli/Dialog.js +60 -0
  4. package/dist/cli/Dialog.js.map +1 -0
  5. package/dist/cli/Messenger.d.ts +7 -0
  6. package/dist/cli/Messenger.js +123 -0
  7. package/dist/cli/Messenger.js.map +1 -0
  8. package/dist/cli/bin/commands-D7N5ucUu.js +50 -0
  9. package/dist/cli/bin/index.js +9 -0
  10. package/dist/cli/index.d.ts +2 -0
  11. package/dist/cli/index.js +3 -0
  12. package/dist/cli/index.js.map +1 -0
  13. package/dist/cli/internal/http.d.ts +6 -0
  14. package/dist/cli/internal/http.js +17 -0
  15. package/dist/cli/internal/http.js.map +1 -0
  16. package/dist/cli/tsdown.config.d.ts +2 -0
  17. package/dist/cli/tsdown.config.js +28 -0
  18. package/dist/cli/tsdown.config.js.map +1 -0
  19. package/dist/core/Chains.d.ts +210 -0
  20. package/dist/core/Chains.js +20 -0
  21. package/dist/core/Chains.js.map +1 -0
  22. package/dist/core/Dialog.d.ts +307 -0
  23. package/dist/core/Dialog.js +809 -0
  24. package/dist/core/Dialog.js.map +1 -0
  25. package/dist/core/Messenger.d.ts +164 -0
  26. package/dist/core/Messenger.js +207 -0
  27. package/dist/core/Messenger.js.map +1 -0
  28. package/dist/core/Mode.d.ts +4 -0
  29. package/dist/core/Mode.js +5 -0
  30. package/dist/core/Mode.js.map +1 -0
  31. package/dist/core/Porto.d.ts +1608 -0
  32. package/dist/core/Porto.js +105 -0
  33. package/dist/core/Porto.js.map +1 -0
  34. package/dist/core/RpcSchema.d.ts +81 -0
  35. package/dist/core/RpcSchema.js +2 -0
  36. package/dist/core/RpcSchema.js.map +1 -0
  37. package/dist/core/Storage.d.ts +14 -0
  38. package/dist/core/Storage.js +109 -0
  39. package/dist/core/Storage.js.map +1 -0
  40. package/dist/core/Transport.d.ts +22 -0
  41. package/dist/core/Transport.js +37 -0
  42. package/dist/core/Transport.js.map +1 -0
  43. package/dist/core/internal/_generated/chains.d.ts +1 -0
  44. package/dist/core/internal/_generated/chains.js +3 -0
  45. package/dist/core/internal/_generated/chains.js.map +1 -0
  46. package/dist/core/internal/_generated/contracts/IthacaAccount.d.ts +1120 -0
  47. package/dist/core/internal/_generated/contracts/IthacaAccount.js +1453 -0
  48. package/dist/core/internal/_generated/contracts/IthacaAccount.js.map +1 -0
  49. package/dist/core/internal/call.d.ts +163 -0
  50. package/dist/core/internal/call.js +115 -0
  51. package/dist/core/internal/call.js.map +1 -0
  52. package/dist/core/internal/erc8010.d.ts +17 -0
  53. package/dist/core/internal/erc8010.js +29 -0
  54. package/dist/core/internal/erc8010.js.map +1 -0
  55. package/dist/core/internal/intersectionObserver.d.ts +1 -0
  56. package/dist/core/internal/intersectionObserver.js +5 -0
  57. package/dist/core/internal/intersectionObserver.js.map +1 -0
  58. package/dist/core/internal/logger.d.ts +21 -0
  59. package/dist/core/internal/logger.js +24 -0
  60. package/dist/core/internal/logger.js.map +1 -0
  61. package/dist/core/internal/mode.d.ts +344 -0
  62. package/dist/core/internal/mode.js +110 -0
  63. package/dist/core/internal/mode.js.map +1 -0
  64. package/dist/core/internal/modes/dialog.d.ts +799 -0
  65. package/dist/core/internal/modes/dialog.js +760 -0
  66. package/dist/core/internal/modes/dialog.js.map +1 -0
  67. package/dist/core/internal/modes/reactNative.d.ts +1401 -0
  68. package/dist/core/internal/modes/reactNative.js +19 -0
  69. package/dist/core/internal/modes/reactNative.js.map +1 -0
  70. package/dist/core/internal/modes/relay.d.ts +684 -0
  71. package/dist/core/internal/modes/relay.js +708 -0
  72. package/dist/core/internal/modes/relay.js.map +1 -0
  73. package/dist/core/internal/permissions.d.ts +59 -0
  74. package/dist/core/internal/permissions.js +30 -0
  75. package/dist/core/internal/permissions.js.map +1 -0
  76. package/dist/core/internal/permissionsRequest.d.ts +71 -0
  77. package/dist/core/internal/permissionsRequest.js +58 -0
  78. package/dist/core/internal/permissionsRequest.js.map +1 -0
  79. package/dist/core/internal/porto.d.ts +13 -0
  80. package/dist/core/internal/porto.js +2 -0
  81. package/dist/core/internal/porto.js.map +1 -0
  82. package/dist/core/internal/promise.d.ts +8 -0
  83. package/dist/core/internal/promise.js +11 -0
  84. package/dist/core/internal/promise.js.map +1 -0
  85. package/dist/core/internal/provider.d.ts +29 -0
  86. package/dist/core/internal/provider.js +941 -0
  87. package/dist/core/internal/provider.js.map +1 -0
  88. package/dist/core/internal/relay/rpcSchema.d.ts +75 -0
  89. package/dist/core/internal/relay/rpcSchema.js +7 -0
  90. package/dist/core/internal/relay/rpcSchema.js.map +1 -0
  91. package/dist/core/internal/relay/schema/capabilities.d.ts +164 -0
  92. package/dist/core/internal/relay/schema/capabilities.js +112 -0
  93. package/dist/core/internal/relay/schema/capabilities.js.map +1 -0
  94. package/dist/core/internal/relay/schema/intent.d.ts +167 -0
  95. package/dist/core/internal/relay/schema/intent.js +170 -0
  96. package/dist/core/internal/relay/schema/intent.js.map +1 -0
  97. package/dist/core/internal/relay/schema/key.d.ts +43 -0
  98. package/dist/core/internal/relay/schema/key.js +30 -0
  99. package/dist/core/internal/relay/schema/key.js.map +1 -0
  100. package/dist/core/internal/relay/schema/permission.d.ts +39 -0
  101. package/dist/core/internal/relay/schema/permission.js +29 -0
  102. package/dist/core/internal/relay/schema/permission.js.map +1 -0
  103. package/dist/core/internal/relay/schema/preCall.d.ts +62 -0
  104. package/dist/core/internal/relay/schema/preCall.js +36 -0
  105. package/dist/core/internal/relay/schema/preCall.js.map +1 -0
  106. package/dist/core/internal/relay/schema/quotes.d.ts +369 -0
  107. package/dist/core/internal/relay/schema/quotes.js +89 -0
  108. package/dist/core/internal/relay/schema/quotes.js.map +1 -0
  109. package/dist/core/internal/relay/schema/rpc.d.ts +1528 -0
  110. package/dist/core/internal/relay/schema/rpc.js +638 -0
  111. package/dist/core/internal/relay/schema/rpc.js.map +1 -0
  112. package/dist/core/internal/relay/schema/token.d.ts +13 -0
  113. package/dist/core/internal/relay/schema/token.js +13 -0
  114. package/dist/core/internal/relay/schema/token.js.map +1 -0
  115. package/dist/core/internal/requiredFunds.d.ts +18 -0
  116. package/dist/core/internal/requiredFunds.js +25 -0
  117. package/dist/core/internal/requiredFunds.js.map +1 -0
  118. package/dist/core/internal/schema/capabilities.d.ts +313 -0
  119. package/dist/core/internal/schema/capabilities.js +133 -0
  120. package/dist/core/internal/schema/capabilities.js.map +1 -0
  121. package/dist/core/internal/schema/key.d.ts +164 -0
  122. package/dist/core/internal/schema/key.js +75 -0
  123. package/dist/core/internal/schema/key.js.map +1 -0
  124. package/dist/core/internal/schema/permissions.d.ts +102 -0
  125. package/dist/core/internal/schema/permissions.js +28 -0
  126. package/dist/core/internal/schema/permissions.js.map +1 -0
  127. package/dist/core/internal/schema/request.d.ts +937 -0
  128. package/dist/core/internal/schema/request.js +57 -0
  129. package/dist/core/internal/schema/request.js.map +1 -0
  130. package/dist/core/internal/schema/rpc.d.ts +3314 -0
  131. package/dist/core/internal/schema/rpc.js +599 -0
  132. package/dist/core/internal/schema/rpc.js.map +1 -0
  133. package/dist/core/internal/schema/token.d.ts +1 -0
  134. package/dist/core/internal/schema/token.js +2 -0
  135. package/dist/core/internal/schema/token.js.map +1 -0
  136. package/dist/core/internal/schema/utils.d.ts +18 -0
  137. package/dist/core/internal/schema/utils.js +213 -0
  138. package/dist/core/internal/schema/utils.js.map +1 -0
  139. package/dist/core/internal/siwe.d.ts +32 -0
  140. package/dist/core/internal/siwe.js +92 -0
  141. package/dist/core/internal/siwe.js.map +1 -0
  142. package/dist/core/internal/store.d.ts +2 -0
  143. package/dist/core/internal/store.js +9 -0
  144. package/dist/core/internal/store.js.map +1 -0
  145. package/dist/core/internal/tokens.d.ts +57 -0
  146. package/dist/core/internal/tokens.js +69 -0
  147. package/dist/core/internal/tokens.js.map +1 -0
  148. package/dist/core/internal/types.d.ts +298 -0
  149. package/dist/core/internal/types.js +2 -0
  150. package/dist/core/internal/types.js.map +1 -0
  151. package/dist/core/internal/urlString.d.ts +1 -0
  152. package/dist/core/internal/urlString.js +8 -0
  153. package/dist/core/internal/urlString.js.map +1 -0
  154. package/dist/core/internal/userAgent.d.ts +10 -0
  155. package/dist/core/internal/userAgent.js +19 -0
  156. package/dist/core/internal/userAgent.js.map +1 -0
  157. package/dist/core/internal/utils.d.ts +24 -0
  158. package/dist/core/internal/utils.js +62 -0
  159. package/dist/core/internal/utils.js.map +1 -0
  160. package/dist/core/react-native/Porto.d.ts +1480 -0
  161. package/dist/core/react-native/Porto.js +17 -0
  162. package/dist/core/react-native/Porto.js.map +1 -0
  163. package/dist/core/react-native/configure.d.ts +9 -0
  164. package/dist/core/react-native/configure.js +24 -0
  165. package/dist/core/react-native/configure.js.map +1 -0
  166. package/dist/core/react-native/environment.d.ts +26 -0
  167. package/dist/core/react-native/environment.js +13 -0
  168. package/dist/core/react-native/environment.js.map +1 -0
  169. package/dist/core/react-native/index.d.ts +4 -0
  170. package/dist/core/react-native/index.js +5 -0
  171. package/dist/core/react-native/index.js.map +1 -0
  172. package/dist/core/react-native/utils.d.ts +1 -0
  173. package/dist/core/react-native/utils.js +12 -0
  174. package/dist/core/react-native/utils.js.map +1 -0
  175. package/dist/index.d.ts +16 -2
  176. package/dist/index.js +15 -2
  177. package/dist/index.js.map +1 -0
  178. package/dist/internal/index.d.ts +3 -0
  179. package/dist/internal/index.js +4 -0
  180. package/dist/internal/index.js.map +1 -0
  181. package/dist/react-native/crypto.d.ts +1 -0
  182. package/dist/react-native/crypto.js +12 -0
  183. package/dist/react-native/crypto.js.map +1 -0
  184. package/dist/react-native/index.d.ts +7 -0
  185. package/dist/react-native/index.js +12 -0
  186. package/dist/react-native/index.js.map +1 -0
  187. package/dist/react-native/register.d.ts +2 -0
  188. package/dist/react-native/register.js +15 -0
  189. package/dist/react-native/register.js.map +1 -0
  190. package/dist/register/index.d.ts +14 -0
  191. package/dist/register/index.js +2 -0
  192. package/dist/register/index.js.map +1 -0
  193. package/dist/remote/Actions.d.ts +33 -0
  194. package/dist/remote/Actions.js +76 -0
  195. package/dist/remote/Actions.js.map +1 -0
  196. package/dist/remote/Events.d.ts +46 -0
  197. package/dist/remote/Events.js +132 -0
  198. package/dist/remote/Events.js.map +1 -0
  199. package/dist/remote/Hooks.d.ts +3800 -0
  200. package/dist/remote/Hooks.js +106 -0
  201. package/dist/remote/Hooks.js.map +1 -0
  202. package/dist/remote/Porto.d.ts +857 -0
  203. package/dist/remote/Porto.js +66 -0
  204. package/dist/remote/Porto.js.map +1 -0
  205. package/dist/remote/index.d.ts +4 -0
  206. package/dist/remote/index.js +5 -0
  207. package/dist/remote/index.js.map +1 -0
  208. package/dist/remote/internal/methodPolicies.d.ts +96 -0
  209. package/dist/remote/internal/methodPolicies.js +102 -0
  210. package/dist/remote/internal/methodPolicies.js.map +1 -0
  211. package/dist/server/Route.d.ts +87 -0
  212. package/dist/server/Route.js +189 -0
  213. package/dist/server/Route.js.map +1 -0
  214. package/dist/server/Router.d.ts +23 -0
  215. package/dist/server/Router.js +29 -0
  216. package/dist/server/Router.js.map +1 -0
  217. package/dist/server/index.d.ts +2 -0
  218. package/dist/server/index.js +3 -0
  219. package/dist/server/index.js.map +1 -0
  220. package/dist/server/internal/merchantSchema.d.ts +64 -0
  221. package/dist/server/internal/merchantSchema.js +7 -0
  222. package/dist/server/internal/merchantSchema.js.map +1 -0
  223. package/dist/server/internal/requestListener.d.ts +123 -0
  224. package/dist/server/internal/requestListener.js +172 -0
  225. package/dist/server/internal/requestListener.js.map +1 -0
  226. package/dist/theme/Theme.d.ts +121 -0
  227. package/dist/theme/Theme.js +18 -0
  228. package/dist/theme/Theme.js.map +1 -0
  229. package/dist/theme/index.d.ts +2 -0
  230. package/dist/theme/index.js +2 -0
  231. package/dist/theme/index.js.map +1 -0
  232. package/dist/trusted-hosts.d.ts +1 -0
  233. package/dist/trusted-hosts.js +41 -0
  234. package/dist/trusted-hosts.js.map +1 -0
  235. package/dist/viem/Account.d.ts +110 -0
  236. package/dist/viem/Account.js +132 -0
  237. package/dist/viem/Account.js.map +1 -0
  238. package/dist/viem/AccountActions.d.ts +10 -0
  239. package/dist/viem/AccountActions.js +14 -0
  240. package/dist/viem/AccountActions.js.map +1 -0
  241. package/dist/viem/CapabilitiesSchema.d.ts +14 -0
  242. package/dist/viem/CapabilitiesSchema.js +2 -0
  243. package/dist/viem/CapabilitiesSchema.js.map +1 -0
  244. package/dist/viem/ContractActions.d.ts +208 -0
  245. package/dist/viem/ContractActions.js +350 -0
  246. package/dist/viem/ContractActions.js.map +1 -0
  247. package/dist/viem/Key.d.ts +1155 -0
  248. package/dist/viem/Key.js +924 -0
  249. package/dist/viem/Key.js.map +1 -0
  250. package/dist/viem/RelayActions.d.ts +435 -0
  251. package/dist/viem/RelayActions.js +385 -0
  252. package/dist/viem/RelayActions.js.map +1 -0
  253. package/dist/viem/RelayClient.d.ts +26 -0
  254. package/dist/viem/RelayClient.js +44 -0
  255. package/dist/viem/RelayClient.js.map +1 -0
  256. package/dist/viem/RpcSchema.d.ts +22 -0
  257. package/dist/viem/RpcSchema.js +2 -0
  258. package/dist/viem/RpcSchema.js.map +1 -0
  259. package/dist/viem/WalletActions.d.ts +86 -0
  260. package/dist/viem/WalletActions.js +220 -0
  261. package/dist/viem/WalletActions.js.map +1 -0
  262. package/dist/viem/WalletClient.d.ts +20 -0
  263. package/dist/viem/WalletClient.js +23 -0
  264. package/dist/viem/WalletClient.js.map +1 -0
  265. package/dist/viem/index.d.ts +13 -0
  266. package/dist/viem/index.js +12 -0
  267. package/dist/viem/index.js.map +1 -0
  268. package/dist/viem/internal/relayActions.d.ts +364 -0
  269. package/dist/viem/internal/relayActions.js +783 -0
  270. package/dist/viem/internal/relayActions.js.map +1 -0
  271. package/dist/viem/internal/utils.d.ts +15 -0
  272. package/dist/viem/internal/utils.js +2 -0
  273. package/dist/viem/internal/utils.js.map +1 -0
  274. package/dist/wagmi/Actions.d.ts +1 -0
  275. package/dist/wagmi/Actions.js +2 -0
  276. package/dist/wagmi/Actions.js.map +1 -0
  277. package/dist/wagmi/Connector.d.ts +26 -0
  278. package/dist/wagmi/Connector.js +238 -0
  279. package/dist/wagmi/Connector.js.map +1 -0
  280. package/dist/wagmi/Hooks.d.ts +1 -0
  281. package/dist/wagmi/Hooks.js +2 -0
  282. package/dist/wagmi/Hooks.js.map +1 -0
  283. package/dist/wagmi/Query.d.ts +1 -0
  284. package/dist/wagmi/Query.js +2 -0
  285. package/dist/wagmi/Query.js.map +1 -0
  286. package/dist/wagmi/index.d.ts +4 -0
  287. package/dist/wagmi/index.js +5 -0
  288. package/dist/wagmi/index.js.map +1 -0
  289. package/dist/wagmi/internal/core.d.ts +83 -0
  290. package/dist/wagmi/internal/core.js +229 -0
  291. package/dist/wagmi/internal/core.js.map +1 -0
  292. package/dist/wagmi/internal/query.d.ts +32 -0
  293. package/dist/wagmi/internal/query.js +23 -0
  294. package/dist/wagmi/internal/query.js.map +1 -0
  295. package/dist/wagmi/internal/react.d.ts +90 -0
  296. package/dist/wagmi/internal/react.js +256 -0
  297. package/dist/wagmi/internal/react.js.map +1 -0
  298. package/dist/wagmi/internal/types.d.ts +10 -0
  299. package/dist/wagmi/internal/types.js +2 -0
  300. package/dist/wagmi/internal/types.js.map +1 -0
  301. package/dist/wagmi/internal/utils.d.ts +1 -0
  302. package/dist/wagmi/internal/utils.js +18 -0
  303. package/dist/wagmi/internal/utils.js.map +1 -0
  304. package/package.json +286 -34
  305. package/src/cli/Dialog.ts +75 -0
  306. package/src/cli/Messenger.ts +148 -0
  307. package/src/cli/bin/index.ts +37 -0
  308. package/src/cli/bin/tsconfig.json +8 -0
  309. package/src/cli/index.ts +2 -0
  310. package/src/cli/internal/commands.ts +212 -0
  311. package/src/cli/internal/context.ts +56 -0
  312. package/src/cli/internal/http.ts +28 -0
  313. package/src/cli/internal/utils.ts +28 -0
  314. package/src/cli/tsdown.config.ts +37 -0
  315. package/src/core/Chains.ts +25 -0
  316. package/src/core/Dialog.ts +1059 -0
  317. package/src/core/Messenger.ts +394 -0
  318. package/src/core/Mode.ts +4 -0
  319. package/src/core/Porto.ts +287 -0
  320. package/src/core/RpcSchema.ts +124 -0
  321. package/src/core/Storage.ts +122 -0
  322. package/src/core/Transport.ts +45 -0
  323. package/src/core/internal/_generated/chains.ts +2 -0
  324. package/src/core/internal/_generated/contracts/EIP7702Proxy.ts +25 -0
  325. package/src/core/internal/_generated/contracts/Escrow.ts +330 -0
  326. package/src/core/internal/_generated/contracts/ExperimentERC20.ts +569 -0
  327. package/src/core/internal/_generated/contracts/ExperimentERC721.ts +588 -0
  328. package/src/core/internal/_generated/contracts/GuardedExecutor.ts +623 -0
  329. package/src/core/internal/_generated/contracts/ICallChecker.ts +34 -0
  330. package/src/core/internal/_generated/contracts/ICommon.ts +4 -0
  331. package/src/core/internal/_generated/contracts/IEscrow.ts +114 -0
  332. package/src/core/internal/_generated/contracts/IFunder.ts +80 -0
  333. package/src/core/internal/_generated/contracts/IFunderV4.ts +45 -0
  334. package/src/core/internal/_generated/contracts/IIthacaAccount.ts +107 -0
  335. package/src/core/internal/_generated/contracts/IOAppCore.ts +142 -0
  336. package/src/core/internal/_generated/contracts/IOAppMsgInspector.ts +45 -0
  337. package/src/core/internal/_generated/contracts/IOAppReceiver.ts +161 -0
  338. package/src/core/internal/_generated/contracts/IOrchestrator.ts +95 -0
  339. package/src/core/internal/_generated/contracts/ISettler.ts +52 -0
  340. package/src/core/internal/_generated/contracts/ISigner.ts +34 -0
  341. package/src/core/internal/_generated/contracts/IthacaAccount.ts +1454 -0
  342. package/src/core/internal/_generated/contracts/IthacaAccountNew.ts +1454 -0
  343. package/src/core/internal/_generated/contracts/IthacaAccountOld.ts +1454 -0
  344. package/src/core/internal/_generated/contracts/LayerZeroSettler.ts +811 -0
  345. package/src/core/internal/_generated/contracts/LibNonce.ts +15 -0
  346. package/src/core/internal/_generated/contracts/LibTStack.ts +4 -0
  347. package/src/core/internal/_generated/contracts/MultiSigSigner.ts +203 -0
  348. package/src/core/internal/_generated/contracts/OApp.ts +412 -0
  349. package/src/core/internal/_generated/contracts/OAppCore.ts +229 -0
  350. package/src/core/internal/_generated/contracts/OAppReceiver.ts +396 -0
  351. package/src/core/internal/_generated/contracts/OAppSender.ts +245 -0
  352. package/src/core/internal/_generated/contracts/Orchestrator.ts +390 -0
  353. package/src/core/internal/_generated/contracts/SimpleFunder.ts +534 -0
  354. package/src/core/internal/_generated/contracts/SimpleSettler.ts +360 -0
  355. package/src/core/internal/_generated/contracts/Simulator.ts +170 -0
  356. package/src/core/internal/_generated/contracts/TokenTransferLib.ts +4 -0
  357. package/src/core/internal/_snapshots/provider.browser.test.ts.snap +119 -0
  358. package/src/core/internal/_snapshots/provider.test.ts.snap +1103 -0
  359. package/src/core/internal/call.test.ts +116 -0
  360. package/src/core/internal/call.ts +245 -0
  361. package/src/core/internal/erc8010.test.ts +74 -0
  362. package/src/core/internal/erc8010.ts +44 -0
  363. package/src/core/internal/intersectionObserver.ts +5 -0
  364. package/src/core/internal/logger.ts +42 -0
  365. package/src/core/internal/mode.ts +498 -0
  366. package/src/core/internal/modes/dialog.ts +1051 -0
  367. package/src/core/internal/modes/reactNative.ts +29 -0
  368. package/src/core/internal/modes/relay.ts +893 -0
  369. package/src/core/internal/permissions.ts +43 -0
  370. package/src/core/internal/permissionsRequest.ts +88 -0
  371. package/src/core/internal/porto.ts +16 -0
  372. package/src/core/internal/promise.ts +19 -0
  373. package/src/core/internal/provider.browser.test.ts +311 -0
  374. package/src/core/internal/provider.test.ts +3552 -0
  375. package/src/core/internal/provider.ts +1277 -0
  376. package/src/core/internal/relay/rpcSchema.ts +101 -0
  377. package/src/core/internal/relay/schema/capabilities.test.ts +663 -0
  378. package/src/core/internal/relay/schema/capabilities.ts +156 -0
  379. package/src/core/internal/relay/schema/intent.test.ts +433 -0
  380. package/src/core/internal/relay/schema/intent.ts +174 -0
  381. package/src/core/internal/relay/schema/key.test.ts +424 -0
  382. package/src/core/internal/relay/schema/key.ts +34 -0
  383. package/src/core/internal/relay/schema/permission.test.ts +499 -0
  384. package/src/core/internal/relay/schema/permission.ts +34 -0
  385. package/src/core/internal/relay/schema/preCall.ts +39 -0
  386. package/src/core/internal/relay/schema/quotes.test.ts +901 -0
  387. package/src/core/internal/relay/schema/quotes.ts +98 -0
  388. package/src/core/internal/relay/schema/rpc.ts +822 -0
  389. package/src/core/internal/relay/schema/token.ts +16 -0
  390. package/src/core/internal/requiredFunds.test.ts +141 -0
  391. package/src/core/internal/requiredFunds.ts +45 -0
  392. package/src/core/internal/schema/capabilities.test.ts +1334 -0
  393. package/src/core/internal/schema/capabilities.ts +162 -0
  394. package/src/core/internal/schema/key.test.ts +570 -0
  395. package/src/core/internal/schema/key.ts +98 -0
  396. package/src/core/internal/schema/permissions.test.ts +948 -0
  397. package/src/core/internal/schema/permissions.ts +31 -0
  398. package/src/core/internal/schema/request.bench.ts +35 -0
  399. package/src/core/internal/schema/request.ts +90 -0
  400. package/src/core/internal/schema/rpc.ts +821 -0
  401. package/src/core/internal/schema/token.ts +1 -0
  402. package/src/core/internal/schema/utils.test.ts +572 -0
  403. package/src/core/internal/schema/utils.ts +236 -0
  404. package/src/core/internal/siwe.test.ts +473 -0
  405. package/src/core/internal/siwe.ts +144 -0
  406. package/src/core/internal/store.ts +9 -0
  407. package/src/core/internal/tokens.test.ts +317 -0
  408. package/src/core/internal/tokens.ts +125 -0
  409. package/src/core/internal/types.ts +448 -0
  410. package/src/core/internal/urlString.ts +5 -0
  411. package/src/core/internal/userAgent.ts +35 -0
  412. package/src/core/internal/utils.test.ts +35 -0
  413. package/src/core/internal/utils.ts +67 -0
  414. package/src/core/react-native/Porto.ts +22 -0
  415. package/src/core/react-native/configure.ts +31 -0
  416. package/src/core/react-native/environment.ts +43 -0
  417. package/src/core/react-native/index.ts +4 -0
  418. package/src/core/react-native/utils.ts +18 -0
  419. package/src/index.ts +17 -0
  420. package/src/internal/index.ts +3 -0
  421. package/src/react-native/crypto.ts +19 -0
  422. package/src/react-native/index.ts +15 -0
  423. package/src/react-native/register.ts +24 -0
  424. package/src/register/index.ts +17 -0
  425. package/src/remote/Actions.ts +115 -0
  426. package/src/remote/Events.ts +193 -0
  427. package/src/remote/Hooks.ts +194 -0
  428. package/src/remote/Porto.ts +144 -0
  429. package/src/remote/index.ts +4 -0
  430. package/src/remote/internal/methodPolicies.ts +124 -0
  431. package/src/server/Route.test.ts +347 -0
  432. package/src/server/Route.ts +259 -0
  433. package/src/server/Router.test.ts +32 -0
  434. package/src/server/Router.ts +59 -0
  435. package/src/server/index.ts +2 -0
  436. package/src/server/internal/merchantSchema.ts +11 -0
  437. package/src/server/internal/requestListener.ts +284 -0
  438. package/src/theme/Theme.ts +163 -0
  439. package/src/theme/index.ts +2 -0
  440. package/src/trusted-hosts.ts +40 -0
  441. package/src/tsconfig.build.tsbuildinfo +1 -0
  442. package/src/tsconfig.json +15 -0
  443. package/src/viem/Account.test.ts +270 -0
  444. package/src/viem/Account.ts +278 -0
  445. package/src/viem/AccountActions.test.ts +3 -0
  446. package/src/viem/AccountActions.ts +30 -0
  447. package/src/viem/CapabilitiesSchema.ts +18 -0
  448. package/src/viem/ContractActions.test.ts +980 -0
  449. package/src/viem/ContractActions.ts +624 -0
  450. package/src/viem/Key.test.ts +1420 -0
  451. package/src/viem/Key.ts +1318 -0
  452. package/src/viem/RelayActions.test.ts +1730 -0
  453. package/src/viem/RelayActions.ts +1082 -0
  454. package/src/viem/RelayClient.test.ts +127 -0
  455. package/src/viem/RelayClient.ts +87 -0
  456. package/src/viem/RpcSchema.ts +27 -0
  457. package/src/viem/WalletActions.test.ts +646 -0
  458. package/src/viem/WalletActions.ts +476 -0
  459. package/src/viem/WalletClient.test.ts +36 -0
  460. package/src/viem/WalletClient.ts +74 -0
  461. package/src/viem/index.ts +13 -0
  462. package/src/viem/internal/relayActions.test.ts +1296 -0
  463. package/src/viem/internal/relayActions.ts +1222 -0
  464. package/src/viem/internal/utils.ts +27 -0
  465. package/src/wagmi/Actions.ts +13 -0
  466. package/src/wagmi/Connector.ts +304 -0
  467. package/src/wagmi/Hooks.ts +14 -0
  468. package/src/wagmi/Query.ts +5 -0
  469. package/src/wagmi/index.ts +4 -0
  470. package/src/wagmi/internal/core.test.ts +12 -0
  471. package/src/wagmi/internal/core.ts +468 -0
  472. package/src/wagmi/internal/query.ts +52 -0
  473. package/src/wagmi/internal/react.test.ts +12 -0
  474. package/src/wagmi/internal/react.ts +705 -0
  475. package/src/wagmi/internal/types.ts +21 -0
  476. package/src/wagmi/internal/utils.ts +25 -0
  477. package/dist/chain.cjs +0 -17
  478. package/dist/chain.d.cts +0 -41
  479. package/dist/chain.d.ts +0 -41
  480. package/dist/chain.js +0 -13
  481. package/dist/config.cjs +0 -19
  482. package/dist/config.d.cts +0 -3
  483. package/dist/config.d.ts +0 -3
  484. package/dist/config.js +0 -16
  485. package/dist/index.cjs +0 -18
  486. package/dist/index.d.cts +0 -2
@@ -0,0 +1,901 @@
1
+ import { describe, expect, test } from 'vitest'
2
+ import * as z from 'zod/mini'
3
+ import * as Quotes from './quotes.js'
4
+
5
+ describe('Quote', () => {
6
+ const validQuoteData = {
7
+ authorizationAddress: '0x1234567890123456789012345678901234567890',
8
+ chainId: '0x1',
9
+ ethPrice: '0x1bc16d674ec80000',
10
+ extraPayment: '0x0',
11
+ feeTokenDeficit: '0x32',
12
+ intent: {
13
+ combinedGas: '0x5208',
14
+ encodedFundTransfers: [],
15
+ encodedPreCalls: [],
16
+ eoa: '0x1234567890123456789012345678901234567890',
17
+ executionData: '0xabcdef',
18
+ expiry: '0x1234567890',
19
+ funder: '0x1234567890123456789012345678901234567890',
20
+ funderSignature: '0xfundersig123',
21
+ isMultichain: false,
22
+ nonce: '0x1',
23
+ payer: '0x1234567890123456789012345678901234567890',
24
+ paymentAmount: '0x12c',
25
+ paymentMaxAmount: '0x190',
26
+ paymentRecipient: '0x9876543210987654321098765432109876543210',
27
+ paymentSignature: '0x123456',
28
+ paymentToken: '0xa0b86991c31cc0c7b6f931c7d751c635d989dc1bb',
29
+ settler: '0x9876543210987654321098765432109876543210',
30
+ settlerContext: '0xsettlercontext123',
31
+ signature: '0xsignature123',
32
+ supportedAccountImplementation:
33
+ '0x0000000000000000000000000000000000000000',
34
+ },
35
+ nativeFeeEstimate: {
36
+ maxFeePerGas: '0x3b9aca00',
37
+ maxPriorityFeePerGas: '0x59682f00',
38
+ },
39
+ orchestrator: '0x9876543210987654321098765432109876543210',
40
+ paymentTokenDecimals: 18,
41
+ txGas: '0x5208',
42
+ }
43
+
44
+ test('behavior: decodes valid quote with all fields', () => {
45
+ const result = z.parse(Quotes.Quote, validQuoteData)
46
+ expect(result).toMatchInlineSnapshot(`
47
+ {
48
+ "authorizationAddress": "0x1234567890123456789012345678901234567890",
49
+ "chainId": 1,
50
+ "ethPrice": 2000000000000000000n,
51
+ "extraPayment": 0n,
52
+ "feeTokenDeficit": 50n,
53
+ "intent": {
54
+ "combinedGas": 21000n,
55
+ "encodedFundTransfers": [],
56
+ "encodedPreCalls": [],
57
+ "eoa": "0x1234567890123456789012345678901234567890",
58
+ "executionData": "0xabcdef",
59
+ "expiry": 78187493520n,
60
+ "funder": "0x1234567890123456789012345678901234567890",
61
+ "funderSignature": "0xfundersig123",
62
+ "isMultichain": false,
63
+ "nonce": 1n,
64
+ "payer": "0x1234567890123456789012345678901234567890",
65
+ "paymentAmount": 300n,
66
+ "paymentMaxAmount": 400n,
67
+ "paymentRecipient": "0x9876543210987654321098765432109876543210",
68
+ "paymentSignature": "0x123456",
69
+ "paymentToken": "0xa0b86991c31cc0c7b6f931c7d751c635d989dc1bb",
70
+ "settler": "0x9876543210987654321098765432109876543210",
71
+ "settlerContext": "0xsettlercontext123",
72
+ "signature": "0xsignature123",
73
+ "supportedAccountImplementation": "0x0000000000000000000000000000000000000000",
74
+ },
75
+ "nativeFeeEstimate": {
76
+ "maxFeePerGas": 1000000000n,
77
+ "maxPriorityFeePerGas": 1500000000n,
78
+ },
79
+ "orchestrator": "0x9876543210987654321098765432109876543210",
80
+ "paymentTokenDecimals": 18,
81
+ "txGas": 21000n,
82
+ }
83
+ `)
84
+ })
85
+
86
+ test('behavior: encodes valid quote data', () => {
87
+ const decodedData = z.parse(Quotes.Quote, validQuoteData)
88
+ const encodedData = z.encode(Quotes.Quote, decodedData)
89
+ expect(encodedData).toMatchInlineSnapshot(`
90
+ {
91
+ "authorizationAddress": "0x1234567890123456789012345678901234567890",
92
+ "chainId": "0x1",
93
+ "ethPrice": "0x1bc16d674ec80000",
94
+ "extraPayment": "0x0",
95
+ "feeTokenDeficit": "0x32",
96
+ "intent": {
97
+ "combinedGas": "0x5208",
98
+ "encodedFundTransfers": [],
99
+ "encodedPreCalls": [],
100
+ "eoa": "0x1234567890123456789012345678901234567890",
101
+ "executionData": "0xabcdef",
102
+ "expiry": "0x1234567890",
103
+ "funder": "0x1234567890123456789012345678901234567890",
104
+ "funderSignature": "0xfundersig123",
105
+ "isMultichain": false,
106
+ "nonce": "0x1",
107
+ "payer": "0x1234567890123456789012345678901234567890",
108
+ "paymentAmount": "0x12c",
109
+ "paymentMaxAmount": "0x190",
110
+ "paymentRecipient": "0x9876543210987654321098765432109876543210",
111
+ "paymentSignature": "0x123456",
112
+ "paymentToken": "0xa0b86991c31cc0c7b6f931c7d751c635d989dc1bb",
113
+ "settler": "0x9876543210987654321098765432109876543210",
114
+ "settlerContext": "0xsettlercontext123",
115
+ "signature": "0xsignature123",
116
+ "supportedAccountImplementation": "0x0000000000000000000000000000000000000000",
117
+ },
118
+ "nativeFeeEstimate": {
119
+ "maxFeePerGas": "0x3b9aca00",
120
+ "maxPriorityFeePerGas": "0x59682f00",
121
+ },
122
+ "orchestrator": "0x9876543210987654321098765432109876543210",
123
+ "paymentTokenDecimals": 18,
124
+ "txGas": "0x5208",
125
+ }
126
+ `)
127
+ })
128
+
129
+ test('behavior: round-trip encoding/decoding preserves data', () => {
130
+ const originalDecoded = z.parse(Quotes.Quote, validQuoteData)
131
+ const encoded = z.encode(Quotes.Quote, originalDecoded)
132
+ const reDecoded = z.parse(Quotes.Quote, encoded)
133
+
134
+ expect(reDecoded).toEqual(originalDecoded)
135
+ })
136
+
137
+ test('behavior: decodes quote with null authorizationAddress', () => {
138
+ const dataWithNullAuth = {
139
+ ...validQuoteData,
140
+ authorizationAddress: null,
141
+ }
142
+ const result = z.parse(Quotes.Quote, dataWithNullAuth)
143
+ expect(result.authorizationAddress).toBeNull()
144
+ })
145
+
146
+ test('behavior: decodes quote with undefined authorizationAddress', () => {
147
+ const dataWithUndefinedAuth = {
148
+ ...validQuoteData,
149
+ authorizationAddress: undefined,
150
+ }
151
+ const result = z.parse(Quotes.Quote, dataWithUndefinedAuth)
152
+ expect(result.authorizationAddress).toBeUndefined()
153
+ })
154
+
155
+ test('behavior: decodes quote with large BigInt values', () => {
156
+ const dataWithLargeBigInts = {
157
+ ...validQuoteData,
158
+ ethPrice: '0xffffffffffffffffffffffffffffffffff',
159
+ extraPayment: '0xffffffffffffffffffffffffffffffffffff',
160
+ feeTokenDeficit: '0xffffffffffffffffffffffffffffff',
161
+ txGas: '0xffffffffffffffffffffffffffffffff',
162
+ }
163
+ const result = z.parse(Quotes.Quote, dataWithLargeBigInts)
164
+ expect(result.ethPrice).toBe(BigInt('0xffffffffffffffffffffffffffffffffff'))
165
+ expect(result.extraPayment).toBe(
166
+ BigInt('0xffffffffffffffffffffffffffffffffffff'),
167
+ )
168
+ expect(result.feeTokenDeficit).toBe(
169
+ BigInt('0xffffffffffffffffffffffffffffff'),
170
+ )
171
+ expect(result.txGas).toBe(BigInt('0xffffffffffffffffffffffffffffffff'))
172
+ })
173
+
174
+ test('behavior: encodes large BigInt values back to hex', () => {
175
+ const dataWithLargeBigInts = {
176
+ ...validQuoteData,
177
+ ethPrice: '0xff',
178
+ extraPayment: '0xffff',
179
+ feeTokenDeficit: '0xfffff',
180
+ txGas: '0xffffff',
181
+ }
182
+ const decoded = z.parse(Quotes.Quote, dataWithLargeBigInts)
183
+ const encoded = z.encode(Quotes.Quote, decoded)
184
+ expect(encoded.ethPrice).toBe('0xff')
185
+ expect(encoded.extraPayment).toBe('0xffff')
186
+ expect(encoded.feeTokenDeficit).toBe('0xfffff')
187
+ expect(encoded.txGas).toBe('0xffffff')
188
+ })
189
+
190
+ test.each([
191
+ { chainId: '0x1', expected: 1 },
192
+ { chainId: '0x5', expected: 5 },
193
+ { chainId: '0x89', expected: 137 },
194
+ { chainId: '0x10435', expected: 66613 },
195
+ ])(
196
+ 'behavior: decodes quote with chainId $chainId',
197
+ ({ chainId, expected }) => {
198
+ const result = z.parse(Quotes.Quote, {
199
+ ...validQuoteData,
200
+ chainId,
201
+ })
202
+ expect(result.chainId).toBe(expected)
203
+ },
204
+ )
205
+
206
+ test.each([
207
+ { expected: 6, paymentTokenDecimals: 6 },
208
+ { expected: 8, paymentTokenDecimals: 8 },
209
+ { expected: 18, paymentTokenDecimals: 18 },
210
+ ])(
211
+ 'behavior: decodes quote with paymentTokenDecimals $paymentTokenDecimals',
212
+ ({ paymentTokenDecimals, expected }) => {
213
+ const result = z.parse(Quotes.Quote, {
214
+ ...validQuoteData,
215
+ paymentTokenDecimals,
216
+ })
217
+ expect(result.paymentTokenDecimals).toBe(expected)
218
+ },
219
+ )
220
+
221
+ test('error: rejects invalid address format for authorizationAddress', () => {
222
+ expect(() =>
223
+ z.parse(Quotes.Quote, {
224
+ ...validQuoteData,
225
+ authorizationAddress: 'invalid-address',
226
+ }),
227
+ ).toThrowErrorMatchingInlineSnapshot(`
228
+ [$ZodError: [
229
+ {
230
+ "code": "invalid_union",
231
+ "errors": [
232
+ [
233
+ {
234
+ "code": "invalid_format",
235
+ "format": "template_literal",
236
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
237
+ "path": [],
238
+ "message": "Needs string in format ^0x[A-Fa-f0-9]{40}$."
239
+ }
240
+ ],
241
+ [
242
+ {
243
+ "expected": "null",
244
+ "code": "invalid_type",
245
+ "path": [],
246
+ "message": "Invalid input"
247
+ }
248
+ ]
249
+ ],
250
+ "path": [
251
+ "authorizationAddress"
252
+ ],
253
+ "message": "Invalid input"
254
+ }
255
+ ]]
256
+ `)
257
+ })
258
+
259
+ test('error: rejects invalid address format for orchestrator', () => {
260
+ expect(() =>
261
+ z.parse(Quotes.Quote, {
262
+ ...validQuoteData,
263
+ orchestrator: 'invalid-address',
264
+ }),
265
+ ).toThrowErrorMatchingInlineSnapshot(`
266
+ [$ZodError: [
267
+ {
268
+ "code": "invalid_format",
269
+ "format": "template_literal",
270
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
271
+ "path": [
272
+ "orchestrator"
273
+ ],
274
+ "message": "Needs string in format ^0x[A-Fa-f0-9]{40}$."
275
+ }
276
+ ]]
277
+ `)
278
+ })
279
+
280
+ test('error: rejects invalid hex format for BigInt fields', () => {
281
+ expect(() =>
282
+ z.parse(Quotes.Quote, {
283
+ ...validQuoteData,
284
+ ethPrice: 'not-hex',
285
+ }),
286
+ ).toThrowErrorMatchingInlineSnapshot(`
287
+ [$ZodError: [
288
+ {
289
+ "code": "invalid_format",
290
+ "format": "template_literal",
291
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
292
+ "path": [
293
+ "ethPrice"
294
+ ],
295
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
296
+ }
297
+ ]]
298
+ `)
299
+ })
300
+
301
+ test('error: rejects invalid number format for chainId', () => {
302
+ expect(() =>
303
+ z.parse(Quotes.Quote, {
304
+ ...validQuoteData,
305
+ chainId: 'not-a-number',
306
+ }),
307
+ ).toThrowErrorMatchingInlineSnapshot(`
308
+ [$ZodError: [
309
+ {
310
+ "code": "invalid_format",
311
+ "format": "template_literal",
312
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
313
+ "path": [
314
+ "chainId"
315
+ ],
316
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
317
+ }
318
+ ]]
319
+ `)
320
+ })
321
+
322
+ test('error: rejects missing required fields', () => {
323
+ expect(() =>
324
+ z.parse(Quotes.Quote, {
325
+ chainId: 1,
326
+ // Missing other required fields
327
+ }),
328
+ ).toThrowErrorMatchingInlineSnapshot(`
329
+ [$ZodError: [
330
+ {
331
+ "expected": "template_literal",
332
+ "code": "invalid_type",
333
+ "path": [
334
+ "chainId"
335
+ ],
336
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
337
+ },
338
+ {
339
+ "expected": "template_literal",
340
+ "code": "invalid_type",
341
+ "path": [
342
+ "ethPrice"
343
+ ],
344
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
345
+ },
346
+ {
347
+ "expected": "template_literal",
348
+ "code": "invalid_type",
349
+ "path": [
350
+ "extraPayment"
351
+ ],
352
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
353
+ },
354
+ {
355
+ "expected": "template_literal",
356
+ "code": "invalid_type",
357
+ "path": [
358
+ "feeTokenDeficit"
359
+ ],
360
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
361
+ },
362
+ {
363
+ "code": "invalid_union",
364
+ "errors": [
365
+ [
366
+ {
367
+ "expected": "object",
368
+ "code": "invalid_type",
369
+ "path": [],
370
+ "message": "Invalid input"
371
+ }
372
+ ],
373
+ [
374
+ {
375
+ "expected": "object",
376
+ "code": "invalid_type",
377
+ "path": [],
378
+ "message": "Invalid input"
379
+ }
380
+ ]
381
+ ],
382
+ "path": [
383
+ "intent"
384
+ ],
385
+ "message": "Invalid input"
386
+ },
387
+ {
388
+ "expected": "object",
389
+ "code": "invalid_type",
390
+ "path": [
391
+ "nativeFeeEstimate"
392
+ ],
393
+ "message": "Invalid input"
394
+ },
395
+ {
396
+ "expected": "template_literal",
397
+ "code": "invalid_type",
398
+ "path": [
399
+ "orchestrator"
400
+ ],
401
+ "message": "Needs string in format ^0x[A-Fa-f0-9]{40}$."
402
+ },
403
+ {
404
+ "expected": "number",
405
+ "code": "invalid_type",
406
+ "path": [
407
+ "paymentTokenDecimals"
408
+ ],
409
+ "message": "Invalid input"
410
+ },
411
+ {
412
+ "expected": "template_literal",
413
+ "code": "invalid_type",
414
+ "path": [
415
+ "txGas"
416
+ ],
417
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
418
+ }
419
+ ]]
420
+ `)
421
+ })
422
+
423
+ test('error: rejects invalid nativeFeeEstimate structure', () => {
424
+ expect(() =>
425
+ z.parse(Quotes.Quote, {
426
+ ...validQuoteData,
427
+ nativeFeeEstimate: {
428
+ maxFeePerGas: 'not-hex',
429
+ maxPriorityFeePerGas: '0x59682f00',
430
+ },
431
+ }),
432
+ ).toThrowErrorMatchingInlineSnapshot(`
433
+ [$ZodError: [
434
+ {
435
+ "code": "invalid_format",
436
+ "format": "template_literal",
437
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
438
+ "path": [
439
+ "nativeFeeEstimate",
440
+ "maxFeePerGas"
441
+ ],
442
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
443
+ }
444
+ ]]
445
+ `)
446
+ })
447
+ })
448
+
449
+ describe('Quotes', () => {
450
+ const validQuotesData = {
451
+ multiChainRoot: '0xabcdef1234567890',
452
+ quotes: [
453
+ {
454
+ authorizationAddress: '0x1234567890123456789012345678901234567890',
455
+ chainId: '0x1',
456
+ ethPrice: '0x1bc16d674ec80000',
457
+ extraPayment: '0x0',
458
+ feeTokenDeficit: '0x32',
459
+ intent: {
460
+ combinedGas: '0x5208',
461
+ encodedFundTransfers: [],
462
+ encodedPreCalls: [],
463
+ eoa: '0x1234567890123456789012345678901234567890',
464
+ executionData: '0xabcdef',
465
+ expiry: '0x1234567890',
466
+ funder: '0x1234567890123456789012345678901234567890',
467
+ funderSignature: '0xfundersig123',
468
+ isMultichain: false,
469
+ nonce: '0x1',
470
+ payer: '0x1234567890123456789012345678901234567890',
471
+ paymentAmount: '0x12c',
472
+ paymentMaxAmount: '0x190',
473
+ paymentRecipient: '0x9876543210987654321098765432109876543210',
474
+ paymentSignature: '0x123456',
475
+ paymentToken: '0xa0b86991c31cc0c7b6f931c7d751c635d989dc1bb',
476
+ settler: '0x9876543210987654321098765432109876543210',
477
+ settlerContext: '0xsettlercontext123',
478
+ signature: '0xsignature123',
479
+ supportedAccountImplementation:
480
+ '0x0000000000000000000000000000000000000000',
481
+ },
482
+ nativeFeeEstimate: {
483
+ maxFeePerGas: '0x3b9aca00',
484
+ maxPriorityFeePerGas: '0x59682f00',
485
+ },
486
+ orchestrator: '0x9876543210987654321098765432109876543210',
487
+ paymentTokenDecimals: 18,
488
+ txGas: '0x5208',
489
+ },
490
+ ],
491
+ ttl: 300,
492
+ }
493
+
494
+ test('behavior: decodes valid quotes with all fields', () => {
495
+ const result = z.parse(Quotes.Quotes, validQuotesData)
496
+ expect(result.quotes).toHaveLength(1)
497
+ expect(result.multiChainRoot).toBe('0xabcdef1234567890')
498
+ expect(result.ttl).toBe(300)
499
+ })
500
+
501
+ test('behavior: decodes quotes without optional multiChainRoot', () => {
502
+ const dataWithoutMultiChain = {
503
+ ...validQuotesData,
504
+ multiChainRoot: undefined,
505
+ }
506
+ const result = z.parse(Quotes.Quotes, dataWithoutMultiChain)
507
+ expect(result.multiChainRoot).toBeUndefined()
508
+ expect(result.quotes).toHaveLength(1)
509
+ expect(result.ttl).toBe(300)
510
+ })
511
+
512
+ test('behavior: encodes valid quotes data', () => {
513
+ const decodedData = z.parse(Quotes.Quotes, validQuotesData)
514
+ const encodedData = z.encode(Quotes.Quotes, decodedData)
515
+ expect(encodedData.quotes).toHaveLength(1)
516
+ expect(encodedData.multiChainRoot).toBe('0xabcdef1234567890')
517
+ expect(encodedData.ttl).toBe(300)
518
+ })
519
+
520
+ test('error: rejects empty quotes array', () => {
521
+ expect(() =>
522
+ z.parse(Quotes.Quotes, {
523
+ ...validQuotesData,
524
+ quotes: [],
525
+ }),
526
+ ).toThrowErrorMatchingInlineSnapshot(`
527
+ [$ZodError: [
528
+ {
529
+ "origin": "array",
530
+ "code": "too_small",
531
+ "minimum": 1,
532
+ "inclusive": true,
533
+ "path": [
534
+ "quotes"
535
+ ],
536
+ "message": "Invalid input"
537
+ }
538
+ ]]
539
+ `)
540
+ })
541
+
542
+ test('error: rejects missing required fields', () => {
543
+ expect(() =>
544
+ z.parse(Quotes.Quotes, {
545
+ multiChainRoot: '0xabcdef1234567890',
546
+ // Missing quotes and ttl
547
+ }),
548
+ ).toThrowErrorMatchingInlineSnapshot(`
549
+ [$ZodError: [
550
+ {
551
+ "expected": "array",
552
+ "code": "invalid_type",
553
+ "path": [
554
+ "quotes"
555
+ ],
556
+ "message": "Invalid input"
557
+ },
558
+ {
559
+ "expected": "number",
560
+ "code": "invalid_type",
561
+ "path": [
562
+ "ttl"
563
+ ],
564
+ "message": "Invalid input"
565
+ }
566
+ ]]
567
+ `)
568
+ })
569
+ })
570
+
571
+ describe('Signed', () => {
572
+ const validSignedData = {
573
+ hash: '0xabcdef1234567890abcdef1234567890abcdef1234567890abcdef1234567890',
574
+ multiChainRoot: '0xabcdef1234567890',
575
+ quotes: [
576
+ {
577
+ authorizationAddress: '0x1234567890123456789012345678901234567890',
578
+ chainId: '0x1',
579
+ ethPrice: '0x1bc16d674ec80000',
580
+ extraPayment: '0x0',
581
+ feeTokenDeficit: '0x32',
582
+ intent: {
583
+ combinedGas: '0x5208',
584
+ encodedFundTransfers: [],
585
+ encodedPreCalls: [],
586
+ eoa: '0x1234567890123456789012345678901234567890',
587
+ executionData: '0xabcdef',
588
+ expiry: '0x1234567890',
589
+ funder: '0x1234567890123456789012345678901234567890',
590
+ funderSignature: '0xfundersig123',
591
+ isMultichain: false,
592
+ nonce: '0x1',
593
+ payer: '0x1234567890123456789012345678901234567890',
594
+ paymentAmount: '0x12c',
595
+ paymentMaxAmount: '0x190',
596
+ paymentRecipient: '0x9876543210987654321098765432109876543210',
597
+ paymentSignature: '0x123456',
598
+ paymentToken: '0xa0b86991c31cc0c7b6f931c7d751c635d989dc1bb',
599
+ settler: '0x9876543210987654321098765432109876543210',
600
+ settlerContext: '0xsettlercontext123',
601
+ signature: '0xsignature123',
602
+ supportedAccountImplementation:
603
+ '0x0000000000000000000000000000000000000000',
604
+ },
605
+ nativeFeeEstimate: {
606
+ maxFeePerGas: '0x3b9aca00',
607
+ maxPriorityFeePerGas: '0x59682f00',
608
+ },
609
+ orchestrator: '0x9876543210987654321098765432109876543210',
610
+ paymentTokenDecimals: 18,
611
+ txGas: '0x5208',
612
+ },
613
+ ],
614
+ r: '0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef',
615
+ s: '0xfedcba0987654321fedcba0987654321fedcba0987654321fedcba0987654321',
616
+ ttl: 300,
617
+ v: '0x1b',
618
+ yParity: '0x0',
619
+ }
620
+
621
+ test('behavior: decodes valid signed quotes with all fields', () => {
622
+ const result = z.parse(Quotes.Signed, validSignedData)
623
+ expect(result.quotes).toHaveLength(1)
624
+ expect(result.multiChainRoot).toBe('0xabcdef1234567890')
625
+ expect(result.ttl).toBe(300)
626
+ expect(result.hash).toBe(
627
+ '0xabcdef1234567890abcdef1234567890abcdef1234567890abcdef1234567890',
628
+ )
629
+ expect(result.r).toBe(
630
+ '0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef',
631
+ )
632
+ expect(result.s).toBe(
633
+ '0xfedcba0987654321fedcba0987654321fedcba0987654321fedcba0987654321',
634
+ )
635
+ expect(result.v).toBe('0x1b')
636
+ expect(result.yParity).toBe('0x0')
637
+ })
638
+
639
+ test('behavior: encodes valid signed quotes data', () => {
640
+ const decodedData = z.parse(Quotes.Signed, validSignedData)
641
+ const encodedData = z.encode(Quotes.Signed, decodedData)
642
+ expect(encodedData.quotes).toHaveLength(1)
643
+ expect(encodedData.multiChainRoot).toBe('0xabcdef1234567890')
644
+ expect(encodedData.ttl).toBe(300)
645
+ expect(encodedData.hash).toBe(
646
+ '0xabcdef1234567890abcdef1234567890abcdef1234567890abcdef1234567890',
647
+ )
648
+ expect(encodedData.r).toBe(
649
+ '0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef',
650
+ )
651
+ expect(encodedData.s).toBe(
652
+ '0xfedcba0987654321fedcba0987654321fedcba0987654321fedcba0987654321',
653
+ )
654
+ expect(encodedData.v).toBe('0x1b')
655
+ expect(encodedData.yParity).toBe('0x0')
656
+ })
657
+
658
+ test('behavior: round-trip encoding/decoding preserves signed data', () => {
659
+ const originalDecoded = z.parse(Quotes.Signed, validSignedData)
660
+ const encoded = z.encode(Quotes.Signed, originalDecoded)
661
+ const reDecoded = z.parse(Quotes.Signed, encoded)
662
+
663
+ expect(reDecoded).toEqual(originalDecoded)
664
+ })
665
+
666
+ test('behavior: decodes signed quotes with optional v field undefined', () => {
667
+ const dataWithUndefinedV = {
668
+ ...validSignedData,
669
+ v: undefined,
670
+ }
671
+ const result = z.parse(Quotes.Signed, dataWithUndefinedV)
672
+ expect(result.v).toBeUndefined()
673
+ expect(result.yParity).toBe('0x0')
674
+ })
675
+
676
+ test('behavior: decodes signed quotes with optional yParity field undefined', () => {
677
+ const dataWithUndefinedYParity = {
678
+ ...validSignedData,
679
+ yParity: undefined,
680
+ }
681
+ const result = z.parse(Quotes.Signed, dataWithUndefinedYParity)
682
+ expect(result.yParity).toBeUndefined()
683
+ expect(result.v).toBe('0x1b')
684
+ })
685
+
686
+ test('behavior: decodes signed quotes with both v and yParity undefined', () => {
687
+ const dataWithBothUndefined = {
688
+ ...validSignedData,
689
+ v: undefined,
690
+ yParity: undefined,
691
+ }
692
+ const result = z.parse(Quotes.Signed, dataWithBothUndefined)
693
+ expect(result.v).toBeUndefined()
694
+ expect(result.yParity).toBeUndefined()
695
+ })
696
+
697
+ test.each([
698
+ {
699
+ data: {
700
+ ...validSignedData,
701
+ v: '0x1b',
702
+ yParity: undefined,
703
+ },
704
+ expectedV: '0x1b',
705
+ expectedYParity: undefined,
706
+ },
707
+ {
708
+ data: {
709
+ ...validSignedData,
710
+ v: undefined,
711
+ yParity: '0x1',
712
+ },
713
+ expectedV: undefined,
714
+ expectedYParity: '0x1',
715
+ },
716
+ ])(
717
+ 'behavior: decodes signed quotes with v=$expectedV yParity=$expectedYParity',
718
+ ({ data, expectedV, expectedYParity }) => {
719
+ const result = z.parse(Quotes.Signed, data)
720
+ expect(result.v).toBe(expectedV)
721
+ expect(result.yParity).toBe(expectedYParity)
722
+ },
723
+ )
724
+
725
+ test('behavior: inherits all base Quotes fields', () => {
726
+ const result = z.parse(Quotes.Signed, validSignedData)
727
+
728
+ // Verify all Quotes fields are present
729
+ expect(result.quotes).toHaveLength(1)
730
+ expect(result.multiChainRoot).toBe(validSignedData.multiChainRoot)
731
+ expect(result.ttl).toBe(validSignedData.ttl)
732
+
733
+ // Verify signature fields are present
734
+ expect(result.hash).toBe(validSignedData.hash)
735
+ expect(result.r).toBe(validSignedData.r)
736
+ expect(result.s).toBe(validSignedData.s)
737
+ expect(result.v).toBe(validSignedData.v)
738
+ expect(result.yParity).toBe(validSignedData.yParity)
739
+ })
740
+
741
+ test('error: rejects invalid hash format', () => {
742
+ expect(() =>
743
+ z.parse(Quotes.Signed, {
744
+ ...validSignedData,
745
+ hash: 'invalid-hash',
746
+ }),
747
+ ).toThrowErrorMatchingInlineSnapshot(`
748
+ [$ZodError: [
749
+ {
750
+ "code": "invalid_format",
751
+ "format": "template_literal",
752
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
753
+ "path": [
754
+ "hash"
755
+ ],
756
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
757
+ }
758
+ ]]
759
+ `)
760
+ })
761
+
762
+ test('error: rejects invalid r signature component', () => {
763
+ expect(() =>
764
+ z.parse(Quotes.Signed, {
765
+ ...validSignedData,
766
+ r: 'invalid-r',
767
+ }),
768
+ ).toThrowErrorMatchingInlineSnapshot(`
769
+ [$ZodError: [
770
+ {
771
+ "code": "invalid_format",
772
+ "format": "template_literal",
773
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
774
+ "path": [
775
+ "r"
776
+ ],
777
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
778
+ }
779
+ ]]
780
+ `)
781
+ })
782
+
783
+ test('error: rejects invalid s signature component', () => {
784
+ expect(() =>
785
+ z.parse(Quotes.Signed, {
786
+ ...validSignedData,
787
+ s: 'invalid-s',
788
+ }),
789
+ ).toThrowErrorMatchingInlineSnapshot(`
790
+ [$ZodError: [
791
+ {
792
+ "code": "invalid_format",
793
+ "format": "template_literal",
794
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
795
+ "path": [
796
+ "s"
797
+ ],
798
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
799
+ }
800
+ ]]
801
+ `)
802
+ })
803
+
804
+ test('error: rejects invalid v signature component', () => {
805
+ expect(() =>
806
+ z.parse(Quotes.Signed, {
807
+ ...validSignedData,
808
+ v: 'invalid-v',
809
+ }),
810
+ ).toThrowErrorMatchingInlineSnapshot(`
811
+ [$ZodError: [
812
+ {
813
+ "code": "invalid_format",
814
+ "format": "template_literal",
815
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
816
+ "path": [
817
+ "v"
818
+ ],
819
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
820
+ }
821
+ ]]
822
+ `)
823
+ })
824
+
825
+ test('error: rejects invalid yParity signature component', () => {
826
+ expect(() =>
827
+ z.parse(Quotes.Signed, {
828
+ ...validSignedData,
829
+ yParity: 'invalid-yParity',
830
+ }),
831
+ ).toThrowErrorMatchingInlineSnapshot(`
832
+ [$ZodError: [
833
+ {
834
+ "code": "invalid_format",
835
+ "format": "template_literal",
836
+ "pattern": "^0x[\\\\s\\\\S]{0,}$",
837
+ "path": [
838
+ "yParity"
839
+ ],
840
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
841
+ }
842
+ ]]
843
+ `)
844
+ })
845
+
846
+ test('error: rejects missing required signature fields', () => {
847
+ expect(() =>
848
+ z.parse(Quotes.Signed, {
849
+ ...validSignedData,
850
+ hash: undefined,
851
+ r: undefined,
852
+ s: undefined,
853
+ }),
854
+ ).toThrowErrorMatchingInlineSnapshot(`
855
+ [$ZodError: [
856
+ {
857
+ "expected": "template_literal",
858
+ "code": "invalid_type",
859
+ "path": [
860
+ "hash"
861
+ ],
862
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
863
+ },
864
+ {
865
+ "expected": "template_literal",
866
+ "code": "invalid_type",
867
+ "path": [
868
+ "r"
869
+ ],
870
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
871
+ },
872
+ {
873
+ "expected": "template_literal",
874
+ "code": "invalid_type",
875
+ "path": [
876
+ "s"
877
+ ],
878
+ "message": "Needs string in format ^0x[A-Fa-f0-9]+$."
879
+ }
880
+ ]]
881
+ `)
882
+ })
883
+
884
+ test('misc: signed quotes contains all quotes fields plus signature fields', () => {
885
+ const signedDecoded = z.parse(Quotes.Signed, validSignedData)
886
+ const { hash, r, s, v, yParity, ...quotesOnlyData } = validSignedData
887
+ const quotesDecoded = z.parse(Quotes.Quotes, quotesOnlyData)
888
+
889
+ // Verify all Quotes fields match
890
+ expect(signedDecoded.quotes).toEqual(quotesDecoded.quotes)
891
+ expect(signedDecoded.multiChainRoot).toBe(quotesDecoded.multiChainRoot)
892
+ expect(signedDecoded.ttl).toBe(quotesDecoded.ttl)
893
+
894
+ // Verify signature fields are only present in signed quotes
895
+ expect(signedDecoded.hash).toBeDefined()
896
+ expect(signedDecoded.r).toBeDefined()
897
+ expect(signedDecoded.s).toBeDefined()
898
+ expect(signedDecoded.v).toBeDefined()
899
+ expect(signedDecoded.yParity).toBeDefined()
900
+ })
901
+ })