@toon-protocol/connector 3.3.1 → 3.3.3

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 +26 -0
  78. package/dist/core/payment-handler.d.ts.map +1 -0
  79. package/dist/core/payment-handler.js +106 -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,707 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ClaimReceiver = exports.ERRORS = void 0;
4
+ const events_1 = require("events");
5
+ const btp_types_1 = require("../btp/btp-types");
6
+ const btp_claim_types_1 = require("../btp/btp-claim-types");
7
+ const nip59_claim_wrapper_1 = require("./privacy/nip59-claim-wrapper");
8
+ exports.ERRORS = {
9
+ MISSING_SELF_DESCRIBING_FIELDS: 'Missing self-describing fields for unknown channel (chainId, tokenNetworkAddress, tokenAddress required)',
10
+ CHANNEL_NOT_FOUND: 'Channel does not exist on-chain',
11
+ CHANNEL_NOT_OPENED: 'Channel not in opened state',
12
+ SIGNER_NOT_PARTICIPANT: 'Signer is not a channel participant',
13
+ ON_CHAIN_VERIFICATION_FAILED: 'On-chain channel verification failed',
14
+ INVALID_SIGNATURE: 'Invalid balance proof signature',
15
+ NO_PROVIDER_REGISTERED: 'No provider registered for blockchain:',
16
+ };
17
+ class ClaimReceiver extends events_1.EventEmitter {
18
+ db;
19
+ chainProviderRegistry;
20
+ logger;
21
+ channelManager;
22
+ peerIdToAddressMap;
23
+ _nip59Wrapper;
24
+ _nodePrivateKey;
25
+ constructor(db, chainProviderRegistry, logger, channelManager, peerIdToAddressMap, _nip59Wrapper, _nodePrivateKey) {
26
+ super();
27
+ this.db = db;
28
+ this.chainProviderRegistry = chainProviderRegistry;
29
+ this.logger = logger;
30
+ this.channelManager = channelManager;
31
+ this.peerIdToAddressMap = peerIdToAddressMap;
32
+ this._nip59Wrapper = _nip59Wrapper;
33
+ this._nodePrivateKey = _nodePrivateKey;
34
+ }
35
+ registerWithBTPServer(btpServer) {
36
+ btpServer.onMessage(async (peerId, message) => {
37
+ if (!(0, btp_types_1.isBTPData)(message)) {
38
+ return;
39
+ }
40
+ for (const protocolData of message.data.protocolData) {
41
+ if (protocolData.protocolName === 'payment-channel-claim') {
42
+ await this.handleClaimMessage(peerId, protocolData);
43
+ }
44
+ else if (protocolData.protocolName === nip59_claim_wrapper_1.BTP_WRAPPED_CLAIM_PROTOCOL.NAME &&
45
+ this._nip59Wrapper &&
46
+ this._nodePrivateKey) {
47
+ await this.handleWrappedClaimMessage(peerId, protocolData);
48
+ }
49
+ }
50
+ });
51
+ this.logger.info('ClaimReceiver registered with BTP server');
52
+ }
53
+ async handleWrappedClaimMessage(peerId, protocolData) {
54
+ const childLogger = this.logger.child({ peerId, protocol: 'claim-receiver-nip59' });
55
+ try {
56
+ const wrappedClaim = (0, nip59_claim_wrapper_1.deserializeWrappedClaim)(protocolData.data);
57
+ const claimMessage = this._nip59Wrapper.unwrapClaim(wrappedClaim, this._nodePrivateKey);
58
+ childLogger.debug({ messageId: claimMessage.messageId }, 'NIP-59 claim unwrapped successfully');
59
+ const plaintextData = {
60
+ protocolName: 'payment-channel-claim',
61
+ contentType: 1,
62
+ data: Buffer.from(JSON.stringify(claimMessage), 'utf8'),
63
+ };
64
+ await this.handleClaimMessage(peerId, plaintextData);
65
+ }
66
+ catch (error) {
67
+ childLogger.warn({ error: error instanceof Error ? error.message : String(error) }, 'Failed to unwrap NIP-59 claim');
68
+ }
69
+ }
70
+ async handleClaimMessage(peerId, protocolData) {
71
+ const childLogger = this.logger.child({ peerId, protocol: 'claim-receiver' });
72
+ try {
73
+ const claimMessage = JSON.parse(protocolData.data.toString('utf8'));
74
+ (0, btp_claim_types_1.validateClaimMessage)(claimMessage);
75
+ const messageId = claimMessage.messageId;
76
+ const blockchain = claimMessage.blockchain;
77
+ childLogger.info({ messageId, blockchain }, 'Received claim message');
78
+ const provider = this.resolveProvider(claimMessage);
79
+ if (!provider) {
80
+ const errorMsg = `${exports.ERRORS.NO_PROVIDER_REGISTERED} ${blockchain}`;
81
+ childLogger.warn({ messageId, blockchain }, errorMsg);
82
+ this._persistReceivedClaim(peerId, claimMessage, false);
83
+ return;
84
+ }
85
+ const verificationResult = await this.verifyClaim(claimMessage, peerId, provider);
86
+ if (verificationResult.valid) {
87
+ this._persistReceivedClaim(peerId, claimMessage, true);
88
+ childLogger.info({ messageId }, 'Claim verified and stored');
89
+ try {
90
+ if ((0, btp_claim_types_1.isEVMClaim)(claimMessage)) {
91
+ const event = {
92
+ peerId,
93
+ channelId: claimMessage.channelId,
94
+ cumulativeAmount: BigInt(claimMessage.transferredAmount),
95
+ };
96
+ this.emit('CLAIM_RECEIVED', event);
97
+ childLogger.debug({ channelId: event.channelId, cumulativeAmount: event.cumulativeAmount.toString() }, 'CLAIM_RECEIVED event emitted');
98
+ }
99
+ else if ((0, btp_claim_types_1.isSolanaClaim)(claimMessage)) {
100
+ const event = {
101
+ peerId,
102
+ channelId: claimMessage.channelAccount,
103
+ cumulativeAmount: BigInt(claimMessage.transferredAmount),
104
+ };
105
+ this.emit('CLAIM_RECEIVED', event);
106
+ childLogger.debug({
107
+ channelAccount: event.channelId,
108
+ cumulativeAmount: event.cumulativeAmount.toString(),
109
+ }, 'CLAIM_RECEIVED event emitted (Solana)');
110
+ }
111
+ else if ((0, btp_claim_types_1.isMinaClaim)(claimMessage)) {
112
+ const event = {
113
+ peerId,
114
+ channelId: claimMessage.zkAppAddress,
115
+ cumulativeAmount: BigInt(0),
116
+ };
117
+ this.emit('CLAIM_RECEIVED', event);
118
+ childLogger.debug({ zkAppAddress: event.channelId }, 'CLAIM_RECEIVED event emitted (Mina)');
119
+ }
120
+ }
121
+ catch (eventError) {
122
+ childLogger.warn({
123
+ messageId: claimMessage.messageId,
124
+ error: eventError instanceof Error ? eventError.message : String(eventError),
125
+ }, 'Failed to emit CLAIM_RECEIVED event (invalid transferredAmount for BigInt conversion)');
126
+ }
127
+ }
128
+ else {
129
+ this._persistReceivedClaim(peerId, claimMessage, false);
130
+ childLogger.warn({ messageId, error: verificationResult.error }, 'Claim verification failed');
131
+ }
132
+ }
133
+ catch (error) {
134
+ childLogger.error({ error }, 'Failed to parse claim message');
135
+ }
136
+ }
137
+ resolveProvider(claim) {
138
+ if ((0, btp_claim_types_1.isEVMClaim)(claim)) {
139
+ if (this.channelManager) {
140
+ const knownChannel = this.channelManager.getChannelById(claim.channelId);
141
+ if (knownChannel && knownChannel.chain) {
142
+ return this.chainProviderRegistry.getProvider(claim.blockchain, knownChannel.chain);
143
+ }
144
+ }
145
+ if (claim.chainId !== undefined) {
146
+ const chainKey = `${claim.blockchain}:${claim.chainId}`;
147
+ return this.chainProviderRegistry.getProvider(claim.blockchain, chainKey);
148
+ }
149
+ }
150
+ if ((0, btp_claim_types_1.isSolanaClaim)(claim)) {
151
+ if (this.channelManager) {
152
+ const knownChannel = this.channelManager.getChannelById(claim.channelAccount);
153
+ if (knownChannel && knownChannel.chain) {
154
+ return this.chainProviderRegistry.getProvider(claim.blockchain, knownChannel.chain);
155
+ }
156
+ }
157
+ if (claim.cluster !== undefined) {
158
+ const chainKey = `${claim.blockchain}:${claim.cluster}`;
159
+ return this.chainProviderRegistry.getProvider(claim.blockchain, chainKey);
160
+ }
161
+ }
162
+ if ((0, btp_claim_types_1.isMinaClaim)(claim)) {
163
+ if (this.channelManager) {
164
+ const knownChannel = this.channelManager.getChannelById(claim.zkAppAddress);
165
+ if (knownChannel && knownChannel.chain) {
166
+ return this.chainProviderRegistry.getProvider(claim.blockchain, knownChannel.chain);
167
+ }
168
+ }
169
+ if (claim.network !== undefined) {
170
+ const chainKey = `${claim.blockchain}:${claim.network}`;
171
+ return this.chainProviderRegistry.getProvider(claim.blockchain, chainKey);
172
+ }
173
+ }
174
+ const allProviders = this.chainProviderRegistry.getAllProviders();
175
+ return allProviders.find((p) => p.chainType === claim.blockchain);
176
+ }
177
+ async verifyClaim(claim, peerId, provider) {
178
+ try {
179
+ if ((0, btp_claim_types_1.isEVMClaim)(claim)) {
180
+ return await this.verifyEVMClaim(claim, peerId, provider);
181
+ }
182
+ if ((0, btp_claim_types_1.isSolanaClaim)(claim)) {
183
+ return await this.verifySolanaClaim(claim, peerId, provider);
184
+ }
185
+ if ((0, btp_claim_types_1.isMinaClaim)(claim)) {
186
+ return await this.verifyMinaClaim(claim, peerId, provider);
187
+ }
188
+ const _exhaustiveCheck = claim;
189
+ return {
190
+ valid: false,
191
+ messageId: _exhaustiveCheck.messageId,
192
+ error: `Verification not supported for blockchain: ${_exhaustiveCheck.blockchain}`,
193
+ };
194
+ }
195
+ catch (error) {
196
+ return {
197
+ valid: false,
198
+ messageId: claim.messageId,
199
+ error: error instanceof Error ? error.message : 'Unknown error',
200
+ };
201
+ }
202
+ }
203
+ async verifyEVMClaim(claim, peerId, provider) {
204
+ this.logger.debug({ channelId: claim.channelId }, 'Checking channel existence in metadata');
205
+ const knownChannel = this.channelManager?.getChannelById(claim.channelId);
206
+ if (!knownChannel && this.channelManager) {
207
+ this.logger.info({ channelId: claim.channelId }, 'Unknown channel detected, starting on-chain verification');
208
+ if (claim.chainId === undefined || !claim.tokenNetworkAddress || !claim.tokenAddress) {
209
+ this.logger.warn({ channelId: claim.channelId, signerAddress: claim.signerAddress }, exports.ERRORS.MISSING_SELF_DESCRIBING_FIELDS);
210
+ return {
211
+ valid: false,
212
+ messageId: claim.messageId,
213
+ error: exports.ERRORS.MISSING_SELF_DESCRIBING_FIELDS,
214
+ };
215
+ }
216
+ let channelState;
217
+ try {
218
+ channelState = await provider.getChannelState(claim.channelId);
219
+ }
220
+ catch (error) {
221
+ this.logger.warn({ channelId: claim.channelId, signerAddress: claim.signerAddress, error }, exports.ERRORS.ON_CHAIN_VERIFICATION_FAILED);
222
+ return {
223
+ valid: false,
224
+ messageId: claim.messageId,
225
+ error: exports.ERRORS.ON_CHAIN_VERIFICATION_FAILED,
226
+ };
227
+ }
228
+ if (channelState.status !== 'opened') {
229
+ const errorMsg = channelState.status === 'settled' || channelState.status === 'closed'
230
+ ? exports.ERRORS.CHANNEL_NOT_OPENED
231
+ : exports.ERRORS.CHANNEL_NOT_FOUND;
232
+ this.logger.warn({ channelId: claim.channelId, signerAddress: claim.signerAddress }, errorMsg);
233
+ return {
234
+ valid: false,
235
+ messageId: claim.messageId,
236
+ error: errorMsg,
237
+ };
238
+ }
239
+ const signerLower = claim.signerAddress.toLowerCase();
240
+ if (!channelState.participants.some((p) => p.toLowerCase() === signerLower)) {
241
+ this.logger.warn({ channelId: claim.channelId, signerAddress: claim.signerAddress }, exports.ERRORS.SIGNER_NOT_PARTICIPANT);
242
+ return {
243
+ valid: false,
244
+ messageId: claim.messageId,
245
+ error: exports.ERRORS.SIGNER_NOT_PARTICIPANT,
246
+ };
247
+ }
248
+ this.logger.info({
249
+ channelId: claim.channelId,
250
+ participants: channelState.participants,
251
+ status: channelState.status,
252
+ }, 'On-chain channel verified successfully');
253
+ const verifyParams = this.buildVerifyParams(claim);
254
+ const sigValid = await provider.verifyBalanceProof(verifyParams);
255
+ if (!sigValid) {
256
+ return {
257
+ valid: false,
258
+ messageId: claim.messageId,
259
+ error: exports.ERRORS.INVALID_SIGNATURE,
260
+ };
261
+ }
262
+ this.channelManager.registerExternalChannel({
263
+ channelId: claim.channelId,
264
+ peerId,
265
+ tokenAddress: claim.tokenAddress,
266
+ tokenNetworkAddress: claim.tokenNetworkAddress,
267
+ chainId: claim.chainId,
268
+ status: 'open',
269
+ });
270
+ this.logger.info({ channelId: claim.channelId, peerId }, 'External channel registered');
271
+ if (this.peerIdToAddressMap && !this.peerIdToAddressMap.has(peerId)) {
272
+ this.peerIdToAddressMap.set(peerId, claim.signerAddress);
273
+ this.logger.info({ peerId, signerAddress: claim.signerAddress }, 'Peer EVM address registered from self-describing claim');
274
+ }
275
+ }
276
+ else {
277
+ const verifyParams = this.buildVerifyParams(claim);
278
+ const isValid = await provider.verifyBalanceProof(verifyParams);
279
+ if (!isValid) {
280
+ return {
281
+ valid: false,
282
+ messageId: claim.messageId,
283
+ error: exports.ERRORS.INVALID_SIGNATURE,
284
+ };
285
+ }
286
+ }
287
+ const latestClaim = await this.getLatestVerifiedClaim(peerId, claim.blockchain, claim.channelId);
288
+ if (latestClaim && (0, btp_claim_types_1.isEVMClaim)(latestClaim)) {
289
+ if (claim.nonce <= latestClaim.nonce) {
290
+ return {
291
+ valid: false,
292
+ messageId: claim.messageId,
293
+ error: 'Nonce not monotonically increasing',
294
+ };
295
+ }
296
+ }
297
+ return { valid: true, messageId: claim.messageId };
298
+ }
299
+ buildVerifyParams(claim) {
300
+ return {
301
+ channelId: claim.channelId,
302
+ nonce: claim.nonce,
303
+ transferredAmount: claim.transferredAmount,
304
+ lockedAmount: claim.lockedAmount,
305
+ locksRoot: claim.locksRoot,
306
+ signature: claim.signature,
307
+ signerAddress: claim.signerAddress,
308
+ };
309
+ }
310
+ async verifySolanaClaim(claim, peerId, provider) {
311
+ this.logger.debug({ channelAccount: claim.channelAccount }, 'Verifying Solana claim');
312
+ const knownChannel = this.channelManager?.getChannelById(claim.channelAccount);
313
+ if (!knownChannel && this.channelManager) {
314
+ this.logger.info({ channelAccount: claim.channelAccount }, 'Unknown Solana channel detected, starting on-chain verification');
315
+ let channelState;
316
+ try {
317
+ channelState = await provider.getChannelState(claim.channelAccount);
318
+ }
319
+ catch (error) {
320
+ this.logger.warn({
321
+ channelAccount: claim.channelAccount,
322
+ signerPublicKey: claim.signerPublicKey,
323
+ error,
324
+ }, exports.ERRORS.ON_CHAIN_VERIFICATION_FAILED);
325
+ return {
326
+ valid: false,
327
+ messageId: claim.messageId,
328
+ error: exports.ERRORS.ON_CHAIN_VERIFICATION_FAILED,
329
+ };
330
+ }
331
+ if (channelState.status !== 'opened' && channelState.status !== 'closed') {
332
+ const errorMsg = channelState.status === 'settled' ? exports.ERRORS.CHANNEL_NOT_OPENED : exports.ERRORS.CHANNEL_NOT_FOUND;
333
+ this.logger.warn({ channelAccount: claim.channelAccount, status: channelState.status }, errorMsg);
334
+ return {
335
+ valid: false,
336
+ messageId: claim.messageId,
337
+ error: errorMsg,
338
+ };
339
+ }
340
+ if (!channelState.participants.includes(claim.signerPublicKey)) {
341
+ this.logger.warn({
342
+ channelAccount: claim.channelAccount,
343
+ signerPublicKey: claim.signerPublicKey,
344
+ }, exports.ERRORS.SIGNER_NOT_PARTICIPANT);
345
+ return {
346
+ valid: false,
347
+ messageId: claim.messageId,
348
+ error: exports.ERRORS.SIGNER_NOT_PARTICIPANT,
349
+ };
350
+ }
351
+ this.logger.info({
352
+ channelAccount: claim.channelAccount,
353
+ participants: channelState.participants,
354
+ status: channelState.status,
355
+ }, 'On-chain Solana channel verified successfully');
356
+ const verifyParams = this.buildSolanaVerifyParams(claim);
357
+ const sigValid = await provider.verifyBalanceProof(verifyParams);
358
+ if (!sigValid) {
359
+ return {
360
+ valid: false,
361
+ messageId: claim.messageId,
362
+ error: exports.ERRORS.INVALID_SIGNATURE,
363
+ };
364
+ }
365
+ this.channelManager.registerExternalChannel({
366
+ channelId: claim.channelAccount,
367
+ peerId,
368
+ tokenAddress: claim.programId,
369
+ status: 'open',
370
+ chain: `solana:${claim.cluster ?? 'devnet'}`,
371
+ });
372
+ this.logger.info({ channelAccount: claim.channelAccount, peerId }, 'External Solana channel registered');
373
+ if (this.peerIdToAddressMap && !this.peerIdToAddressMap.has(peerId)) {
374
+ this.peerIdToAddressMap.set(peerId, claim.signerPublicKey);
375
+ this.logger.info({ peerId, signerPublicKey: claim.signerPublicKey }, 'Peer Solana address registered from self-describing claim');
376
+ }
377
+ }
378
+ else {
379
+ const verifyParams = this.buildSolanaVerifyParams(claim);
380
+ const isValid = await provider.verifyBalanceProof(verifyParams);
381
+ if (!isValid) {
382
+ return {
383
+ valid: false,
384
+ messageId: claim.messageId,
385
+ error: exports.ERRORS.INVALID_SIGNATURE,
386
+ };
387
+ }
388
+ }
389
+ const latestClaim = await this.getLatestVerifiedClaim(peerId, claim.blockchain, claim.channelAccount);
390
+ if (latestClaim && (0, btp_claim_types_1.isSolanaClaim)(latestClaim)) {
391
+ if (claim.nonce <= latestClaim.nonce) {
392
+ return {
393
+ valid: false,
394
+ messageId: claim.messageId,
395
+ error: 'Nonce not monotonically increasing',
396
+ };
397
+ }
398
+ }
399
+ return { valid: true, messageId: claim.messageId };
400
+ }
401
+ buildSolanaVerifyParams(claim) {
402
+ return {
403
+ channelId: claim.channelAccount,
404
+ nonce: claim.nonce,
405
+ transferredAmount: claim.transferredAmount,
406
+ lockedAmount: '0',
407
+ locksRoot: '0x0000000000000000000000000000000000000000000000000000000000000000',
408
+ signature: claim.signature,
409
+ signerAddress: claim.signerPublicKey,
410
+ };
411
+ }
412
+ async verifyMinaClaim(claim, peerId, provider) {
413
+ this.logger.debug({
414
+ event: 'mina_claim_received',
415
+ messageId: claim.messageId,
416
+ zkAppAddress: claim.zkAppAddress,
417
+ }, 'Verifying Mina claim');
418
+ const knownChannel = this.channelManager?.getChannelById(claim.zkAppAddress);
419
+ if (!knownChannel && this.channelManager) {
420
+ this.logger.info({ zkAppAddress: claim.zkAppAddress }, 'Unknown Mina channel detected, starting on-chain verification');
421
+ let channelState;
422
+ try {
423
+ channelState = await provider.getChannelState(claim.zkAppAddress);
424
+ }
425
+ catch (error) {
426
+ this.logger.warn({ event: 'mina_claim_verification_failed', messageId: claim.messageId, error }, exports.ERRORS.ON_CHAIN_VERIFICATION_FAILED);
427
+ return {
428
+ valid: false,
429
+ messageId: claim.messageId,
430
+ error: exports.ERRORS.ON_CHAIN_VERIFICATION_FAILED,
431
+ };
432
+ }
433
+ if (channelState.status !== 'opened' && channelState.status !== 'closed') {
434
+ const errorMsg = channelState.status === 'settled' ? exports.ERRORS.CHANNEL_NOT_OPENED : exports.ERRORS.CHANNEL_NOT_FOUND;
435
+ this.logger.warn({ zkAppAddress: claim.zkAppAddress, status: channelState.status }, errorMsg);
436
+ return {
437
+ valid: false,
438
+ messageId: claim.messageId,
439
+ error: errorMsg,
440
+ };
441
+ }
442
+ this.logger.info({
443
+ zkAppAddress: claim.zkAppAddress,
444
+ participants: channelState.participants,
445
+ status: channelState.status,
446
+ }, 'On-chain Mina channel verified successfully');
447
+ const verifyParams = this.buildMinaVerifyParams(claim);
448
+ const proofValid = await provider.verifyBalanceProof(verifyParams);
449
+ if (!proofValid) {
450
+ this.logger.warn({ event: 'mina_claim_verification_failed', messageId: claim.messageId }, exports.ERRORS.INVALID_SIGNATURE);
451
+ return {
452
+ valid: false,
453
+ messageId: claim.messageId,
454
+ error: exports.ERRORS.INVALID_SIGNATURE,
455
+ };
456
+ }
457
+ this.channelManager.registerExternalChannel({
458
+ channelId: claim.zkAppAddress,
459
+ peerId,
460
+ tokenAddress: claim.tokenId,
461
+ status: 'open',
462
+ chain: `mina:${claim.network ?? 'devnet'}`,
463
+ });
464
+ this.logger.info({ zkAppAddress: claim.zkAppAddress, peerId }, 'External Mina channel registered');
465
+ }
466
+ else {
467
+ const verifyParams = this.buildMinaVerifyParams(claim);
468
+ const isValid = await provider.verifyBalanceProof(verifyParams);
469
+ if (!isValid) {
470
+ return {
471
+ valid: false,
472
+ messageId: claim.messageId,
473
+ error: exports.ERRORS.INVALID_SIGNATURE,
474
+ };
475
+ }
476
+ }
477
+ const latestClaim = await this.getLatestVerifiedClaim(peerId, claim.blockchain, claim.zkAppAddress);
478
+ if (latestClaim && (0, btp_claim_types_1.isMinaClaim)(latestClaim)) {
479
+ if (claim.nonce <= latestClaim.nonce) {
480
+ return {
481
+ valid: false,
482
+ messageId: claim.messageId,
483
+ error: 'Nonce not monotonically increasing',
484
+ };
485
+ }
486
+ }
487
+ return { valid: true, messageId: claim.messageId };
488
+ }
489
+ buildMinaVerifyParams(claim) {
490
+ return {
491
+ channelId: claim.zkAppAddress,
492
+ nonce: claim.nonce,
493
+ transferredAmount: claim.balanceCommitment,
494
+ lockedAmount: '0',
495
+ locksRoot: '0x' + '0'.repeat(64),
496
+ signature: claim.proof,
497
+ signerAddress: claim.zkAppAddress,
498
+ };
499
+ }
500
+ _persistReceivedClaim(peerId, claim, verified) {
501
+ try {
502
+ let channelId = '';
503
+ if ((0, btp_claim_types_1.isEVMClaim)(claim)) {
504
+ channelId = claim.channelId;
505
+ }
506
+ else if ((0, btp_claim_types_1.isSolanaClaim)(claim)) {
507
+ channelId = claim.channelAccount;
508
+ }
509
+ else if ((0, btp_claim_types_1.isMinaClaim)(claim)) {
510
+ channelId = claim.zkAppAddress;
511
+ }
512
+ const stmt = this.db.prepare(`
513
+ INSERT INTO received_claims (
514
+ message_id,
515
+ peer_id,
516
+ blockchain,
517
+ channel_id,
518
+ claim_data,
519
+ verified,
520
+ received_at,
521
+ redeemed_at,
522
+ redemption_tx_hash
523
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
524
+ `);
525
+ stmt.run(claim.messageId, peerId, claim.blockchain, channelId, JSON.stringify(claim), verified ? 1 : 0, Date.now(), null, null);
526
+ }
527
+ catch (error) {
528
+ if (error instanceof Error && error.message.includes('UNIQUE constraint failed')) {
529
+ this.logger.warn({ messageId: claim.messageId }, 'Duplicate claim message ignored (idempotency)');
530
+ }
531
+ else {
532
+ this.logger.error({ error }, 'Failed to persist claim to database');
533
+ }
534
+ }
535
+ }
536
+ async getLatestVerifiedClaim(peerId, blockchain, channelId) {
537
+ try {
538
+ const stmt = this.db.prepare(`
539
+ SELECT claim_data
540
+ FROM received_claims
541
+ WHERE peer_id = ?
542
+ AND blockchain = ?
543
+ AND channel_id = ?
544
+ AND verified = 1
545
+ AND redeemed_at IS NULL
546
+ ORDER BY received_at DESC
547
+ LIMIT 1
548
+ `);
549
+ const row = stmt.get(peerId, blockchain, channelId);
550
+ if (!row) {
551
+ return null;
552
+ }
553
+ return JSON.parse(row.claim_data);
554
+ }
555
+ catch (error) {
556
+ this.logger.error({ error }, 'Failed to query latest verified claim');
557
+ return null;
558
+ }
559
+ }
560
+ async getRecentClaims(limit = 50) {
561
+ try {
562
+ const stmt = this.db.prepare(`
563
+ SELECT message_id, peer_id, blockchain, channel_id, claim_data, received_at
564
+ FROM received_claims
565
+ WHERE verified = 1
566
+ ORDER BY received_at DESC
567
+ LIMIT ?
568
+ `);
569
+ const rows = stmt.all(limit);
570
+ return rows.map((row) => ({
571
+ messageId: row.message_id,
572
+ peerId: row.peer_id,
573
+ blockchain: row.blockchain,
574
+ channelId: row.channel_id,
575
+ claimData: JSON.parse(row.claim_data),
576
+ receivedAt: row.received_at,
577
+ }));
578
+ }
579
+ catch (error) {
580
+ this.logger.error({ error }, 'Failed to query recent claims');
581
+ return [];
582
+ }
583
+ }
584
+ async getLastClaimAt(peerId, blockchain) {
585
+ try {
586
+ const stmt = this.db.prepare(`
587
+ SELECT MAX(received_at) AS last_at
588
+ FROM received_claims
589
+ WHERE peer_id = ? AND blockchain = ? AND verified = 1
590
+ `);
591
+ const row = stmt.get(peerId, blockchain);
592
+ return row?.last_at ?? null;
593
+ }
594
+ catch (error) {
595
+ this.logger.error({ error, peerId, blockchain }, 'Failed to query last claim timestamp');
596
+ return null;
597
+ }
598
+ }
599
+ async getCumulativeInboundByAsset(peerId) {
600
+ const out = new Map();
601
+ try {
602
+ const stmt = this.db.prepare(`
603
+ SELECT blockchain, channel_id, claim_data, received_at
604
+ FROM received_claims
605
+ WHERE peer_id = ? AND verified = 1
606
+ `);
607
+ const rows = stmt.all(peerId);
608
+ const latestByChannel = new Map();
609
+ for (const row of rows) {
610
+ let claim;
611
+ try {
612
+ claim = JSON.parse(row.claim_data);
613
+ }
614
+ catch {
615
+ continue;
616
+ }
617
+ let tokenAddress = '';
618
+ let amount = 0n;
619
+ let nonce = 0;
620
+ if ((0, btp_claim_types_1.isEVMClaim)(claim)) {
621
+ tokenAddress = claim.tokenAddress ?? '';
622
+ try {
623
+ amount = BigInt(claim.transferredAmount ?? '0');
624
+ }
625
+ catch {
626
+ amount = 0n;
627
+ }
628
+ nonce = claim.nonce ?? 0;
629
+ }
630
+ else if ((0, btp_claim_types_1.isSolanaClaim)(claim)) {
631
+ tokenAddress = claim.programId;
632
+ try {
633
+ amount = BigInt(claim.transferredAmount ?? '0');
634
+ }
635
+ catch {
636
+ amount = 0n;
637
+ }
638
+ nonce = claim.nonce ?? 0;
639
+ }
640
+ else if ((0, btp_claim_types_1.isMinaClaim)(claim)) {
641
+ tokenAddress = claim.tokenId ?? '';
642
+ amount = 0n;
643
+ nonce = claim.nonce ?? 0;
644
+ }
645
+ if (!tokenAddress)
646
+ continue;
647
+ const key = `${row.blockchain}:${row.channel_id}`;
648
+ const existing = latestByChannel.get(key);
649
+ if (!existing || nonce > existing.nonce) {
650
+ latestByChannel.set(key, {
651
+ blockchain: row.blockchain,
652
+ tokenAddress,
653
+ amount,
654
+ nonce,
655
+ receivedAt: row.received_at,
656
+ });
657
+ }
658
+ }
659
+ for (const entry of latestByChannel.values()) {
660
+ const assetKey = `${entry.blockchain}:${entry.tokenAddress}`;
661
+ const bucket = out.get(assetKey);
662
+ if (bucket) {
663
+ bucket.total += entry.amount;
664
+ if (entry.receivedAt > bucket.lastAt)
665
+ bucket.lastAt = entry.receivedAt;
666
+ }
667
+ else {
668
+ out.set(assetKey, {
669
+ blockchain: entry.blockchain,
670
+ tokenAddress: entry.tokenAddress,
671
+ total: entry.amount,
672
+ lastAt: entry.receivedAt,
673
+ });
674
+ }
675
+ }
676
+ }
677
+ catch (error) {
678
+ this.logger.error({ error, peerId }, 'Failed to compute cumulative inbound claims');
679
+ }
680
+ return out;
681
+ }
682
+ async getLatestVerifiedClaimForChannel(peerId, channelId) {
683
+ try {
684
+ const stmt = this.db.prepare(`
685
+ SELECT claim_data
686
+ FROM received_claims
687
+ WHERE peer_id = ?
688
+ AND channel_id = ?
689
+ AND verified = 1
690
+ AND redeemed_at IS NULL
691
+ ORDER BY received_at DESC
692
+ LIMIT 1
693
+ `);
694
+ const row = stmt.get(peerId, channelId);
695
+ if (!row) {
696
+ return null;
697
+ }
698
+ return JSON.parse(row.claim_data);
699
+ }
700
+ catch (error) {
701
+ this.logger.error({ error }, 'Failed to query latest verified claim for channel');
702
+ return null;
703
+ }
704
+ }
705
+ }
706
+ exports.ClaimReceiver = ClaimReceiver;
707
+ //# sourceMappingURL=claim-receiver.js.map