@toon-protocol/connector 3.3.1 → 3.3.2

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 (473) hide show
  1. package/dist/btp/btp-claim-types.d.ts +52 -0
  2. package/dist/btp/btp-claim-types.d.ts.map +1 -0
  3. package/dist/btp/btp-claim-types.js +209 -0
  4. package/dist/btp/btp-claim-types.js.map +1 -0
  5. package/dist/btp/btp-client-manager.d.ts +30 -0
  6. package/dist/btp/btp-client-manager.d.ts.map +1 -0
  7. package/dist/btp/btp-client-manager.js +153 -0
  8. package/dist/btp/btp-client-manager.js.map +1 -0
  9. package/dist/btp/btp-client.d.ts +58 -0
  10. package/dist/btp/btp-client.d.ts.map +1 -0
  11. package/dist/btp/btp-client.js +485 -0
  12. package/dist/btp/btp-client.js.map +1 -0
  13. package/dist/btp/btp-message-parser.d.ts +4 -0
  14. package/dist/btp/btp-message-parser.d.ts.map +1 -0
  15. package/dist/btp/btp-message-parser.js +211 -0
  16. package/dist/btp/btp-message-parser.js.map +1 -0
  17. package/dist/btp/btp-server.d.ts +33 -0
  18. package/dist/btp/btp-server.d.ts.map +1 -0
  19. package/dist/btp/btp-server.js +485 -0
  20. package/dist/btp/btp-server.js.map +1 -0
  21. package/dist/btp/btp-types.d.ts +43 -0
  22. package/dist/btp/btp-types.d.ts.map +1 -0
  23. package/dist/btp/btp-types.js +44 -0
  24. package/dist/btp/btp-types.js.map +1 -0
  25. package/dist/btp/inbound-claim-validator.d.ts +20 -0
  26. package/dist/btp/inbound-claim-validator.d.ts.map +1 -0
  27. package/dist/btp/inbound-claim-validator.js +150 -0
  28. package/dist/btp/inbound-claim-validator.js.map +1 -0
  29. package/dist/cli/index.d.ts +3 -0
  30. package/dist/cli/index.d.ts.map +1 -0
  31. package/dist/cli/index.js +175 -0
  32. package/dist/cli/index.js.map +1 -0
  33. package/dist/cli/onboarding-wizard.d.ts +7 -0
  34. package/dist/cli/onboarding-wizard.d.ts.map +1 -0
  35. package/dist/cli/onboarding-wizard.js +257 -0
  36. package/dist/cli/onboarding-wizard.js.map +1 -0
  37. package/dist/cli/types.d.ts +38 -0
  38. package/dist/cli/types.d.ts.map +1 -0
  39. package/dist/cli/types.js +3 -0
  40. package/dist/cli/types.js.map +1 -0
  41. package/dist/config/config-loader.d.ts +24 -0
  42. package/dist/config/config-loader.d.ts.map +1 -0
  43. package/dist/config/config-loader.js +436 -0
  44. package/dist/config/config-loader.js.map +1 -0
  45. package/dist/config/environment-validator.d.ts +4 -0
  46. package/dist/config/environment-validator.d.ts.map +1 -0
  47. package/dist/config/environment-validator.js +239 -0
  48. package/dist/config/environment-validator.js.map +1 -0
  49. package/dist/config/index.d.ts +3 -0
  50. package/dist/config/index.d.ts.map +1 -0
  51. package/dist/config/index.js +7 -0
  52. package/dist/config/index.js.map +1 -0
  53. package/dist/config/key-manager-config.d.ts +7 -0
  54. package/dist/config/key-manager-config.d.ts.map +1 -0
  55. package/dist/config/key-manager-config.js +209 -0
  56. package/dist/config/key-manager-config.js.map +1 -0
  57. package/dist/config/topology-validator.d.ts +14 -0
  58. package/dist/config/topology-validator.d.ts.map +1 -0
  59. package/dist/config/topology-validator.js +142 -0
  60. package/dist/config/topology-validator.js.map +1 -0
  61. package/dist/config/types.d.ts +226 -0
  62. package/dist/config/types.d.ts.map +1 -0
  63. package/dist/config/types.js +52 -0
  64. package/dist/config/types.js.map +1 -0
  65. package/dist/core/connector-node.d.ts +91 -0
  66. package/dist/core/connector-node.d.ts.map +1 -0
  67. package/dist/core/connector-node.js +1322 -0
  68. package/dist/core/connector-node.js.map +1 -0
  69. package/dist/core/local-delivery-client.d.ts +16 -0
  70. package/dist/core/local-delivery-client.d.ts.map +1 -0
  71. package/dist/core/local-delivery-client.js +160 -0
  72. package/dist/core/local-delivery-client.js.map +1 -0
  73. package/dist/core/packet-handler.d.ts +57 -0
  74. package/dist/core/packet-handler.d.ts.map +1 -0
  75. package/dist/core/packet-handler.js +655 -0
  76. package/dist/core/packet-handler.js.map +1 -0
  77. package/dist/core/payment-handler.d.ts +25 -0
  78. package/dist/core/payment-handler.d.ts.map +1 -0
  79. package/dist/core/payment-handler.js +104 -0
  80. package/dist/core/payment-handler.js.map +1 -0
  81. package/dist/discovery/index.d.ts +3 -0
  82. package/dist/discovery/index.d.ts.map +1 -0
  83. package/dist/discovery/index.js +6 -0
  84. package/dist/discovery/index.js.map +1 -0
  85. package/dist/discovery/peer-discovery-service.d.ts +29 -0
  86. package/dist/discovery/peer-discovery-service.d.ts.map +1 -0
  87. package/dist/discovery/peer-discovery-service.js +230 -0
  88. package/dist/discovery/peer-discovery-service.js.map +1 -0
  89. package/dist/discovery/types.d.ts +38 -0
  90. package/dist/discovery/types.d.ts.map +1 -0
  91. package/dist/discovery/types.js +3 -0
  92. package/dist/discovery/types.js.map +1 -0
  93. package/dist/encoding/oer-parser.d.ts +39 -0
  94. package/dist/encoding/oer-parser.d.ts.map +1 -0
  95. package/dist/encoding/oer-parser.js +154 -0
  96. package/dist/encoding/oer-parser.js.map +1 -0
  97. package/dist/facilitator/index.d.ts +2 -0
  98. package/dist/facilitator/index.d.ts.map +1 -0
  99. package/dist/facilitator/index.js +7 -0
  100. package/dist/facilitator/index.js.map +1 -0
  101. package/dist/facilitator/spsp-client.d.ts +18 -0
  102. package/dist/facilitator/spsp-client.d.ts.map +1 -0
  103. package/dist/facilitator/spsp-client.js +95 -0
  104. package/dist/facilitator/spsp-client.js.map +1 -0
  105. package/dist/http/admin-api-inventory.d.ts +29 -0
  106. package/dist/http/admin-api-inventory.d.ts.map +1 -0
  107. package/dist/http/admin-api-inventory.js +480 -0
  108. package/dist/http/admin-api-inventory.js.map +1 -0
  109. package/dist/http/admin-api.d.ts +182 -0
  110. package/dist/http/admin-api.d.ts.map +1 -0
  111. package/dist/http/admin-api.js +1324 -0
  112. package/dist/http/admin-api.js.map +1 -0
  113. package/dist/http/admin-server.d.ts +49 -0
  114. package/dist/http/admin-server.d.ts.map +1 -0
  115. package/dist/http/admin-server.js +160 -0
  116. package/dist/http/admin-server.js.map +1 -0
  117. package/dist/http/health-server.d.ts +22 -0
  118. package/dist/http/health-server.d.ts.map +1 -0
  119. package/dist/http/health-server.js +192 -0
  120. package/dist/http/health-server.js.map +1 -0
  121. package/dist/http/ilp-send-handler.d.ts +15 -0
  122. package/dist/http/ilp-send-handler.d.ts.map +1 -0
  123. package/dist/http/ilp-send-handler.js +167 -0
  124. package/dist/http/ilp-send-handler.js.map +1 -0
  125. package/dist/http/types.d.ts +43 -0
  126. package/dist/http/types.d.ts.map +1 -0
  127. package/dist/http/types.js +3 -0
  128. package/dist/http/types.js.map +1 -0
  129. package/dist/index.d.ts +2 -0
  130. package/dist/index.d.ts.map +1 -0
  131. package/dist/index.js +5 -0
  132. package/dist/index.js.map +1 -0
  133. package/dist/lib.d.ts +22 -0
  134. package/dist/lib.d.ts.map +1 -0
  135. package/dist/lib.js +39 -0
  136. package/dist/lib.js.map +1 -0
  137. package/dist/main.d.ts +4 -0
  138. package/dist/main.d.ts.map +1 -0
  139. package/dist/main.js +79 -0
  140. package/dist/main.js.map +1 -0
  141. package/dist/observability/metrics-registry.d.ts +39 -0
  142. package/dist/observability/metrics-registry.d.ts.map +1 -0
  143. package/dist/observability/metrics-registry.js +151 -0
  144. package/dist/observability/metrics-registry.js.map +1 -0
  145. package/dist/routing/packet-processor.d.ts +36 -0
  146. package/dist/routing/packet-processor.d.ts.map +1 -0
  147. package/dist/routing/packet-processor.js +112 -0
  148. package/dist/routing/packet-processor.js.map +1 -0
  149. package/dist/routing/packet-worker.d.ts +10 -0
  150. package/dist/routing/packet-worker.d.ts.map +1 -0
  151. package/dist/routing/packet-worker.js +34 -0
  152. package/dist/routing/packet-worker.js.map +1 -0
  153. package/dist/routing/routing-table.d.ts +15 -0
  154. package/dist/routing/routing-table.d.ts.map +1 -0
  155. package/dist/routing/routing-table.js +63 -0
  156. package/dist/routing/routing-table.js.map +1 -0
  157. package/dist/routing/worker-pool.d.ts +43 -0
  158. package/dist/routing/worker-pool.d.ts.map +1 -0
  159. package/dist/routing/worker-pool.js +228 -0
  160. package/dist/routing/worker-pool.js.map +1 -0
  161. package/dist/security/alert-notifier.d.ts +34 -0
  162. package/dist/security/alert-notifier.d.ts.map +1 -0
  163. package/dist/security/alert-notifier.js +136 -0
  164. package/dist/security/alert-notifier.js.map +1 -0
  165. package/dist/security/audit-logger.d.ts +34 -0
  166. package/dist/security/audit-logger.d.ts.map +1 -0
  167. package/dist/security/audit-logger.js +132 -0
  168. package/dist/security/audit-logger.js.map +1 -0
  169. package/dist/security/backends/environment-backend.d.ts +15 -0
  170. package/dist/security/backends/environment-backend.d.ts.map +1 -0
  171. package/dist/security/backends/environment-backend.js +56 -0
  172. package/dist/security/backends/environment-backend.js.map +1 -0
  173. package/dist/security/fraud-detector.d.ts +79 -0
  174. package/dist/security/fraud-detector.d.ts.map +1 -0
  175. package/dist/security/fraud-detector.js +147 -0
  176. package/dist/security/fraud-detector.js.map +1 -0
  177. package/dist/security/key-manager-signer.d.ts +15 -0
  178. package/dist/security/key-manager-signer.d.ts.map +1 -0
  179. package/dist/security/key-manager-signer.js +91 -0
  180. package/dist/security/key-manager-signer.js.map +1 -0
  181. package/dist/security/key-manager.d.ts +69 -0
  182. package/dist/security/key-manager.d.ts.map +1 -0
  183. package/dist/security/key-manager.js +79 -0
  184. package/dist/security/key-manager.js.map +1 -0
  185. package/dist/security/key-rotation-manager.d.ts +27 -0
  186. package/dist/security/key-rotation-manager.d.ts.map +1 -0
  187. package/dist/security/key-rotation-manager.js +142 -0
  188. package/dist/security/key-rotation-manager.js.map +1 -0
  189. package/dist/security/rate-limit-config.d.ts +7 -0
  190. package/dist/security/rate-limit-config.d.ts.map +1 -0
  191. package/dist/security/rate-limit-config.js +57 -0
  192. package/dist/security/rate-limit-config.js.map +1 -0
  193. package/dist/security/rate-limiter.d.ts +46 -0
  194. package/dist/security/rate-limiter.d.ts.map +1 -0
  195. package/dist/security/rate-limiter.js +170 -0
  196. package/dist/security/rate-limiter.js.map +1 -0
  197. package/dist/security/reputation-tracker.d.ts +30 -0
  198. package/dist/security/reputation-tracker.d.ts.map +1 -0
  199. package/dist/security/reputation-tracker.js +111 -0
  200. package/dist/security/reputation-tracker.js.map +1 -0
  201. package/dist/security/rules/balance-manipulation-rule.d.ts +23 -0
  202. package/dist/security/rules/balance-manipulation-rule.d.ts.map +1 -0
  203. package/dist/security/rules/balance-manipulation-rule.js +70 -0
  204. package/dist/security/rules/balance-manipulation-rule.js.map +1 -0
  205. package/dist/security/rules/double-spend-detection-rule.d.ts +23 -0
  206. package/dist/security/rules/double-spend-detection-rule.d.ts.map +1 -0
  207. package/dist/security/rules/double-spend-detection-rule.js +61 -0
  208. package/dist/security/rules/double-spend-detection-rule.js.map +1 -0
  209. package/dist/security/rules/rapid-channel-closure-rule.d.ts +16 -0
  210. package/dist/security/rules/rapid-channel-closure-rule.d.ts.map +1 -0
  211. package/dist/security/rules/rapid-channel-closure-rule.js +57 -0
  212. package/dist/security/rules/rapid-channel-closure-rule.js.map +1 -0
  213. package/dist/security/rules/sudden-traffic-spike-rule.d.ts +18 -0
  214. package/dist/security/rules/sudden-traffic-spike-rule.d.ts.map +1 -0
  215. package/dist/security/rules/sudden-traffic-spike-rule.js +92 -0
  216. package/dist/security/rules/sudden-traffic-spike-rule.js.map +1 -0
  217. package/dist/security/rules/unusual-settlement-amount-rule.d.ts +12 -0
  218. package/dist/security/rules/unusual-settlement-amount-rule.d.ts.map +1 -0
  219. package/dist/security/rules/unusual-settlement-amount-rule.js +33 -0
  220. package/dist/security/rules/unusual-settlement-amount-rule.js.map +1 -0
  221. package/dist/security/token-bucket.d.ts +16 -0
  222. package/dist/security/token-bucket.d.ts.map +1 -0
  223. package/dist/security/token-bucket.js +49 -0
  224. package/dist/security/token-bucket.js.map +1 -0
  225. package/dist/security/violation-counter.d.ts +11 -0
  226. package/dist/security/violation-counter.d.ts.map +1 -0
  227. package/dist/security/violation-counter.js +61 -0
  228. package/dist/security/violation-counter.js.map +1 -0
  229. package/dist/settlement/account-id-generator.d.ts +4 -0
  230. package/dist/settlement/account-id-generator.d.ts.map +1 -0
  231. package/dist/settlement/account-id-generator.js +38 -0
  232. package/dist/settlement/account-id-generator.js.map +1 -0
  233. package/dist/settlement/account-manager.d.ts +51 -0
  234. package/dist/settlement/account-manager.d.ts.map +1 -0
  235. package/dist/settlement/account-manager.js +459 -0
  236. package/dist/settlement/account-manager.js.map +1 -0
  237. package/dist/settlement/account-metadata.d.ts +11 -0
  238. package/dist/settlement/account-metadata.d.ts.map +1 -0
  239. package/dist/settlement/account-metadata.js +40 -0
  240. package/dist/settlement/account-metadata.js.map +1 -0
  241. package/dist/settlement/channel-manager.d.ts +67 -0
  242. package/dist/settlement/channel-manager.d.ts.map +1 -0
  243. package/dist/settlement/channel-manager.js +226 -0
  244. package/dist/settlement/channel-manager.js.map +1 -0
  245. package/dist/settlement/claim-receiver-db-schema.d.ts +4 -0
  246. package/dist/settlement/claim-receiver-db-schema.d.ts.map +1 -0
  247. package/dist/settlement/claim-receiver-db-schema.js +25 -0
  248. package/dist/settlement/claim-receiver-db-schema.js.map +1 -0
  249. package/dist/settlement/claim-receiver.d.ts +67 -0
  250. package/dist/settlement/claim-receiver.d.ts.map +1 -0
  251. package/dist/settlement/claim-receiver.js +707 -0
  252. package/dist/settlement/claim-receiver.js.map +1 -0
  253. package/dist/settlement/claim-redemption-service.d.ts +39 -0
  254. package/dist/settlement/claim-redemption-service.d.ts.map +1 -0
  255. package/dist/settlement/claim-redemption-service.js +189 -0
  256. package/dist/settlement/claim-redemption-service.js.map +1 -0
  257. package/dist/settlement/claim-sender-db-schema.d.ts +3 -0
  258. package/dist/settlement/claim-sender-db-schema.d.ts.map +1 -0
  259. package/dist/settlement/claim-sender-db-schema.js +18 -0
  260. package/dist/settlement/claim-sender-db-schema.js.map +1 -0
  261. package/dist/settlement/claim-sender.d.ts +24 -0
  262. package/dist/settlement/claim-sender.d.ts.map +1 -0
  263. package/dist/settlement/claim-sender.js +146 -0
  264. package/dist/settlement/claim-sender.js.map +1 -0
  265. package/dist/settlement/eip712-helper.d.ts +13 -0
  266. package/dist/settlement/eip712-helper.d.ts.map +1 -0
  267. package/dist/settlement/eip712-helper.js +24 -0
  268. package/dist/settlement/eip712-helper.js.map +1 -0
  269. package/dist/settlement/in-memory-ledger-client.d.ts +40 -0
  270. package/dist/settlement/in-memory-ledger-client.d.ts.map +1 -0
  271. package/dist/settlement/in-memory-ledger-client.js +177 -0
  272. package/dist/settlement/in-memory-ledger-client.js.map +1 -0
  273. package/dist/settlement/ledger-client.d.ts +22 -0
  274. package/dist/settlement/ledger-client.d.ts.map +1 -0
  275. package/dist/settlement/ledger-client.js +3 -0
  276. package/dist/settlement/ledger-client.js.map +1 -0
  277. package/dist/settlement/metrics-collector.d.ts +29 -0
  278. package/dist/settlement/metrics-collector.d.ts.map +1 -0
  279. package/dist/settlement/metrics-collector.js +81 -0
  280. package/dist/settlement/metrics-collector.js.map +1 -0
  281. package/dist/settlement/mina-payment-channel-sdk.d.ts +73 -0
  282. package/dist/settlement/mina-payment-channel-sdk.d.ts.map +1 -0
  283. package/dist/settlement/mina-payment-channel-sdk.js +538 -0
  284. package/dist/settlement/mina-payment-channel-sdk.js.map +1 -0
  285. package/dist/settlement/payment-channel-sdk.d.ts +59 -0
  286. package/dist/settlement/payment-channel-sdk.d.ts.map +1 -0
  287. package/dist/settlement/payment-channel-sdk.js +677 -0
  288. package/dist/settlement/payment-channel-sdk.js.map +1 -0
  289. package/dist/settlement/per-packet-claim-service.d.ts +39 -0
  290. package/dist/settlement/per-packet-claim-service.d.ts.map +1 -0
  291. package/dist/settlement/per-packet-claim-service.js +342 -0
  292. package/dist/settlement/per-packet-claim-service.js.map +1 -0
  293. package/dist/settlement/privacy/index.d.ts +3 -0
  294. package/dist/settlement/privacy/index.d.ts.map +1 -0
  295. package/dist/settlement/privacy/index.js +11 -0
  296. package/dist/settlement/privacy/index.js.map +1 -0
  297. package/dist/settlement/privacy/nip59-claim-wrapper.d.ts +60 -0
  298. package/dist/settlement/privacy/nip59-claim-wrapper.d.ts.map +1 -0
  299. package/dist/settlement/privacy/nip59-claim-wrapper.js +361 -0
  300. package/dist/settlement/privacy/nip59-claim-wrapper.js.map +1 -0
  301. package/dist/settlement/provider/chain-provider-registry.d.ts +20 -0
  302. package/dist/settlement/provider/chain-provider-registry.d.ts.map +1 -0
  303. package/dist/settlement/provider/chain-provider-registry.js +53 -0
  304. package/dist/settlement/provider/chain-provider-registry.js.map +1 -0
  305. package/dist/settlement/provider/evm-payment-channel-provider.d.ts +31 -0
  306. package/dist/settlement/provider/evm-payment-channel-provider.d.ts.map +1 -0
  307. package/dist/settlement/provider/evm-payment-channel-provider.js +207 -0
  308. package/dist/settlement/provider/evm-payment-channel-provider.js.map +1 -0
  309. package/dist/settlement/provider/index.d.ts +6 -0
  310. package/dist/settlement/provider/index.d.ts.map +1 -0
  311. package/dist/settlement/provider/index.js +16 -0
  312. package/dist/settlement/provider/index.js.map +1 -0
  313. package/dist/settlement/provider/mina-payment-channel-provider.d.ts +43 -0
  314. package/dist/settlement/provider/mina-payment-channel-provider.d.ts.map +1 -0
  315. package/dist/settlement/provider/mina-payment-channel-provider.js +330 -0
  316. package/dist/settlement/provider/mina-payment-channel-provider.js.map +1 -0
  317. package/dist/settlement/provider/payment-channel-provider.d.ts +88 -0
  318. package/dist/settlement/provider/payment-channel-provider.d.ts.map +1 -0
  319. package/dist/settlement/provider/payment-channel-provider.js +3 -0
  320. package/dist/settlement/provider/payment-channel-provider.js.map +1 -0
  321. package/dist/settlement/provider/solana-payment-channel-provider.d.ts +38 -0
  322. package/dist/settlement/provider/solana-payment-channel-provider.d.ts.map +1 -0
  323. package/dist/settlement/provider/solana-payment-channel-provider.js +262 -0
  324. package/dist/settlement/provider/solana-payment-channel-provider.js.map +1 -0
  325. package/dist/settlement/sent-claims-queries.d.ts +23 -0
  326. package/dist/settlement/sent-claims-queries.d.ts.map +1 -0
  327. package/dist/settlement/sent-claims-queries.js +134 -0
  328. package/dist/settlement/sent-claims-queries.js.map +1 -0
  329. package/dist/settlement/settlement-api.d.ts +37 -0
  330. package/dist/settlement/settlement-api.d.ts.map +1 -0
  331. package/dist/settlement/settlement-api.js +172 -0
  332. package/dist/settlement/settlement-api.js.map +1 -0
  333. package/dist/settlement/settlement-coordinator.d.ts +47 -0
  334. package/dist/settlement/settlement-coordinator.d.ts.map +1 -0
  335. package/dist/settlement/settlement-coordinator.js +166 -0
  336. package/dist/settlement/settlement-coordinator.js.map +1 -0
  337. package/dist/settlement/settlement-executor.d.ts +51 -0
  338. package/dist/settlement/settlement-executor.d.ts.map +1 -0
  339. package/dist/settlement/settlement-executor.js +265 -0
  340. package/dist/settlement/settlement-executor.js.map +1 -0
  341. package/dist/settlement/settlement-monitor.d.ts +30 -0
  342. package/dist/settlement/settlement-monitor.d.ts.map +1 -0
  343. package/dist/settlement/settlement-monitor.js +141 -0
  344. package/dist/settlement/settlement-monitor.js.map +1 -0
  345. package/dist/settlement/solana-payment-channel-sdk.d.ts +79 -0
  346. package/dist/settlement/solana-payment-channel-sdk.d.ts.map +1 -0
  347. package/dist/settlement/solana-payment-channel-sdk.js +636 -0
  348. package/dist/settlement/solana-payment-channel-sdk.js.map +1 -0
  349. package/dist/settlement/tigerbeetle-batch-writer.d.ts +58 -0
  350. package/dist/settlement/tigerbeetle-batch-writer.d.ts.map +1 -0
  351. package/dist/settlement/tigerbeetle-batch-writer.js +162 -0
  352. package/dist/settlement/tigerbeetle-batch-writer.js.map +1 -0
  353. package/dist/settlement/tigerbeetle-client.d.ts +40 -0
  354. package/dist/settlement/tigerbeetle-client.d.ts.map +1 -0
  355. package/dist/settlement/tigerbeetle-client.js +279 -0
  356. package/dist/settlement/tigerbeetle-client.js.map +1 -0
  357. package/dist/settlement/tigerbeetle-errors.d.ts +23 -0
  358. package/dist/settlement/tigerbeetle-errors.d.ts.map +1 -0
  359. package/dist/settlement/tigerbeetle-errors.js +58 -0
  360. package/dist/settlement/tigerbeetle-errors.js.map +1 -0
  361. package/dist/settlement/types.d.ts +64 -0
  362. package/dist/settlement/types.d.ts.map +1 -0
  363. package/dist/settlement/types.js +42 -0
  364. package/dist/settlement/types.js.map +1 -0
  365. package/dist/settlement/unified-settlement-executor.d.ts +34 -0
  366. package/dist/settlement/unified-settlement-executor.d.ts.map +1 -0
  367. package/dist/settlement/unified-settlement-executor.js +145 -0
  368. package/dist/settlement/unified-settlement-executor.js.map +1 -0
  369. package/dist/test-utils/index.d.ts +3 -0
  370. package/dist/test-utils/index.d.ts.map +1 -0
  371. package/dist/test-utils/index.js +15 -0
  372. package/dist/test-utils/index.js.map +1 -0
  373. package/dist/test-utils/isolated-test-env.d.ts +31 -0
  374. package/dist/test-utils/isolated-test-env.d.ts.map +1 -0
  375. package/dist/test-utils/isolated-test-env.js +127 -0
  376. package/dist/test-utils/isolated-test-env.js.map +1 -0
  377. package/dist/test-utils/mock-factories-patch.d.ts +2 -0
  378. package/dist/test-utils/mock-factories-patch.d.ts.map +1 -0
  379. package/dist/test-utils/mock-factories-patch.js +3 -0
  380. package/dist/test-utils/mock-factories-patch.js.map +1 -0
  381. package/dist/test-utils/mock-factories.d.ts +22 -0
  382. package/dist/test-utils/mock-factories.d.ts.map +1 -0
  383. package/dist/test-utils/mock-factories.js +56 -0
  384. package/dist/test-utils/mock-factories.js.map +1 -0
  385. package/dist/transport/direct-transport-provider.d.ts +12 -0
  386. package/dist/transport/direct-transport-provider.d.ts.map +1 -0
  387. package/dist/transport/direct-transport-provider.js +27 -0
  388. package/dist/transport/direct-transport-provider.js.map +1 -0
  389. package/dist/transport/index.d.ts +7 -0
  390. package/dist/transport/index.d.ts.map +1 -0
  391. package/dist/transport/index.js +16 -0
  392. package/dist/transport/index.js.map +1 -0
  393. package/dist/transport/managed-anon-client.d.ts +47 -0
  394. package/dist/transport/managed-anon-client.d.ts.map +1 -0
  395. package/dist/transport/managed-anon-client.js +265 -0
  396. package/dist/transport/managed-anon-client.js.map +1 -0
  397. package/dist/transport/probe-tcp-port.d.ts +3 -0
  398. package/dist/transport/probe-tcp-port.d.ts.map +1 -0
  399. package/dist/transport/probe-tcp-port.js +59 -0
  400. package/dist/transport/probe-tcp-port.js.map +1 -0
  401. package/dist/transport/socks-transport-provider.d.ts +29 -0
  402. package/dist/transport/socks-transport-provider.d.ts.map +1 -0
  403. package/dist/transport/socks-transport-provider.js +136 -0
  404. package/dist/transport/socks-transport-provider.js.map +1 -0
  405. package/dist/transport/socks-url.d.ts +6 -0
  406. package/dist/transport/socks-url.d.ts.map +1 -0
  407. package/dist/transport/socks-url.js +29 -0
  408. package/dist/transport/socks-url.js.map +1 -0
  409. package/dist/transport/transport-provider.d.ts +9 -0
  410. package/dist/transport/transport-provider.d.ts.map +1 -0
  411. package/dist/transport/transport-provider.js +3 -0
  412. package/dist/transport/transport-provider.js.map +1 -0
  413. package/dist/utils/connection-pool.d.ts +42 -0
  414. package/dist/utils/connection-pool.d.ts.map +1 -0
  415. package/dist/utils/connection-pool.js +209 -0
  416. package/dist/utils/connection-pool.js.map +1 -0
  417. package/dist/utils/evm-rpc-connection-pool.d.ts +8 -0
  418. package/dist/utils/evm-rpc-connection-pool.d.ts.map +1 -0
  419. package/dist/utils/evm-rpc-connection-pool.js +40 -0
  420. package/dist/utils/evm-rpc-connection-pool.js.map +1 -0
  421. package/dist/utils/logger.d.ts +6 -0
  422. package/dist/utils/logger.d.ts.map +1 -0
  423. package/dist/utils/logger.js +58 -0
  424. package/dist/utils/logger.js.map +1 -0
  425. package/dist/utils/optional-require.d.ts +2 -0
  426. package/dist/utils/optional-require.d.ts.map +1 -0
  427. package/dist/utils/optional-require.js +54 -0
  428. package/dist/utils/optional-require.js.map +1 -0
  429. package/dist/utils/redact.d.ts +3 -0
  430. package/dist/utils/redact.d.ts.map +1 -0
  431. package/dist/utils/redact.js +21 -0
  432. package/dist/utils/redact.js.map +1 -0
  433. package/dist/wallet/audit-logger.d.ts +22 -0
  434. package/dist/wallet/audit-logger.d.ts.map +1 -0
  435. package/dist/wallet/audit-logger.js +120 -0
  436. package/dist/wallet/audit-logger.js.map +1 -0
  437. package/dist/wallet/fraud-detector-interface.d.ts +14 -0
  438. package/dist/wallet/fraud-detector-interface.d.ts.map +1 -0
  439. package/dist/wallet/fraud-detector-interface.js +3 -0
  440. package/dist/wallet/fraud-detector-interface.js.map +1 -0
  441. package/dist/wallet/key-manager.d.ts +6 -0
  442. package/dist/wallet/key-manager.d.ts.map +1 -0
  443. package/dist/wallet/key-manager.js +3 -0
  444. package/dist/wallet/key-manager.js.map +1 -0
  445. package/dist/wallet/rate-limiter.d.ts +26 -0
  446. package/dist/wallet/rate-limiter.d.ts.map +1 -0
  447. package/dist/wallet/rate-limiter.js +114 -0
  448. package/dist/wallet/rate-limiter.js.map +1 -0
  449. package/dist/wallet/suspicious-activity-detector.d.ts +25 -0
  450. package/dist/wallet/suspicious-activity-detector.d.ts.map +1 -0
  451. package/dist/wallet/suspicious-activity-detector.js +97 -0
  452. package/dist/wallet/suspicious-activity-detector.js.map +1 -0
  453. package/dist/wallet/treasury-wallet.d.ts +20 -0
  454. package/dist/wallet/treasury-wallet.d.ts.map +1 -0
  455. package/dist/wallet/treasury-wallet.js +151 -0
  456. package/dist/wallet/treasury-wallet.js.map +1 -0
  457. package/dist/wallet/wallet-authentication.d.ts +31 -0
  458. package/dist/wallet/wallet-authentication.d.ts.map +1 -0
  459. package/dist/wallet/wallet-authentication.js +102 -0
  460. package/dist/wallet/wallet-authentication.js.map +1 -0
  461. package/dist/wallet/wallet-db-schema.d.ts +11 -0
  462. package/dist/wallet/wallet-db-schema.d.ts.map +1 -0
  463. package/dist/wallet/wallet-db-schema.js +79 -0
  464. package/dist/wallet/wallet-db-schema.js.map +1 -0
  465. package/dist/wallet/wallet-security.d.ts +58 -0
  466. package/dist/wallet/wallet-security.d.ts.map +1 -0
  467. package/dist/wallet/wallet-security.js +148 -0
  468. package/dist/wallet/wallet-security.js.map +1 -0
  469. package/dist/wallet/wallet-seed-manager.d.ts +65 -0
  470. package/dist/wallet/wallet-seed-manager.d.ts.map +1 -0
  471. package/dist/wallet/wallet-seed-manager.js +418 -0
  472. package/dist/wallet/wallet-seed-manager.js.map +1 -0
  473. package/package.json +1 -1
@@ -0,0 +1,207 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMPaymentChannelProvider = void 0;
4
+ exports.createEVMProviderFactory = createEVMProviderFactory;
5
+ function safeBigInt(value, fieldName) {
6
+ try {
7
+ return BigInt(value);
8
+ }
9
+ catch {
10
+ const sanitized = value.length > 32 ? `${value.slice(0, 32)}...` : value;
11
+ throw new Error(`Invalid ${fieldName}: expected a numeric string, received "${sanitized}"`);
12
+ }
13
+ }
14
+ class EVMPaymentChannelProvider {
15
+ _sdk;
16
+ _tokenAddress;
17
+ _logger;
18
+ chainType = 'evm';
19
+ chainId;
20
+ constructor(_sdk, chainId, _tokenAddress, _logger) {
21
+ this._sdk = _sdk;
22
+ this._tokenAddress = _tokenAddress;
23
+ this._logger = _logger;
24
+ if (!chainId) {
25
+ throw new Error('EVMPaymentChannelProvider: chainId must not be empty');
26
+ }
27
+ if (!_tokenAddress) {
28
+ throw new Error('EVMPaymentChannelProvider: tokenAddress must not be empty');
29
+ }
30
+ this.chainId = chainId;
31
+ }
32
+ async openChannel(participant, settlementTimeout) {
33
+ this._logger.info('EVMPaymentChannelProvider: opening channel', {
34
+ participant,
35
+ settlementTimeout,
36
+ chainId: this.chainId,
37
+ });
38
+ const result = await this._sdk.openChannel(participant, this._tokenAddress, settlementTimeout, 0n);
39
+ return { channelId: result.channelId, txHash: result.txHash };
40
+ }
41
+ async deposit(channelId, amount) {
42
+ this._logger.info('EVMPaymentChannelProvider: depositing', {
43
+ channelId,
44
+ amount,
45
+ chainId: this.chainId,
46
+ });
47
+ await this._sdk.deposit(channelId, this._tokenAddress, safeBigInt(amount, 'deposit amount'));
48
+ return { txHash: '' };
49
+ }
50
+ async claimFromChannel(channelId, balanceProof, signature) {
51
+ this._logger.info('EVMPaymentChannelProvider: claiming from channel', {
52
+ channelId,
53
+ nonce: balanceProof.nonce,
54
+ chainId: this.chainId,
55
+ });
56
+ const sdkProof = this.toSdkBalanceProof(balanceProof);
57
+ await this._sdk.claimFromChannel(channelId, this._tokenAddress, sdkProof, signature);
58
+ return { txHash: '' };
59
+ }
60
+ async closeChannel(channelId) {
61
+ this._logger.info('EVMPaymentChannelProvider: closing channel', {
62
+ channelId,
63
+ chainId: this.chainId,
64
+ });
65
+ await this._sdk.closeChannel(channelId, this._tokenAddress);
66
+ return { txHash: '' };
67
+ }
68
+ async settleChannel(channelId) {
69
+ this._logger.info('EVMPaymentChannelProvider: settling channel', {
70
+ channelId,
71
+ chainId: this.chainId,
72
+ });
73
+ await this._sdk.settleChannel(channelId, this._tokenAddress);
74
+ return { txHash: '' };
75
+ }
76
+ async signBalanceProof(params) {
77
+ this._logger.debug('EVMPaymentChannelProvider: signing balance proof', {
78
+ channelId: params.channelId,
79
+ nonce: params.nonce,
80
+ chainId: this.chainId,
81
+ });
82
+ return this._sdk.signBalanceProof(params.channelId, params.nonce, safeBigInt(params.transferredAmount, 'transferredAmount'), safeBigInt(params.lockedAmount, 'lockedAmount'), params.locksRoot);
83
+ }
84
+ async verifyBalanceProof(params) {
85
+ this._logger.debug('EVMPaymentChannelProvider: verifying balance proof', {
86
+ channelId: params.channelId,
87
+ nonce: params.nonce,
88
+ chainId: this.chainId,
89
+ });
90
+ const sdkProof = this.toSdkBalanceProof(params);
91
+ return this._sdk.verifyBalanceProof(sdkProof, params.signature, params.signerAddress);
92
+ }
93
+ async getChannelState(channelId) {
94
+ const state = await this._sdk.getChannelState(channelId, this._tokenAddress);
95
+ return this.toProviderChannelState(state);
96
+ }
97
+ subscribeToEvents(channelId, callback) {
98
+ this._logger.debug('EVMPaymentChannelProvider: subscribing to events', {
99
+ channelId,
100
+ chainId: this.chainId,
101
+ });
102
+ let unsubscribed = false;
103
+ const forwardEvent = (type, eventChannelId, data) => {
104
+ if (unsubscribed)
105
+ return;
106
+ if (eventChannelId !== channelId)
107
+ return;
108
+ const event = {
109
+ type,
110
+ channelId: eventChannelId,
111
+ data,
112
+ };
113
+ callback(event);
114
+ };
115
+ const onRegError = (eventName, err) => {
116
+ this._logger.warn('EVMPaymentChannelProvider: event registration failed', {
117
+ eventName,
118
+ channelId,
119
+ chainId: this.chainId,
120
+ error: err instanceof Error ? err.message : String(err),
121
+ });
122
+ };
123
+ void this._sdk
124
+ .onChannelOpened(this._tokenAddress, (evt) => {
125
+ forwardEvent('channel_opened', evt.channelId, {
126
+ participant1: evt.participant1,
127
+ participant2: evt.participant2,
128
+ settlementTimeout: evt.settlementTimeout,
129
+ });
130
+ })
131
+ .catch((err) => onRegError('ChannelOpened', err));
132
+ void this._sdk
133
+ .onChannelClosed(this._tokenAddress, (evt) => {
134
+ forwardEvent('channel_closed', evt.channelId, {
135
+ closingParticipant: evt.closingParticipant,
136
+ });
137
+ })
138
+ .catch((err) => onRegError('ChannelClosed', err));
139
+ void this._sdk
140
+ .onChannelSettled(this._tokenAddress, (evt) => {
141
+ forwardEvent('channel_settled', evt.channelId, {
142
+ participant1Amount: evt.participant1Amount.toString(),
143
+ participant2Amount: evt.participant2Amount.toString(),
144
+ });
145
+ })
146
+ .catch((err) => onRegError('ChannelSettled', err));
147
+ void this._sdk
148
+ .onChannelCooperativeSettled(this._tokenAddress, (evt) => {
149
+ forwardEvent('channel_settled', evt.channelId, {
150
+ participant1Amount: evt.participant1Amount.toString(),
151
+ participant2Amount: evt.participant2Amount.toString(),
152
+ cooperative: true,
153
+ });
154
+ })
155
+ .catch((err) => onRegError('ChannelCooperativeSettled', err));
156
+ return {
157
+ unsubscribe: () => {
158
+ unsubscribed = true;
159
+ this._sdk.removeAllListeners();
160
+ this._logger.debug('EVMPaymentChannelProvider: unsubscribed from events', {
161
+ channelId,
162
+ chainId: this.chainId,
163
+ });
164
+ },
165
+ };
166
+ }
167
+ async getSigningContext() {
168
+ const [chainId, tokenNetworkAddress, signerAddress] = await Promise.all([
169
+ this._sdk.getChainId(),
170
+ this._sdk.getTokenNetworkAddress(this._tokenAddress),
171
+ this._sdk.getSignerAddress(),
172
+ ]);
173
+ return { chainId, tokenNetworkAddress, signerAddress };
174
+ }
175
+ toSdkBalanceProof(params) {
176
+ return {
177
+ channelId: params.channelId,
178
+ nonce: params.nonce,
179
+ transferredAmount: safeBigInt(params.transferredAmount, 'transferredAmount'),
180
+ lockedAmount: safeBigInt(params.lockedAmount, 'lockedAmount'),
181
+ locksRoot: params.locksRoot,
182
+ };
183
+ }
184
+ toProviderChannelState(state) {
185
+ return {
186
+ channelId: state.channelId,
187
+ status: state.status,
188
+ participants: [...state.participants],
189
+ deposit: state.myDeposit + state.theirDeposit,
190
+ };
191
+ }
192
+ }
193
+ exports.EVMPaymentChannelProvider = EVMPaymentChannelProvider;
194
+ function createEVMProviderFactory(sdk, logger) {
195
+ return (config) => {
196
+ if (config.chainType !== 'evm') {
197
+ throw new Error(`EVM factory received non-EVM config: ${config.chainType}`);
198
+ }
199
+ if (!/^[\w-]+$/.test(config.keyId)) {
200
+ throw new Error('EVM factory received invalid keyId: expected alphanumeric string with hyphens/underscores');
201
+ }
202
+ const chainId = `evm:${config.keyId}`;
203
+ const tokenAddress = config.registryAddress;
204
+ return new EVMPaymentChannelProvider(sdk, chainId, tokenAddress, logger);
205
+ };
206
+ }
207
+ //# sourceMappingURL=evm-payment-channel-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evm-payment-channel-provider.js","sourceRoot":"","sources":["../../../src/settlement/provider/evm-payment-channel-provider.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ export { type PaymentChannelProvider, type ProviderChannelState, type ProviderEventType, type ProviderEvent, type ProviderEventCallback, type ProviderEventSubscription, type OpenChannelResult, type TxResult, type BalanceProofParams, type VerifyBalanceProofParams, type ProviderConfig, type EVMProviderConfig, type SolanaProviderConfig, type MinaProviderConfig, } from './payment-channel-provider';
2
+ export { ChainProviderRegistry, ChainProviderAlreadyRegisteredError, type RegistryPeerConfig, type ChainProviderFactory, } from './chain-provider-registry';
3
+ export { EVMPaymentChannelProvider, createEVMProviderFactory, } from './evm-payment-channel-provider';
4
+ export { SolanaPaymentChannelProvider, createSolanaProviderFactory, } from './solana-payment-channel-provider';
5
+ export { MinaPaymentChannelProvider, createMinaProviderFactory, type MinaProviderOptions, } from './mina-payment-channel-provider';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/settlement/provider/index.ts"],"names":[],"mappings":"AAQA,OAAO,EACL,KAAK,sBAAsB,EAC3B,KAAK,oBAAoB,EACzB,KAAK,iBAAiB,EACtB,KAAK,aAAa,EAClB,KAAK,qBAAqB,EAC1B,KAAK,yBAAyB,EAC9B,KAAK,iBAAiB,EACtB,KAAK,QAAQ,EACb,KAAK,kBAAkB,EACvB,KAAK,wBAAwB,EAC7B,KAAK,cAAc,EACnB,KAAK,iBAAiB,EACtB,KAAK,oBAAoB,EACzB,KAAK,kBAAkB,GACxB,MAAM,4BAA4B,CAAC;AAEpC,OAAO,EACL,qBAAqB,EACrB,mCAAmC,EACnC,KAAK,kBAAkB,EACvB,KAAK,oBAAoB,GAC1B,MAAM,2BAA2B,CAAC;AAEnC,OAAO,EACL,yBAAyB,EACzB,wBAAwB,GACzB,MAAM,gCAAgC,CAAC;AAExC,OAAO,EACL,4BAA4B,EAC5B,2BAA2B,GAC5B,MAAM,mCAAmC,CAAC;AAE3C,OAAO,EACL,0BAA0B,EAC1B,yBAAyB,EACzB,KAAK,mBAAmB,GACzB,MAAM,iCAAiC,CAAC"}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createMinaProviderFactory = exports.MinaPaymentChannelProvider = exports.createSolanaProviderFactory = exports.SolanaPaymentChannelProvider = exports.createEVMProviderFactory = exports.EVMPaymentChannelProvider = exports.ChainProviderAlreadyRegisteredError = exports.ChainProviderRegistry = void 0;
4
+ var chain_provider_registry_1 = require("./chain-provider-registry");
5
+ Object.defineProperty(exports, "ChainProviderRegistry", { enumerable: true, get: function () { return chain_provider_registry_1.ChainProviderRegistry; } });
6
+ Object.defineProperty(exports, "ChainProviderAlreadyRegisteredError", { enumerable: true, get: function () { return chain_provider_registry_1.ChainProviderAlreadyRegisteredError; } });
7
+ var evm_payment_channel_provider_1 = require("./evm-payment-channel-provider");
8
+ Object.defineProperty(exports, "EVMPaymentChannelProvider", { enumerable: true, get: function () { return evm_payment_channel_provider_1.EVMPaymentChannelProvider; } });
9
+ Object.defineProperty(exports, "createEVMProviderFactory", { enumerable: true, get: function () { return evm_payment_channel_provider_1.createEVMProviderFactory; } });
10
+ var solana_payment_channel_provider_1 = require("./solana-payment-channel-provider");
11
+ Object.defineProperty(exports, "SolanaPaymentChannelProvider", { enumerable: true, get: function () { return solana_payment_channel_provider_1.SolanaPaymentChannelProvider; } });
12
+ Object.defineProperty(exports, "createSolanaProviderFactory", { enumerable: true, get: function () { return solana_payment_channel_provider_1.createSolanaProviderFactory; } });
13
+ var mina_payment_channel_provider_1 = require("./mina-payment-channel-provider");
14
+ Object.defineProperty(exports, "MinaPaymentChannelProvider", { enumerable: true, get: function () { return mina_payment_channel_provider_1.MinaPaymentChannelProvider; } });
15
+ Object.defineProperty(exports, "createMinaProviderFactory", { enumerable: true, get: function () { return mina_payment_channel_provider_1.createMinaProviderFactory; } });
16
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/settlement/provider/index.ts"],"names":[],"mappings":";;;AAyBA,qEAKmC;AAJjC,gIAAA,qBAAqB,OAAA;AACrB,8IAAA,mCAAmC,OAAA;AAKrC,+EAGwC;AAFtC,yIAAA,yBAAyB,OAAA;AACzB,wIAAA,wBAAwB,OAAA;AAG1B,qFAG2C;AAFzC,+IAAA,4BAA4B,OAAA;AAC5B,8IAAA,2BAA2B,OAAA;AAG7B,iFAIyC;AAHvC,2IAAA,0BAA0B,OAAA;AAC1B,0IAAA,yBAAyB,OAAA"}
@@ -0,0 +1,43 @@
1
+ import type { Logger } from '../../utils/logger';
2
+ import type { BlockchainType } from '../../btp/btp-claim-types';
3
+ import type { PaymentChannelProvider, ProviderChannelState, ProviderEventCallback, ProviderEventSubscription, OpenChannelResult, TxResult, BalanceProofParams, VerifyBalanceProofParams } from './payment-channel-provider';
4
+ import type { ChainProviderFactory } from './chain-provider-registry';
5
+ import { MinaPaymentChannelSDK } from '../mina-payment-channel-sdk';
6
+ export interface MinaProviderOptions {
7
+ tokenId?: string;
8
+ network?: string;
9
+ }
10
+ export declare class MinaPaymentChannelProvider implements PaymentChannelProvider {
11
+ private readonly _sdk;
12
+ private readonly _zkAppAddress;
13
+ private readonly _logger;
14
+ readonly chainType: BlockchainType;
15
+ readonly chainId: string;
16
+ private readonly _tokenId;
17
+ private readonly _network;
18
+ private _signerPublicKey;
19
+ constructor(_sdk: MinaPaymentChannelSDK, chainId: string, _zkAppAddress: string, signerKey: string, _logger: Logger, options?: MinaProviderOptions);
20
+ private _preCompile;
21
+ openChannel(participant: string, settlementTimeout: number): Promise<OpenChannelResult>;
22
+ deposit(channelId: string, amount: string): Promise<TxResult>;
23
+ claimFromChannel(channelId: string, balanceProof: BalanceProofParams, signature: string): Promise<TxResult>;
24
+ closeChannel(channelId: string, finalBalanceA?: bigint, finalBalanceB?: bigint, salt?: bigint, nonce?: bigint, signatureA?: string, signatureB?: string): Promise<TxResult>;
25
+ settleChannel(channelId: string, balanceA?: bigint, balanceB?: bigint, salt?: bigint, participantA?: string, participantB?: string, nonce?: bigint): Promise<TxResult>;
26
+ signBalanceProof(params: BalanceProofParams): Promise<string>;
27
+ verifyBalanceProof(params: VerifyBalanceProofParams): Promise<boolean>;
28
+ getChannelState(channelId: string): Promise<ProviderChannelState>;
29
+ subscribeToEvents(channelId: string, callback: ProviderEventCallback): ProviderEventSubscription;
30
+ getMinaContext(): Promise<{
31
+ zkAppAddress: string;
32
+ tokenId: string;
33
+ network: string;
34
+ signerAddress: string;
35
+ }>;
36
+ private _ensureSignerPublicKey;
37
+ private _toProviderChannelState;
38
+ private _diffState;
39
+ private _wrapError;
40
+ private _warnIfEVMFields;
41
+ }
42
+ export declare function createMinaProviderFactory(logger: Logger, signerKey: string): ChainProviderFactory;
43
+ //# sourceMappingURL=mina-payment-channel-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mina-payment-channel-provider.d.ts","sourceRoot":"","sources":["../../../src/settlement/provider/mina-payment-channel-provider.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,330 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MinaPaymentChannelProvider = void 0;
4
+ exports.createMinaProviderFactory = createMinaProviderFactory;
5
+ const mina_payment_channel_sdk_1 = require("../mina-payment-channel-sdk");
6
+ const MINA_CHANNEL_STATE = {
7
+ UNINITIALIZED: 0,
8
+ OPEN: 1,
9
+ CLOSING: 2,
10
+ SETTLED: 3,
11
+ };
12
+ function safeBigInt(value, fieldName) {
13
+ try {
14
+ return BigInt(value);
15
+ }
16
+ catch {
17
+ const sanitized = value.length > 32 ? `${value.slice(0, 32)}...` : value;
18
+ throw new Error(`Invalid ${fieldName}: expected a numeric string, received "${sanitized}"`);
19
+ }
20
+ }
21
+ class MinaPaymentChannelProvider {
22
+ _sdk;
23
+ _zkAppAddress;
24
+ _logger;
25
+ chainType = 'mina';
26
+ chainId;
27
+ _tokenId;
28
+ _network;
29
+ _signerPublicKey = null;
30
+ constructor(_sdk, chainId, _zkAppAddress, signerKey, _logger, options) {
31
+ this._sdk = _sdk;
32
+ this._zkAppAddress = _zkAppAddress;
33
+ this._logger = _logger;
34
+ if (!chainId) {
35
+ throw new Error('MinaPaymentChannelProvider: chainId must not be empty');
36
+ }
37
+ if (!_zkAppAddress) {
38
+ throw new Error('MinaPaymentChannelProvider: zkAppAddress must not be empty');
39
+ }
40
+ if (!signerKey) {
41
+ throw new Error('MinaPaymentChannelProvider: signerKey must not be empty');
42
+ }
43
+ this.chainId = chainId;
44
+ this._tokenId = options?.tokenId ?? 'MINA';
45
+ this._network = options?.network ?? chainId.split(':')[1] ?? 'devnet';
46
+ void this._preCompile();
47
+ }
48
+ async _preCompile() {
49
+ try {
50
+ await this._sdk.compileContract();
51
+ this._logger.info({ event: 'zkapp_compiled', chainId: this.chainId, zkAppAddress: this._zkAppAddress }, 'Mina zkApp circuit pre-compiled successfully');
52
+ }
53
+ catch (err) {
54
+ this._logger.error({
55
+ event: 'zkapp_compile_error',
56
+ chainId: this.chainId,
57
+ zkAppAddress: this._zkAppAddress,
58
+ error: err instanceof Error ? err.message : String(err),
59
+ }, 'Failed to pre-compile Mina zkApp circuit');
60
+ }
61
+ }
62
+ async openChannel(participant, settlementTimeout) {
63
+ this._logger.info({ event: 'open_channel', participant, settlementTimeout, chainId: this.chainId }, 'Opening Mina payment channel');
64
+ try {
65
+ const signerPublicKey = await this._ensureSignerPublicKey();
66
+ const result = await this._sdk.openChannel(signerPublicKey, participant, settlementTimeout, this._tokenId);
67
+ return { channelId: result.zkAppAddress, txHash: result.txHash };
68
+ }
69
+ catch (err) {
70
+ throw this._wrapError(err, 'openChannel', 'new');
71
+ }
72
+ }
73
+ async deposit(channelId, amount) {
74
+ this._logger.info({ event: 'deposit', channelId, amount, chainId: this.chainId }, 'Depositing into Mina payment channel');
75
+ try {
76
+ const result = await this._sdk.deposit(channelId, safeBigInt(amount, 'deposit amount'));
77
+ return { txHash: result.txHash };
78
+ }
79
+ catch (err) {
80
+ throw this._wrapError(err, 'deposit', channelId);
81
+ }
82
+ }
83
+ async claimFromChannel(channelId, balanceProof, signature) {
84
+ this._logger.info({ event: 'claim_from_channel', channelId, nonce: balanceProof.nonce, chainId: this.chainId }, 'Claiming from Mina payment channel');
85
+ this._warnIfEVMFields(balanceProof);
86
+ try {
87
+ const transferredAmount = safeBigInt(balanceProof.transferredAmount, 'transferredAmount');
88
+ const nonce = safeBigInt(String(balanceProof.nonce), 'nonce');
89
+ const result = await this._sdk.claimFromChannel(channelId, transferredAmount, 0n, 0n, nonce, signature, signature);
90
+ return { txHash: result.txHash };
91
+ }
92
+ catch (err) {
93
+ throw this._wrapError(err, 'claimFromChannel', channelId);
94
+ }
95
+ }
96
+ async closeChannel(channelId, finalBalanceA, finalBalanceB, salt, nonce, signatureA, signatureB) {
97
+ this._logger.info({ event: 'close_channel', channelId, chainId: this.chainId }, 'Closing Mina payment channel');
98
+ try {
99
+ const result = await this._sdk.closeChannel(channelId, finalBalanceA ?? 0n, finalBalanceB ?? 0n, salt ?? 0n, nonce ?? 0n, signatureA ?? '{"r":"0","s":"0"}', signatureB ?? '{"r":"0","s":"0"}');
100
+ return { txHash: result.txHash };
101
+ }
102
+ catch (err) {
103
+ throw this._wrapError(err, 'closeChannel', channelId);
104
+ }
105
+ }
106
+ async settleChannel(channelId, balanceA, balanceB, salt, participantA, participantB, nonce) {
107
+ this._logger.info({ event: 'settle_channel', channelId, chainId: this.chainId }, 'Settling Mina payment channel');
108
+ try {
109
+ const result = await this._sdk.settleChannel(channelId, balanceA ?? 0n, balanceB ?? 0n, salt ?? 0n, participantA ?? '', participantB ?? '', nonce ?? 0n);
110
+ return { txHash: result.txHash };
111
+ }
112
+ catch (err) {
113
+ throw this._wrapError(err, 'settleChannel', channelId);
114
+ }
115
+ }
116
+ async signBalanceProof(params) {
117
+ this._logger.debug({
118
+ event: 'sign_balance_proof',
119
+ channelId: params.channelId,
120
+ nonce: params.nonce,
121
+ chainId: this.chainId,
122
+ }, 'Signing Mina balance proof');
123
+ this._warnIfEVMFields(params);
124
+ try {
125
+ const transferredAmount = safeBigInt(params.transferredAmount, 'transferredAmount');
126
+ const nonce = safeBigInt(String(params.nonce), 'nonce');
127
+ return await this._sdk.signBalanceProof(params.channelId, transferredAmount, 0n, 0n, nonce);
128
+ }
129
+ catch (err) {
130
+ throw this._wrapError(err, 'signBalanceProof', params.channelId);
131
+ }
132
+ }
133
+ async verifyBalanceProof(params) {
134
+ this._logger.debug({
135
+ event: 'verify_balance_proof',
136
+ channelId: params.channelId,
137
+ nonce: params.nonce,
138
+ signerAddress: params.signerAddress,
139
+ chainId: this.chainId,
140
+ }, 'Verifying Mina balance proof');
141
+ this._warnIfEVMFields(params);
142
+ try {
143
+ const nonce = safeBigInt(String(params.nonce), 'nonce');
144
+ return await this._sdk.verifyBalanceProof(params.channelId, params.signerAddress, params.signature, nonce);
145
+ }
146
+ catch (err) {
147
+ this._logger.warn({
148
+ event: 'verify_balance_proof_error',
149
+ channelId: params.channelId,
150
+ nonce: params.nonce,
151
+ chainId: this.chainId,
152
+ error: err instanceof Error ? err.message : String(err),
153
+ }, 'Balance proof verification failed with error');
154
+ return false;
155
+ }
156
+ }
157
+ async getChannelState(channelId) {
158
+ try {
159
+ const state = await this._sdk.getChannelState(channelId);
160
+ return this._toProviderChannelState(channelId, state);
161
+ }
162
+ catch (err) {
163
+ throw this._wrapError(err, 'getChannelState', channelId);
164
+ }
165
+ }
166
+ subscribeToEvents(channelId, callback) {
167
+ this._logger.debug({ event: 'subscribe_events', channelId, chainId: this.chainId }, 'Subscribing to Mina channel events');
168
+ let previousState;
169
+ let unsubscribed = false;
170
+ const subscription = this._sdk.subscribeToChannel(channelId, (currentState) => {
171
+ if (unsubscribed)
172
+ return;
173
+ const eventType = this._diffState(previousState, currentState);
174
+ previousState = currentState;
175
+ if (eventType) {
176
+ const event = {
177
+ type: eventType,
178
+ channelId,
179
+ data: {
180
+ channelState: currentState.channelState,
181
+ depositTotal: currentState.depositTotal.toString(),
182
+ nonceField: currentState.nonceField.toString(),
183
+ balanceCommitment: currentState.balanceCommitment,
184
+ },
185
+ };
186
+ callback(event);
187
+ }
188
+ });
189
+ return {
190
+ unsubscribe: () => {
191
+ unsubscribed = true;
192
+ subscription.unsubscribe();
193
+ this._logger.debug({ event: 'unsubscribe_events', channelId, chainId: this.chainId }, 'Unsubscribed from Mina channel events');
194
+ },
195
+ };
196
+ }
197
+ async getMinaContext() {
198
+ const signerPublicKey = await this._ensureSignerPublicKey();
199
+ return {
200
+ zkAppAddress: this._zkAppAddress,
201
+ tokenId: this._tokenId,
202
+ network: this._network,
203
+ signerAddress: signerPublicKey,
204
+ };
205
+ }
206
+ async _ensureSignerPublicKey() {
207
+ if (!this._signerPublicKey) {
208
+ this._signerPublicKey = await this._sdk.getSignerPublicKey();
209
+ }
210
+ return this._signerPublicKey;
211
+ }
212
+ _toProviderChannelState(channelId, state) {
213
+ let status;
214
+ switch (state.channelState) {
215
+ case MINA_CHANNEL_STATE.OPEN:
216
+ status = 'opened';
217
+ break;
218
+ case MINA_CHANNEL_STATE.CLOSING:
219
+ status = 'closed';
220
+ break;
221
+ case MINA_CHANNEL_STATE.SETTLED:
222
+ status = 'settled';
223
+ break;
224
+ default:
225
+ this._logger.warn({
226
+ event: 'unexpected_channel_state',
227
+ channelId,
228
+ channelState: state.channelState,
229
+ chainId: this.chainId,
230
+ }, `Unexpected Mina channel state ${state.channelState}, defaulting to 'opened'`);
231
+ status = 'opened';
232
+ break;
233
+ }
234
+ return {
235
+ channelId,
236
+ status,
237
+ participants: [state.participantA, state.participantB],
238
+ deposit: state.depositTotal,
239
+ };
240
+ }
241
+ _diffState(previous, current) {
242
+ if (!previous) {
243
+ return undefined;
244
+ }
245
+ if (previous.channelState !== MINA_CHANNEL_STATE.SETTLED &&
246
+ current.channelState === MINA_CHANNEL_STATE.SETTLED) {
247
+ return 'channel_settled';
248
+ }
249
+ if (previous.channelState !== MINA_CHANNEL_STATE.CLOSING &&
250
+ current.channelState === MINA_CHANNEL_STATE.CLOSING) {
251
+ return 'channel_closed';
252
+ }
253
+ if (previous.channelState === MINA_CHANNEL_STATE.UNINITIALIZED &&
254
+ current.channelState === MINA_CHANNEL_STATE.OPEN) {
255
+ return 'channel_opened';
256
+ }
257
+ if (current.nonceField < previous.nonceField) {
258
+ this._logger.warn({
259
+ event: 'state_rollback_detected',
260
+ field: 'nonceField',
261
+ previous: previous.nonceField.toString(),
262
+ current: current.nonceField.toString(),
263
+ chainId: this.chainId,
264
+ }, 'Nonce decreased between polls -- possible chain reorg');
265
+ }
266
+ if (current.depositTotal < previous.depositTotal) {
267
+ this._logger.warn({
268
+ event: 'state_rollback_detected',
269
+ field: 'depositTotal',
270
+ previous: previous.depositTotal.toString(),
271
+ current: current.depositTotal.toString(),
272
+ chainId: this.chainId,
273
+ }, 'Deposit decreased between polls -- possible chain reorg');
274
+ }
275
+ if (current.nonceField > previous.nonceField) {
276
+ return 'channel_claimed';
277
+ }
278
+ if (current.depositTotal > previous.depositTotal) {
279
+ return 'channel_deposited';
280
+ }
281
+ return undefined;
282
+ }
283
+ _wrapError(err, method, channelId) {
284
+ if (err instanceof mina_payment_channel_sdk_1.MinaChannelError) {
285
+ return new Error(`MinaPaymentChannelProvider [${this.chainId}] ${method} channel ${channelId}: ` +
286
+ `${err.errorName} (code ${err.code}): ${err.message}`, { cause: err });
287
+ }
288
+ if (err instanceof Error) {
289
+ return new Error(`MinaPaymentChannelProvider [${this.chainId}] ${method} channel ${channelId}: ${err.message}`, { cause: err });
290
+ }
291
+ return new Error(`MinaPaymentChannelProvider [${this.chainId}] ${method} channel ${channelId}: ${String(err)}`, { cause: err });
292
+ }
293
+ _warnIfEVMFields(params) {
294
+ if (params.lockedAmount && params.lockedAmount !== '0') {
295
+ this._logger.warn({
296
+ event: 'ignored_field',
297
+ field: 'lockedAmount',
298
+ value: params.lockedAmount,
299
+ chainId: this.chainId,
300
+ }, 'lockedAmount is not supported on Mina channels and will be ignored');
301
+ }
302
+ if (params.locksRoot && params.locksRoot !== '' && params.locksRoot !== '0x') {
303
+ this._logger.warn({
304
+ event: 'ignored_field',
305
+ field: 'locksRoot',
306
+ value: params.locksRoot,
307
+ chainId: this.chainId,
308
+ }, 'locksRoot is not supported on Mina channels and will be ignored');
309
+ }
310
+ }
311
+ }
312
+ exports.MinaPaymentChannelProvider = MinaPaymentChannelProvider;
313
+ function createMinaProviderFactory(logger, signerKey) {
314
+ if (!signerKey) {
315
+ throw new Error('createMinaProviderFactory: signerKey must not be empty');
316
+ }
317
+ return (config) => {
318
+ if (config.chainType !== 'mina') {
319
+ throw new Error(`Mina factory received non-Mina config: ${config.chainType}`);
320
+ }
321
+ const sdk = new mina_payment_channel_sdk_1.MinaPaymentChannelSDK(config.graphqlUrl, config.zkAppAddress, logger, signerKey);
322
+ const network = config.network ?? 'devnet';
323
+ const chainId = `mina:${network}`;
324
+ return new MinaPaymentChannelProvider(sdk, chainId, config.zkAppAddress, signerKey, logger, {
325
+ tokenId: config.tokenId,
326
+ network,
327
+ });
328
+ };
329
+ }
330
+ //# sourceMappingURL=mina-payment-channel-provider.js.map