@toon-protocol/connector 1.7.1

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 (458) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +421 -0
  3. package/dist/btp/btp-claim-types.d.ts +30 -0
  4. package/dist/btp/btp-claim-types.d.ts.map +1 -0
  5. package/dist/btp/btp-claim-types.js +103 -0
  6. package/dist/btp/btp-claim-types.js.map +1 -0
  7. package/dist/btp/btp-client-manager.d.ts +27 -0
  8. package/dist/btp/btp-client-manager.d.ts.map +1 -0
  9. package/dist/btp/btp-client-manager.js +138 -0
  10. package/dist/btp/btp-client-manager.js.map +1 -0
  11. package/dist/btp/btp-client.d.ts +55 -0
  12. package/dist/btp/btp-client.d.ts.map +1 -0
  13. package/dist/btp/btp-client.js +474 -0
  14. package/dist/btp/btp-client.js.map +1 -0
  15. package/dist/btp/btp-message-parser.d.ts +4 -0
  16. package/dist/btp/btp-message-parser.d.ts.map +1 -0
  17. package/dist/btp/btp-message-parser.js +211 -0
  18. package/dist/btp/btp-message-parser.js.map +1 -0
  19. package/dist/btp/btp-server.d.ts +30 -0
  20. package/dist/btp/btp-server.d.ts.map +1 -0
  21. package/dist/btp/btp-server.js +458 -0
  22. package/dist/btp/btp-server.js.map +1 -0
  23. package/dist/btp/btp-types.d.ts +43 -0
  24. package/dist/btp/btp-types.d.ts.map +1 -0
  25. package/dist/btp/btp-types.js +44 -0
  26. package/dist/btp/btp-types.js.map +1 -0
  27. package/dist/cli/index.d.ts +3 -0
  28. package/dist/cli/index.d.ts.map +1 -0
  29. package/dist/cli/index.js +175 -0
  30. package/dist/cli/index.js.map +1 -0
  31. package/dist/cli/onboarding-wizard.d.ts +7 -0
  32. package/dist/cli/onboarding-wizard.d.ts.map +1 -0
  33. package/dist/cli/onboarding-wizard.js +257 -0
  34. package/dist/cli/onboarding-wizard.js.map +1 -0
  35. package/dist/cli/types.d.ts +38 -0
  36. package/dist/cli/types.d.ts.map +1 -0
  37. package/dist/cli/types.js +3 -0
  38. package/dist/cli/types.js.map +1 -0
  39. package/dist/config/aptos-env-validator.d.ts +8 -0
  40. package/dist/config/aptos-env-validator.d.ts.map +1 -0
  41. package/dist/config/aptos-env-validator.js +25 -0
  42. package/dist/config/aptos-env-validator.js.map +1 -0
  43. package/dist/config/config-loader.d.ts +20 -0
  44. package/dist/config/config-loader.d.ts.map +1 -0
  45. package/dist/config/config-loader.js +269 -0
  46. package/dist/config/config-loader.js.map +1 -0
  47. package/dist/config/environment-validator.d.ts +4 -0
  48. package/dist/config/environment-validator.d.ts.map +1 -0
  49. package/dist/config/environment-validator.js +239 -0
  50. package/dist/config/environment-validator.js.map +1 -0
  51. package/dist/config/index.d.ts +2 -0
  52. package/dist/config/index.d.ts.map +1 -0
  53. package/dist/config/index.js +7 -0
  54. package/dist/config/index.js.map +1 -0
  55. package/dist/config/key-manager-config.d.ts +7 -0
  56. package/dist/config/key-manager-config.d.ts.map +1 -0
  57. package/dist/config/key-manager-config.js +209 -0
  58. package/dist/config/key-manager-config.js.map +1 -0
  59. package/dist/config/topology-validator.d.ts +14 -0
  60. package/dist/config/topology-validator.d.ts.map +1 -0
  61. package/dist/config/topology-validator.js +142 -0
  62. package/dist/config/topology-validator.js.map +1 -0
  63. package/dist/config/types.d.ts +210 -0
  64. package/dist/config/types.d.ts.map +1 -0
  65. package/dist/config/types.js +10 -0
  66. package/dist/config/types.js.map +1 -0
  67. package/dist/core/connector-node.d.ts +79 -0
  68. package/dist/core/connector-node.d.ts.map +1 -0
  69. package/dist/core/connector-node.js +1036 -0
  70. package/dist/core/connector-node.js.map +1 -0
  71. package/dist/core/local-delivery-client.d.ts +16 -0
  72. package/dist/core/local-delivery-client.d.ts.map +1 -0
  73. package/dist/core/local-delivery-client.js +176 -0
  74. package/dist/core/local-delivery-client.js.map +1 -0
  75. package/dist/core/packet-handler.d.ts +45 -0
  76. package/dist/core/packet-handler.d.ts.map +1 -0
  77. package/dist/core/packet-handler.js +606 -0
  78. package/dist/core/packet-handler.js.map +1 -0
  79. package/dist/core/payment-handler.d.ts +27 -0
  80. package/dist/core/payment-handler.d.ts.map +1 -0
  81. package/dist/core/payment-handler.js +115 -0
  82. package/dist/core/payment-handler.js.map +1 -0
  83. package/dist/discovery/index.d.ts +3 -0
  84. package/dist/discovery/index.d.ts.map +1 -0
  85. package/dist/discovery/index.js +6 -0
  86. package/dist/discovery/index.js.map +1 -0
  87. package/dist/discovery/peer-discovery-service.d.ts +29 -0
  88. package/dist/discovery/peer-discovery-service.d.ts.map +1 -0
  89. package/dist/discovery/peer-discovery-service.js +230 -0
  90. package/dist/discovery/peer-discovery-service.js.map +1 -0
  91. package/dist/discovery/types.d.ts +38 -0
  92. package/dist/discovery/types.d.ts.map +1 -0
  93. package/dist/discovery/types.js +3 -0
  94. package/dist/discovery/types.js.map +1 -0
  95. package/dist/encoding/oer-parser.d.ts +39 -0
  96. package/dist/encoding/oer-parser.d.ts.map +1 -0
  97. package/dist/encoding/oer-parser.js +154 -0
  98. package/dist/encoding/oer-parser.js.map +1 -0
  99. package/dist/explorer-ui/assets/EventDetailPanel-CnSaMk3V.js +6 -0
  100. package/dist/explorer-ui/assets/FilterBar-BEmAzBku.js +26 -0
  101. package/dist/explorer-ui/assets/chevron-right-BUT9VhYe.js +11 -0
  102. package/dist/explorer-ui/assets/index-BZ2INVgy.js +360 -0
  103. package/dist/explorer-ui/assets/index-Cemh6svI.css +1 -0
  104. package/dist/explorer-ui/index.html +14 -0
  105. package/dist/explorer-ui/vite.svg +1 -0
  106. package/dist/facilitator/index.d.ts +2 -0
  107. package/dist/facilitator/index.d.ts.map +1 -0
  108. package/dist/facilitator/index.js +7 -0
  109. package/dist/facilitator/index.js.map +1 -0
  110. package/dist/facilitator/spsp-client.d.ts +18 -0
  111. package/dist/facilitator/spsp-client.d.ts.map +1 -0
  112. package/dist/facilitator/spsp-client.js +95 -0
  113. package/dist/facilitator/spsp-client.js.map +1 -0
  114. package/dist/http/admin-api.d.ts +123 -0
  115. package/dist/http/admin-api.d.ts.map +1 -0
  116. package/dist/http/admin-api.js +1057 -0
  117. package/dist/http/admin-api.js.map +1 -0
  118. package/dist/http/admin-server.d.ts +41 -0
  119. package/dist/http/admin-server.d.ts.map +1 -0
  120. package/dist/http/admin-server.js +156 -0
  121. package/dist/http/admin-server.js.map +1 -0
  122. package/dist/http/health-server.d.ts +22 -0
  123. package/dist/http/health-server.d.ts.map +1 -0
  124. package/dist/http/health-server.js +192 -0
  125. package/dist/http/health-server.js.map +1 -0
  126. package/dist/http/ilp-send-handler.d.ts +19 -0
  127. package/dist/http/ilp-send-handler.d.ts.map +1 -0
  128. package/dist/http/ilp-send-handler.js +162 -0
  129. package/dist/http/ilp-send-handler.js.map +1 -0
  130. package/dist/http/types.d.ts +39 -0
  131. package/dist/http/types.d.ts.map +1 -0
  132. package/dist/http/types.js +3 -0
  133. package/dist/http/types.js.map +1 -0
  134. package/dist/index.d.ts +2 -0
  135. package/dist/index.d.ts.map +1 -0
  136. package/dist/index.js +5 -0
  137. package/dist/index.js.map +1 -0
  138. package/dist/lib.d.ts +22 -0
  139. package/dist/lib.d.ts.map +1 -0
  140. package/dist/lib.js +41 -0
  141. package/dist/lib.js.map +1 -0
  142. package/dist/main.d.ts +4 -0
  143. package/dist/main.d.ts.map +1 -0
  144. package/dist/main.js +79 -0
  145. package/dist/main.js.map +1 -0
  146. package/dist/routing/packet-processor.d.ts +36 -0
  147. package/dist/routing/packet-processor.d.ts.map +1 -0
  148. package/dist/routing/packet-processor.js +112 -0
  149. package/dist/routing/packet-processor.js.map +1 -0
  150. package/dist/routing/packet-worker.d.ts +10 -0
  151. package/dist/routing/packet-worker.d.ts.map +1 -0
  152. package/dist/routing/packet-worker.js +34 -0
  153. package/dist/routing/packet-worker.js.map +1 -0
  154. package/dist/routing/routing-table.d.ts +15 -0
  155. package/dist/routing/routing-table.d.ts.map +1 -0
  156. package/dist/routing/routing-table.js +63 -0
  157. package/dist/routing/routing-table.js.map +1 -0
  158. package/dist/routing/worker-pool.d.ts +43 -0
  159. package/dist/routing/worker-pool.d.ts.map +1 -0
  160. package/dist/routing/worker-pool.js +228 -0
  161. package/dist/routing/worker-pool.js.map +1 -0
  162. package/dist/security/alert-notifier.d.ts +34 -0
  163. package/dist/security/alert-notifier.d.ts.map +1 -0
  164. package/dist/security/alert-notifier.js +136 -0
  165. package/dist/security/alert-notifier.js.map +1 -0
  166. package/dist/security/audit-logger.d.ts +34 -0
  167. package/dist/security/audit-logger.d.ts.map +1 -0
  168. package/dist/security/audit-logger.js +132 -0
  169. package/dist/security/audit-logger.js.map +1 -0
  170. package/dist/security/backends/aws-kms-backend.d.ts +18 -0
  171. package/dist/security/backends/aws-kms-backend.d.ts.map +1 -0
  172. package/dist/security/backends/aws-kms-backend.js +130 -0
  173. package/dist/security/backends/aws-kms-backend.js.map +1 -0
  174. package/dist/security/backends/azure-kv-backend.d.ts +17 -0
  175. package/dist/security/backends/azure-kv-backend.d.ts.map +1 -0
  176. package/dist/security/backends/azure-kv-backend.js +121 -0
  177. package/dist/security/backends/azure-kv-backend.js.map +1 -0
  178. package/dist/security/backends/environment-backend.d.ts +15 -0
  179. package/dist/security/backends/environment-backend.d.ts.map +1 -0
  180. package/dist/security/backends/environment-backend.js +56 -0
  181. package/dist/security/backends/environment-backend.js.map +1 -0
  182. package/dist/security/backends/gcp-kms-backend.d.ts +17 -0
  183. package/dist/security/backends/gcp-kms-backend.d.ts.map +1 -0
  184. package/dist/security/backends/gcp-kms-backend.js +110 -0
  185. package/dist/security/backends/gcp-kms-backend.js.map +1 -0
  186. package/dist/security/backends/hsm-backend.d.ts +18 -0
  187. package/dist/security/backends/hsm-backend.d.ts.map +1 -0
  188. package/dist/security/backends/hsm-backend.js +187 -0
  189. package/dist/security/backends/hsm-backend.js.map +1 -0
  190. package/dist/security/fraud-detector.d.ts +79 -0
  191. package/dist/security/fraud-detector.d.ts.map +1 -0
  192. package/dist/security/fraud-detector.js +147 -0
  193. package/dist/security/fraud-detector.js.map +1 -0
  194. package/dist/security/key-manager-signer.d.ts +15 -0
  195. package/dist/security/key-manager-signer.d.ts.map +1 -0
  196. package/dist/security/key-manager-signer.js +91 -0
  197. package/dist/security/key-manager-signer.js.map +1 -0
  198. package/dist/security/key-manager.d.ts +69 -0
  199. package/dist/security/key-manager.d.ts.map +1 -0
  200. package/dist/security/key-manager.js +79 -0
  201. package/dist/security/key-manager.js.map +1 -0
  202. package/dist/security/key-rotation-manager.d.ts +27 -0
  203. package/dist/security/key-rotation-manager.d.ts.map +1 -0
  204. package/dist/security/key-rotation-manager.js +142 -0
  205. package/dist/security/key-rotation-manager.js.map +1 -0
  206. package/dist/security/rate-limit-config.d.ts +7 -0
  207. package/dist/security/rate-limit-config.d.ts.map +1 -0
  208. package/dist/security/rate-limit-config.js +57 -0
  209. package/dist/security/rate-limit-config.js.map +1 -0
  210. package/dist/security/rate-limiter.d.ts +46 -0
  211. package/dist/security/rate-limiter.d.ts.map +1 -0
  212. package/dist/security/rate-limiter.js +170 -0
  213. package/dist/security/rate-limiter.js.map +1 -0
  214. package/dist/security/reputation-tracker.d.ts +30 -0
  215. package/dist/security/reputation-tracker.d.ts.map +1 -0
  216. package/dist/security/reputation-tracker.js +111 -0
  217. package/dist/security/reputation-tracker.js.map +1 -0
  218. package/dist/security/rules/balance-manipulation-rule.d.ts +23 -0
  219. package/dist/security/rules/balance-manipulation-rule.d.ts.map +1 -0
  220. package/dist/security/rules/balance-manipulation-rule.js +70 -0
  221. package/dist/security/rules/balance-manipulation-rule.js.map +1 -0
  222. package/dist/security/rules/double-spend-detection-rule.d.ts +23 -0
  223. package/dist/security/rules/double-spend-detection-rule.d.ts.map +1 -0
  224. package/dist/security/rules/double-spend-detection-rule.js +61 -0
  225. package/dist/security/rules/double-spend-detection-rule.js.map +1 -0
  226. package/dist/security/rules/rapid-channel-closure-rule.d.ts +16 -0
  227. package/dist/security/rules/rapid-channel-closure-rule.d.ts.map +1 -0
  228. package/dist/security/rules/rapid-channel-closure-rule.js +57 -0
  229. package/dist/security/rules/rapid-channel-closure-rule.js.map +1 -0
  230. package/dist/security/rules/sudden-traffic-spike-rule.d.ts +18 -0
  231. package/dist/security/rules/sudden-traffic-spike-rule.d.ts.map +1 -0
  232. package/dist/security/rules/sudden-traffic-spike-rule.js +92 -0
  233. package/dist/security/rules/sudden-traffic-spike-rule.js.map +1 -0
  234. package/dist/security/rules/unusual-settlement-amount-rule.d.ts +12 -0
  235. package/dist/security/rules/unusual-settlement-amount-rule.d.ts.map +1 -0
  236. package/dist/security/rules/unusual-settlement-amount-rule.js +33 -0
  237. package/dist/security/rules/unusual-settlement-amount-rule.js.map +1 -0
  238. package/dist/security/token-bucket.d.ts +16 -0
  239. package/dist/security/token-bucket.d.ts.map +1 -0
  240. package/dist/security/token-bucket.js +49 -0
  241. package/dist/security/token-bucket.js.map +1 -0
  242. package/dist/security/violation-counter.d.ts +11 -0
  243. package/dist/security/violation-counter.d.ts.map +1 -0
  244. package/dist/security/violation-counter.js +61 -0
  245. package/dist/security/violation-counter.js.map +1 -0
  246. package/dist/settlement/account-id-generator.d.ts +4 -0
  247. package/dist/settlement/account-id-generator.d.ts.map +1 -0
  248. package/dist/settlement/account-id-generator.js +38 -0
  249. package/dist/settlement/account-id-generator.js.map +1 -0
  250. package/dist/settlement/account-manager.d.ts +47 -0
  251. package/dist/settlement/account-manager.d.ts.map +1 -0
  252. package/dist/settlement/account-manager.js +447 -0
  253. package/dist/settlement/account-manager.js.map +1 -0
  254. package/dist/settlement/account-metadata.d.ts +11 -0
  255. package/dist/settlement/account-metadata.d.ts.map +1 -0
  256. package/dist/settlement/account-metadata.js +40 -0
  257. package/dist/settlement/account-metadata.js.map +1 -0
  258. package/dist/settlement/aptos-channel-sdk.d.ts +66 -0
  259. package/dist/settlement/aptos-channel-sdk.d.ts.map +1 -0
  260. package/dist/settlement/aptos-channel-sdk.js +274 -0
  261. package/dist/settlement/aptos-channel-sdk.js.map +1 -0
  262. package/dist/settlement/aptos-claim-signer.d.ts +57 -0
  263. package/dist/settlement/aptos-claim-signer.d.ts.map +1 -0
  264. package/dist/settlement/aptos-claim-signer.js +200 -0
  265. package/dist/settlement/aptos-claim-signer.js.map +1 -0
  266. package/dist/settlement/aptos-client.d.ts +99 -0
  267. package/dist/settlement/aptos-client.d.ts.map +1 -0
  268. package/dist/settlement/aptos-client.js +474 -0
  269. package/dist/settlement/aptos-client.js.map +1 -0
  270. package/dist/settlement/channel-manager.d.ts +66 -0
  271. package/dist/settlement/channel-manager.d.ts.map +1 -0
  272. package/dist/settlement/channel-manager.js +214 -0
  273. package/dist/settlement/channel-manager.js.map +1 -0
  274. package/dist/settlement/claim-receiver-db-schema.d.ts +4 -0
  275. package/dist/settlement/claim-receiver-db-schema.d.ts.map +1 -0
  276. package/dist/settlement/claim-receiver-db-schema.js +25 -0
  277. package/dist/settlement/claim-receiver-db-schema.js.map +1 -0
  278. package/dist/settlement/claim-receiver.d.ts +31 -0
  279. package/dist/settlement/claim-receiver.d.ts.map +1 -0
  280. package/dist/settlement/claim-receiver.js +228 -0
  281. package/dist/settlement/claim-receiver.js.map +1 -0
  282. package/dist/settlement/claim-redemption-service.d.ts +39 -0
  283. package/dist/settlement/claim-redemption-service.d.ts.map +1 -0
  284. package/dist/settlement/claim-redemption-service.js +189 -0
  285. package/dist/settlement/claim-redemption-service.js.map +1 -0
  286. package/dist/settlement/claim-sender-db-schema.d.ts +3 -0
  287. package/dist/settlement/claim-sender-db-schema.d.ts.map +1 -0
  288. package/dist/settlement/claim-sender-db-schema.js +18 -0
  289. package/dist/settlement/claim-sender-db-schema.js.map +1 -0
  290. package/dist/settlement/claim-sender.d.ts +22 -0
  291. package/dist/settlement/claim-sender.d.ts.map +1 -0
  292. package/dist/settlement/claim-sender.js +108 -0
  293. package/dist/settlement/claim-sender.js.map +1 -0
  294. package/dist/settlement/eip712-helper.d.ts +13 -0
  295. package/dist/settlement/eip712-helper.d.ts.map +1 -0
  296. package/dist/settlement/eip712-helper.js +24 -0
  297. package/dist/settlement/eip712-helper.js.map +1 -0
  298. package/dist/settlement/in-memory-ledger-client.d.ts +40 -0
  299. package/dist/settlement/in-memory-ledger-client.d.ts.map +1 -0
  300. package/dist/settlement/in-memory-ledger-client.js +177 -0
  301. package/dist/settlement/in-memory-ledger-client.js.map +1 -0
  302. package/dist/settlement/ledger-client.d.ts +22 -0
  303. package/dist/settlement/ledger-client.d.ts.map +1 -0
  304. package/dist/settlement/ledger-client.js +3 -0
  305. package/dist/settlement/ledger-client.js.map +1 -0
  306. package/dist/settlement/metrics-collector.d.ts +29 -0
  307. package/dist/settlement/metrics-collector.d.ts.map +1 -0
  308. package/dist/settlement/metrics-collector.js +81 -0
  309. package/dist/settlement/metrics-collector.js.map +1 -0
  310. package/dist/settlement/payment-channel-sdk.d.ts +59 -0
  311. package/dist/settlement/payment-channel-sdk.d.ts.map +1 -0
  312. package/dist/settlement/payment-channel-sdk.js +677 -0
  313. package/dist/settlement/payment-channel-sdk.js.map +1 -0
  314. package/dist/settlement/per-packet-claim-service.d.ts +33 -0
  315. package/dist/settlement/per-packet-claim-service.d.ts.map +1 -0
  316. package/dist/settlement/per-packet-claim-service.js +177 -0
  317. package/dist/settlement/per-packet-claim-service.js.map +1 -0
  318. package/dist/settlement/settlement-api.d.ts +37 -0
  319. package/dist/settlement/settlement-api.d.ts.map +1 -0
  320. package/dist/settlement/settlement-api.js +172 -0
  321. package/dist/settlement/settlement-api.js.map +1 -0
  322. package/dist/settlement/settlement-coordinator.d.ts +47 -0
  323. package/dist/settlement/settlement-coordinator.d.ts.map +1 -0
  324. package/dist/settlement/settlement-coordinator.js +166 -0
  325. package/dist/settlement/settlement-coordinator.js.map +1 -0
  326. package/dist/settlement/settlement-executor.d.ts +44 -0
  327. package/dist/settlement/settlement-executor.d.ts.map +1 -0
  328. package/dist/settlement/settlement-executor.js +247 -0
  329. package/dist/settlement/settlement-executor.js.map +1 -0
  330. package/dist/settlement/settlement-monitor.d.ts +29 -0
  331. package/dist/settlement/settlement-monitor.d.ts.map +1 -0
  332. package/dist/settlement/settlement-monitor.js +172 -0
  333. package/dist/settlement/settlement-monitor.js.map +1 -0
  334. package/dist/settlement/tigerbeetle-batch-writer.d.ts +58 -0
  335. package/dist/settlement/tigerbeetle-batch-writer.d.ts.map +1 -0
  336. package/dist/settlement/tigerbeetle-batch-writer.js +162 -0
  337. package/dist/settlement/tigerbeetle-batch-writer.js.map +1 -0
  338. package/dist/settlement/tigerbeetle-client.d.ts +40 -0
  339. package/dist/settlement/tigerbeetle-client.d.ts.map +1 -0
  340. package/dist/settlement/tigerbeetle-client.js +279 -0
  341. package/dist/settlement/tigerbeetle-client.js.map +1 -0
  342. package/dist/settlement/tigerbeetle-errors.d.ts +23 -0
  343. package/dist/settlement/tigerbeetle-errors.d.ts.map +1 -0
  344. package/dist/settlement/tigerbeetle-errors.js +58 -0
  345. package/dist/settlement/tigerbeetle-errors.js.map +1 -0
  346. package/dist/settlement/types.d.ts +64 -0
  347. package/dist/settlement/types.d.ts.map +1 -0
  348. package/dist/settlement/types.js +42 -0
  349. package/dist/settlement/types.js.map +1 -0
  350. package/dist/settlement/unified-settlement-executor.d.ts +34 -0
  351. package/dist/settlement/unified-settlement-executor.d.ts.map +1 -0
  352. package/dist/settlement/unified-settlement-executor.js +145 -0
  353. package/dist/settlement/unified-settlement-executor.js.map +1 -0
  354. package/dist/settlement/xrp-channel-lifecycle.d.ts +41 -0
  355. package/dist/settlement/xrp-channel-lifecycle.d.ts.map +1 -0
  356. package/dist/settlement/xrp-channel-lifecycle.js +142 -0
  357. package/dist/settlement/xrp-channel-lifecycle.js.map +1 -0
  358. package/dist/settlement/xrp-channel-manager.d.ts +59 -0
  359. package/dist/settlement/xrp-channel-manager.d.ts.map +1 -0
  360. package/dist/settlement/xrp-channel-manager.js +160 -0
  361. package/dist/settlement/xrp-channel-manager.js.map +1 -0
  362. package/dist/settlement/xrp-channel-sdk.d.ts +30 -0
  363. package/dist/settlement/xrp-channel-sdk.d.ts.map +1 -0
  364. package/dist/settlement/xrp-channel-sdk.js +164 -0
  365. package/dist/settlement/xrp-channel-sdk.js.map +1 -0
  366. package/dist/settlement/xrp-claim-signer.d.ts +22 -0
  367. package/dist/settlement/xrp-claim-signer.d.ts.map +1 -0
  368. package/dist/settlement/xrp-claim-signer.js +122 -0
  369. package/dist/settlement/xrp-claim-signer.js.map +1 -0
  370. package/dist/settlement/xrpl-client.d.ts +104 -0
  371. package/dist/settlement/xrpl-client.d.ts.map +1 -0
  372. package/dist/settlement/xrpl-client.js +304 -0
  373. package/dist/settlement/xrpl-client.js.map +1 -0
  374. package/dist/test/testnet-config.d.ts +58 -0
  375. package/dist/test/testnet-config.d.ts.map +1 -0
  376. package/dist/test/testnet-config.js +89 -0
  377. package/dist/test/testnet-config.js.map +1 -0
  378. package/dist/test-utils/index.d.ts +3 -0
  379. package/dist/test-utils/index.d.ts.map +1 -0
  380. package/dist/test-utils/index.js +15 -0
  381. package/dist/test-utils/index.js.map +1 -0
  382. package/dist/test-utils/isolated-test-env.d.ts +31 -0
  383. package/dist/test-utils/isolated-test-env.d.ts.map +1 -0
  384. package/dist/test-utils/isolated-test-env.js +127 -0
  385. package/dist/test-utils/isolated-test-env.js.map +1 -0
  386. package/dist/test-utils/mock-factories-patch.d.ts +2 -0
  387. package/dist/test-utils/mock-factories-patch.d.ts.map +1 -0
  388. package/dist/test-utils/mock-factories-patch.js +3 -0
  389. package/dist/test-utils/mock-factories-patch.js.map +1 -0
  390. package/dist/test-utils/mock-factories.d.ts +22 -0
  391. package/dist/test-utils/mock-factories.d.ts.map +1 -0
  392. package/dist/test-utils/mock-factories.js +56 -0
  393. package/dist/test-utils/mock-factories.js.map +1 -0
  394. package/dist/utils/connection-pool.d.ts +42 -0
  395. package/dist/utils/connection-pool.d.ts.map +1 -0
  396. package/dist/utils/connection-pool.js +209 -0
  397. package/dist/utils/connection-pool.js.map +1 -0
  398. package/dist/utils/evm-rpc-connection-pool.d.ts +8 -0
  399. package/dist/utils/evm-rpc-connection-pool.d.ts.map +1 -0
  400. package/dist/utils/evm-rpc-connection-pool.js +40 -0
  401. package/dist/utils/evm-rpc-connection-pool.js.map +1 -0
  402. package/dist/utils/logger.d.ts +6 -0
  403. package/dist/utils/logger.d.ts.map +1 -0
  404. package/dist/utils/logger.js +58 -0
  405. package/dist/utils/logger.js.map +1 -0
  406. package/dist/utils/optional-require.d.ts +2 -0
  407. package/dist/utils/optional-require.d.ts.map +1 -0
  408. package/dist/utils/optional-require.js +54 -0
  409. package/dist/utils/optional-require.js.map +1 -0
  410. package/dist/utils/xrp-wss-connection-pool.d.ts +8 -0
  411. package/dist/utils/xrp-wss-connection-pool.d.ts.map +1 -0
  412. package/dist/utils/xrp-wss-connection-pool.js +42 -0
  413. package/dist/utils/xrp-wss-connection-pool.js.map +1 -0
  414. package/dist/wallet/audit-logger.d.ts +22 -0
  415. package/dist/wallet/audit-logger.d.ts.map +1 -0
  416. package/dist/wallet/audit-logger.js +120 -0
  417. package/dist/wallet/audit-logger.js.map +1 -0
  418. package/dist/wallet/fraud-detector-interface.d.ts +14 -0
  419. package/dist/wallet/fraud-detector-interface.d.ts.map +1 -0
  420. package/dist/wallet/fraud-detector-interface.js +3 -0
  421. package/dist/wallet/fraud-detector-interface.js.map +1 -0
  422. package/dist/wallet/key-manager.d.ts +6 -0
  423. package/dist/wallet/key-manager.d.ts.map +1 -0
  424. package/dist/wallet/key-manager.js +3 -0
  425. package/dist/wallet/key-manager.js.map +1 -0
  426. package/dist/wallet/placeholder-fraud-detector.d.ts +10 -0
  427. package/dist/wallet/placeholder-fraud-detector.d.ts.map +1 -0
  428. package/dist/wallet/placeholder-fraud-detector.js +10 -0
  429. package/dist/wallet/placeholder-fraud-detector.js.map +1 -0
  430. package/dist/wallet/rate-limiter.d.ts +26 -0
  431. package/dist/wallet/rate-limiter.d.ts.map +1 -0
  432. package/dist/wallet/rate-limiter.js +114 -0
  433. package/dist/wallet/rate-limiter.js.map +1 -0
  434. package/dist/wallet/suspicious-activity-detector.d.ts +25 -0
  435. package/dist/wallet/suspicious-activity-detector.d.ts.map +1 -0
  436. package/dist/wallet/suspicious-activity-detector.js +97 -0
  437. package/dist/wallet/suspicious-activity-detector.js.map +1 -0
  438. package/dist/wallet/treasury-wallet.d.ts +20 -0
  439. package/dist/wallet/treasury-wallet.d.ts.map +1 -0
  440. package/dist/wallet/treasury-wallet.js +151 -0
  441. package/dist/wallet/treasury-wallet.js.map +1 -0
  442. package/dist/wallet/wallet-authentication.d.ts +31 -0
  443. package/dist/wallet/wallet-authentication.d.ts.map +1 -0
  444. package/dist/wallet/wallet-authentication.js +102 -0
  445. package/dist/wallet/wallet-authentication.js.map +1 -0
  446. package/dist/wallet/wallet-db-schema.d.ts +11 -0
  447. package/dist/wallet/wallet-db-schema.d.ts.map +1 -0
  448. package/dist/wallet/wallet-db-schema.js +79 -0
  449. package/dist/wallet/wallet-db-schema.js.map +1 -0
  450. package/dist/wallet/wallet-security.d.ts +58 -0
  451. package/dist/wallet/wallet-security.d.ts.map +1 -0
  452. package/dist/wallet/wallet-security.js +148 -0
  453. package/dist/wallet/wallet-security.js.map +1 -0
  454. package/dist/wallet/wallet-seed-manager.d.ts +65 -0
  455. package/dist/wallet/wallet-seed-manager.d.ts.map +1 -0
  456. package/dist/wallet/wallet-seed-manager.js +418 -0
  457. package/dist/wallet/wallet-seed-manager.js.map +1 -0
  458. package/package.json +134 -0
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.KeyManagerSigner = void 0;
4
+ exports.createKeyManagerSigner = createKeyManagerSigner;
5
+ const optional_require_1 = require("../utils/optional-require");
6
+ async function createKeyManagerSigner(keyManager, evmKeyId, provider) {
7
+ const { ethers } = await (0, optional_require_1.requireOptional)('ethers', 'EVM settlement');
8
+ class KeyManagerSignerImpl extends ethers.AbstractSigner {
9
+ keyManager;
10
+ evmKeyId;
11
+ _cachedAddress = null;
12
+ constructor(km, keyId, p) {
13
+ super(p);
14
+ this.keyManager = km;
15
+ this.evmKeyId = keyId;
16
+ }
17
+ async getAddress() {
18
+ if (this._cachedAddress) {
19
+ return this._cachedAddress;
20
+ }
21
+ const publicKeyBuffer = await this.keyManager.getPublicKey(this.evmKeyId);
22
+ const publicKeyHex = '0x' + publicKeyBuffer.toString('hex');
23
+ const pubKeyWithoutPrefix = publicKeyHex.startsWith('0x04')
24
+ ? '0x' + publicKeyHex.slice(4)
25
+ : publicKeyHex;
26
+ const addressHash = ethers.keccak256(pubKeyWithoutPrefix);
27
+ this._cachedAddress = ethers.getAddress('0x' + addressHash.slice(-40));
28
+ return this._cachedAddress;
29
+ }
30
+ async signTransaction(transaction) {
31
+ const resolved = await ethers.resolveProperties(transaction);
32
+ const tx = ethers.Transaction.from(resolved);
33
+ const digest = tx.unsignedHash;
34
+ const signatureBuffer = await this.keyManager.sign(Buffer.from(digest.slice(2), 'hex'), this.evmKeyId);
35
+ const signature = ethers.Signature.from('0x' + signatureBuffer.toString('hex'));
36
+ tx.signature = signature;
37
+ return tx.serialized;
38
+ }
39
+ async sendTransaction(transaction) {
40
+ const provider = this.provider;
41
+ if (!provider) {
42
+ throw new Error('Provider required to send transaction');
43
+ }
44
+ const from = await this.getAddress();
45
+ const network = await provider.getNetwork();
46
+ const chainId = Number(network.chainId);
47
+ const feeData = await provider.getFeeData();
48
+ if (!feeData.maxFeePerGas || !feeData.maxPriorityFeePerGas) {
49
+ throw new Error('Unable to retrieve EIP-1559 fee data from provider');
50
+ }
51
+ const populatedTx = await ethers.resolveProperties({
52
+ to: transaction.to,
53
+ nonce: transaction.nonce !== undefined
54
+ ? transaction.nonce
55
+ : await provider.getTransactionCount(from, 'pending'),
56
+ gasLimit: transaction.gasLimit !== undefined
57
+ ? transaction.gasLimit
58
+ : await provider.estimateGas({
59
+ ...transaction,
60
+ from: from,
61
+ }),
62
+ data: transaction.data ?? '0x',
63
+ value: transaction.value ?? 0,
64
+ chainId: transaction.chainId ?? chainId,
65
+ type: 2,
66
+ maxFeePerGas: transaction.maxFeePerGas ?? feeData.maxFeePerGas,
67
+ maxPriorityFeePerGas: transaction.maxPriorityFeePerGas ?? feeData.maxPriorityFeePerGas,
68
+ });
69
+ const signedTx = await this.signTransaction(populatedTx);
70
+ const txResponse = await provider.broadcastTransaction(signedTx);
71
+ return txResponse;
72
+ }
73
+ async signMessage(message) {
74
+ const messageBytes = typeof message === 'string' ? ethers.toUtf8Bytes(message) : message;
75
+ const messageHash = ethers.hashMessage(messageBytes);
76
+ const signatureBuffer = await this.keyManager.sign(Buffer.from(messageHash.slice(2), 'hex'), this.evmKeyId);
77
+ return '0x' + signatureBuffer.toString('hex');
78
+ }
79
+ async signTypedData(domain, types, value) {
80
+ const hash = ethers.TypedDataEncoder.hash(domain, types, value);
81
+ const signatureBuffer = await this.keyManager.sign(Buffer.from(hash.slice(2), 'hex'), this.evmKeyId);
82
+ return '0x' + signatureBuffer.toString('hex');
83
+ }
84
+ connect(provider) {
85
+ return new KeyManagerSignerImpl(this.keyManager, this.evmKeyId, provider);
86
+ }
87
+ }
88
+ return new KeyManagerSignerImpl(keyManager, evmKeyId, provider);
89
+ }
90
+ exports.KeyManagerSigner = null;
91
+ //# sourceMappingURL=key-manager-signer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"key-manager-signer.js","sourceRoot":"","sources":["../../src/security/key-manager-signer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,69 @@
1
+ import { Logger } from 'pino';
2
+ export interface KeyManagerBackend {
3
+ sign(message: Buffer, keyId: string): Promise<Buffer>;
4
+ getPublicKey(keyId: string): Promise<Buffer>;
5
+ rotateKey(keyId: string): Promise<string>;
6
+ }
7
+ export interface AWSConfig {
8
+ region: string;
9
+ evmKeyId: string;
10
+ credentials?: {
11
+ accessKeyId: string;
12
+ secretAccessKey: string;
13
+ };
14
+ }
15
+ export interface GCPConfig {
16
+ projectId: string;
17
+ locationId: string;
18
+ keyRingId: string;
19
+ evmKeyId: string;
20
+ }
21
+ export interface AzureConfig {
22
+ vaultUrl: string;
23
+ evmKeyName: string;
24
+ credentials?: {
25
+ tenantId: string;
26
+ clientId: string;
27
+ clientSecret: string;
28
+ };
29
+ }
30
+ export interface HSMConfig {
31
+ pkcs11LibraryPath: string;
32
+ slotId: number;
33
+ pin: string;
34
+ evmKeyLabel: string;
35
+ }
36
+ export interface KeyRotationConfig {
37
+ enabled: boolean;
38
+ intervalDays: number;
39
+ overlapDays: number;
40
+ notifyBeforeDays: number;
41
+ }
42
+ export interface KeyManagerConfig {
43
+ backend: 'env' | 'aws-kms' | 'gcp-kms' | 'azure-kv' | 'hsm';
44
+ nodeId: string;
45
+ evmPrivateKey?: string;
46
+ aws?: AWSConfig;
47
+ gcp?: GCPConfig;
48
+ azure?: AzureConfig;
49
+ hsm?: HSMConfig;
50
+ rotation?: KeyRotationConfig;
51
+ }
52
+ export interface AuditLogEntry {
53
+ event: 'SIGN_REQUEST' | 'SIGN_SUCCESS' | 'SIGN_FAILURE' | 'KEY_ROTATION_START' | 'KEY_ROTATION_COMPLETE' | 'KEY_ACCESS_DENIED';
54
+ keyId: string;
55
+ timestamp: number;
56
+ nodeId: string;
57
+ backend: string;
58
+ details?: Record<string, unknown>;
59
+ }
60
+ export declare class KeyManager {
61
+ private backend;
62
+ private logger;
63
+ private auditLogger;
64
+ constructor(config: KeyManagerConfig, logger: Logger);
65
+ sign(message: Buffer, keyId: string): Promise<Buffer>;
66
+ getPublicKey(keyId: string): Promise<Buffer>;
67
+ rotateKey(keyId: string): Promise<string>;
68
+ }
69
+ //# sourceMappingURL=key-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"key-manager.d.ts","sourceRoot":"","sources":["../../src/security/key-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAO9B,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACtD,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7C,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CAC3C;AAKD,MAAM,WAAW,SAAS;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE;QACZ,WAAW,EAAE,MAAM,CAAC;QACpB,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC;CACH;AAKD,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAKD,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE;QACZ,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,YAAY,EAAE,MAAM,CAAC;KACtB,CAAC;CACH;AAKD,MAAM,WAAW,SAAS;IACxB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,EAAE,MAAM,CAAC;CACrB;AAKD,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,OAAO,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAKD,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,KAAK,GAAG,SAAS,GAAG,SAAS,GAAG,UAAU,GAAG,KAAK,CAAC;IAC5D,MAAM,EAAE,MAAM,CAAC;IAGf,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,KAAK,CAAC,EAAE,WAAW,CAAC;IACpB,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,QAAQ,CAAC,EAAE,iBAAiB,CAAC;CAC9B;AAKD,MAAM,WAAW,aAAa;IAC5B,KAAK,EACD,cAAc,GACd,cAAc,GACd,cAAc,GACd,oBAAoB,GACpB,uBAAuB,GACvB,mBAAmB,CAAC;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAMD,qBAAa,UAAU;IACrB,OAAO,CAAC,OAAO,CAAoB;IACnC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,WAAW,CAAc;gBAErB,MAAM,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM;IAyC9C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IA6BrD,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAkB5C,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAkBhD"}
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.KeyManager = void 0;
4
+ const audit_logger_1 = require("./audit-logger");
5
+ class KeyManager {
6
+ backend;
7
+ logger;
8
+ auditLogger;
9
+ constructor(config, logger) {
10
+ this.logger = logger.child({ component: 'KeyManager' });
11
+ this.auditLogger = new audit_logger_1.AuditLogger(logger, {
12
+ nodeId: config.nodeId,
13
+ backend: config.backend,
14
+ });
15
+ switch (config.backend) {
16
+ case 'env': {
17
+ const { EnvironmentVariableBackend } = require('./backends/environment-backend');
18
+ this.backend = new EnvironmentVariableBackend(this.logger, {
19
+ evmPrivateKey: config.evmPrivateKey,
20
+ });
21
+ break;
22
+ }
23
+ case 'aws-kms':
24
+ case 'gcp-kms':
25
+ case 'azure-kv':
26
+ case 'hsm': {
27
+ throw new Error(`Backend type '${config.backend}' is not supported. Only 'env' backend is available.`);
28
+ }
29
+ default:
30
+ throw new Error(`Unknown backend type: ${config.backend}`);
31
+ }
32
+ this.logger.info({ backend: config.backend }, 'KeyManager initialized');
33
+ }
34
+ async sign(message, keyId) {
35
+ const messageHash = message.toString('hex');
36
+ this.auditLogger.logSignRequest(keyId, messageHash);
37
+ this.logger.debug({ keyId, messageLength: message.length }, 'Signing message');
38
+ try {
39
+ const signature = await this.backend.sign(message, keyId);
40
+ const signatureHash = signature.toString('hex');
41
+ this.auditLogger.logSignSuccess(keyId, signatureHash);
42
+ this.logger.info({ keyId, signatureLength: signature.length }, 'Message signed successfully');
43
+ return signature;
44
+ }
45
+ catch (error) {
46
+ this.auditLogger.logSignFailure(keyId, error);
47
+ this.logger.error({ keyId, error }, 'Message signing failed');
48
+ throw error;
49
+ }
50
+ }
51
+ async getPublicKey(keyId) {
52
+ this.logger.debug({ keyId }, 'Retrieving public key');
53
+ try {
54
+ const publicKey = await this.backend.getPublicKey(keyId);
55
+ this.logger.info({ keyId, publicKeyLength: publicKey.length }, 'Public key retrieved');
56
+ return publicKey;
57
+ }
58
+ catch (error) {
59
+ this.logger.error({ keyId, error }, 'Public key retrieval failed');
60
+ throw error;
61
+ }
62
+ }
63
+ async rotateKey(keyId) {
64
+ this.auditLogger.logKeyRotation(keyId, '', 'START');
65
+ this.logger.info({ keyId }, 'Starting key rotation');
66
+ try {
67
+ const newKeyId = await this.backend.rotateKey(keyId);
68
+ this.auditLogger.logKeyRotation(keyId, newKeyId, 'COMPLETE');
69
+ this.logger.info({ oldKeyId: keyId, newKeyId }, 'Key rotation completed');
70
+ return newKeyId;
71
+ }
72
+ catch (error) {
73
+ this.logger.error({ keyId, error }, 'Key rotation failed');
74
+ throw error;
75
+ }
76
+ }
77
+ }
78
+ exports.KeyManager = KeyManager;
79
+ //# sourceMappingURL=key-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"key-manager.js","sourceRoot":"","sources":["../../src/security/key-manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import { KeyManager, KeyRotationConfig } from './key-manager';
2
+ import { Logger } from 'pino';
3
+ export interface KeyRotationMetadata {
4
+ oldKeyId: string;
5
+ newKeyId: string;
6
+ rotationDate: number;
7
+ overlapEndsAt: number;
8
+ }
9
+ export declare class KeyRotationManager {
10
+ private readonly keyManager;
11
+ private readonly config;
12
+ private readonly logger;
13
+ private rotationTimer?;
14
+ private notificationTimer?;
15
+ private rotationMetadata;
16
+ constructor(keyManager: KeyManager, config: KeyRotationConfig, logger: Logger);
17
+ start(): void;
18
+ stop(): void;
19
+ private checkNotificationNeeded;
20
+ rotateKey(keyId: string): Promise<string>;
21
+ private scheduleOverlapCleanup;
22
+ private disableOldKey;
23
+ isKeyValid(keyId: string): boolean;
24
+ getRotationMetadata(keyId: string): KeyRotationMetadata | undefined;
25
+ getAllRotationMetadata(): Map<string, KeyRotationMetadata>;
26
+ }
27
+ //# sourceMappingURL=key-rotation-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"key-rotation-manager.d.ts","sourceRoot":"","sources":["../../src/security/key-rotation-manager.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAM9B,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;CACvB;AAWD,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAC3C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,aAAa,CAAC,CAAiB;IACvC,OAAO,CAAC,iBAAiB,CAAC,CAAiB;IAC3C,OAAO,CAAC,gBAAgB,CAA+C;gBAS3D,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM;IA2B7E,KAAK,IAAI,IAAI;IAyCb,IAAI,IAAI,IAAI;IAkBZ,OAAO,CAAC,uBAAuB;IA0BzB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAiD/C,OAAO,CAAC,sBAAsB;IA8B9B,OAAO,CAAC,aAAa;IA6BrB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IA0BlC,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,mBAAmB,GAAG,SAAS;IAsBnE,sBAAsB,IAAI,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC;CAG3D"}
@@ -0,0 +1,142 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.KeyRotationManager = void 0;
4
+ class KeyRotationManager {
5
+ keyManager;
6
+ config;
7
+ logger;
8
+ rotationTimer;
9
+ notificationTimer;
10
+ rotationMetadata = new Map();
11
+ constructor(keyManager, config, logger) {
12
+ this.keyManager = keyManager;
13
+ this.config = config;
14
+ this.logger = logger.child({ component: 'KeyRotationManager' });
15
+ if (config.intervalDays <= 0) {
16
+ throw new Error('Rotation interval must be positive');
17
+ }
18
+ if (config.overlapDays < 0) {
19
+ throw new Error('Overlap days must be non-negative');
20
+ }
21
+ if (config.notifyBeforeDays < 0) {
22
+ throw new Error('Notification days must be non-negative');
23
+ }
24
+ if (config.overlapDays >= config.intervalDays) {
25
+ throw new Error('Overlap period must be less than rotation interval');
26
+ }
27
+ }
28
+ start() {
29
+ if (!this.config.enabled) {
30
+ this.logger.info('Key rotation is disabled in configuration');
31
+ return;
32
+ }
33
+ this.stop();
34
+ const rotationIntervalMs = this.config.intervalDays * 24 * 60 * 60 * 1000;
35
+ this.rotationTimer = setInterval(() => {
36
+ this.logger.info('Rotation timer triggered - checking for keys to rotate');
37
+ }, rotationIntervalMs);
38
+ const dailyCheckMs = 24 * 60 * 60 * 1000;
39
+ this.notificationTimer = setInterval(() => {
40
+ this.checkNotificationNeeded();
41
+ }, dailyCheckMs);
42
+ this.logger.info({
43
+ rotationIntervalDays: this.config.intervalDays,
44
+ overlapDays: this.config.overlapDays,
45
+ notifyBeforeDays: this.config.notifyBeforeDays,
46
+ }, 'Key rotation scheduler started');
47
+ }
48
+ stop() {
49
+ if (this.rotationTimer) {
50
+ clearInterval(this.rotationTimer);
51
+ this.rotationTimer = undefined;
52
+ }
53
+ if (this.notificationTimer) {
54
+ clearInterval(this.notificationTimer);
55
+ this.notificationTimer = undefined;
56
+ }
57
+ this.logger.info('Key rotation scheduler stopped');
58
+ }
59
+ checkNotificationNeeded() {
60
+ this.logger.debug('Checking if rotation notifications needed');
61
+ }
62
+ async rotateKey(keyId) {
63
+ this.logger.info({ keyId }, 'Starting key rotation');
64
+ try {
65
+ const newKeyId = await this.keyManager.rotateKey(keyId);
66
+ const rotationDate = Date.now();
67
+ const overlapEndsAt = rotationDate + this.config.overlapDays * 24 * 60 * 60 * 1000;
68
+ const metadata = {
69
+ oldKeyId: keyId,
70
+ newKeyId,
71
+ rotationDate,
72
+ overlapEndsAt,
73
+ };
74
+ this.rotationMetadata.set(newKeyId, metadata);
75
+ this.logger.info({
76
+ oldKeyId: keyId,
77
+ newKeyId,
78
+ rotationDate: new Date(rotationDate).toISOString(),
79
+ overlapEndsAt: new Date(overlapEndsAt).toISOString(),
80
+ overlapDays: this.config.overlapDays,
81
+ }, 'Key rotation completed - overlap period started');
82
+ this.scheduleOverlapCleanup(keyId, newKeyId, overlapEndsAt);
83
+ return newKeyId;
84
+ }
85
+ catch (error) {
86
+ this.logger.error({ keyId, error }, 'Key rotation failed');
87
+ throw error;
88
+ }
89
+ }
90
+ scheduleOverlapCleanup(oldKeyId, newKeyId, overlapEndsAt) {
91
+ const delayMs = overlapEndsAt - Date.now();
92
+ if (delayMs <= 0) {
93
+ this.disableOldKey(oldKeyId, newKeyId);
94
+ return;
95
+ }
96
+ setTimeout(() => {
97
+ this.disableOldKey(oldKeyId, newKeyId);
98
+ }, delayMs);
99
+ this.logger.debug({
100
+ oldKeyId,
101
+ newKeyId,
102
+ overlapEndsAt: new Date(overlapEndsAt).toISOString(),
103
+ delayMs,
104
+ }, 'Scheduled old key cleanup after overlap period');
105
+ }
106
+ disableOldKey(oldKeyId, newKeyId) {
107
+ this.logger.info({
108
+ oldKeyId,
109
+ newKeyId,
110
+ }, 'Overlap period expired - disabling old key');
111
+ this.rotationMetadata.delete(newKeyId);
112
+ }
113
+ isKeyValid(keyId) {
114
+ const metadata = this.rotationMetadata.get(keyId);
115
+ if (metadata) {
116
+ return true;
117
+ }
118
+ for (const [, meta] of this.rotationMetadata.entries()) {
119
+ if (meta.oldKeyId === keyId) {
120
+ return Date.now() < meta.overlapEndsAt;
121
+ }
122
+ }
123
+ return true;
124
+ }
125
+ getRotationMetadata(keyId) {
126
+ const metadata = this.rotationMetadata.get(keyId);
127
+ if (metadata) {
128
+ return metadata;
129
+ }
130
+ for (const [, meta] of this.rotationMetadata.entries()) {
131
+ if (meta.oldKeyId === keyId) {
132
+ return meta;
133
+ }
134
+ }
135
+ return undefined;
136
+ }
137
+ getAllRotationMetadata() {
138
+ return new Map(this.rotationMetadata);
139
+ }
140
+ }
141
+ exports.KeyRotationManager = KeyRotationManager;
142
+ //# sourceMappingURL=key-rotation-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"key-rotation-manager.js","sourceRoot":"","sources":["../../src/security/key-rotation-manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { RateLimitConfig, PeerRateLimitConfig } from './rate-limiter';
2
+ export declare const DEFAULT_RATE_LIMIT_CONFIG: RateLimitConfig;
3
+ export declare function createRateLimitConfig(overrides?: Partial<RateLimitConfig>): RateLimitConfig;
4
+ export declare function addTrustedPeer(config: RateLimitConfig, peerId: string): RateLimitConfig;
5
+ export declare function setPeerLimit(config: RateLimitConfig, peerId: string, peerConfig: PeerRateLimitConfig): RateLimitConfig;
6
+ export declare function isRateLimitingEnabled(): boolean;
7
+ //# sourceMappingURL=rate-limit-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rate-limit-config.d.ts","sourceRoot":"","sources":["../../src/security/rate-limit-config.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAK3E,eAAO,MAAM,yBAAyB,EAAE,eAQvC,CAAC;AAKF,wBAAgB,qBAAqB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,eAAe,CAK3F;AAKD,wBAAgB,cAAc,CAAC,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,GAAG,eAAe,CAOvF;AAKD,wBAAgB,YAAY,CAC1B,MAAM,EAAE,eAAe,EACvB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,mBAAmB,GAC9B,eAAe,CAOjB;AA8BD,wBAAgB,qBAAqB,IAAI,OAAO,CAE/C"}
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DEFAULT_RATE_LIMIT_CONFIG = void 0;
4
+ exports.createRateLimitConfig = createRateLimitConfig;
5
+ exports.addTrustedPeer = addTrustedPeer;
6
+ exports.setPeerLimit = setPeerLimit;
7
+ exports.isRateLimitingEnabled = isRateLimitingEnabled;
8
+ exports.DEFAULT_RATE_LIMIT_CONFIG = {
9
+ maxRequestsPerSecond: parseIntEnv('RATE_LIMIT_MAX_PER_SECOND', 1000),
10
+ maxRequestsPerMinute: parseIntEnv('RATE_LIMIT_MAX_PER_MINUTE', 60000),
11
+ burstSize: parseIntEnv('RATE_LIMIT_BURST_SIZE', 2000),
12
+ blockDuration: parseIntEnv('RATE_LIMIT_BLOCK_DURATION', 300),
13
+ violationThreshold: parseIntEnv('RATE_LIMIT_VIOLATION_THRESHOLD', 100),
14
+ violationWindowSeconds: parseIntEnv('RATE_LIMIT_VIOLATION_WINDOW', 60),
15
+ adaptiveRateLimiting: parseBoolEnv('RATE_LIMIT_ADAPTIVE_ENABLED', true),
16
+ };
17
+ function createRateLimitConfig(overrides) {
18
+ return {
19
+ ...exports.DEFAULT_RATE_LIMIT_CONFIG,
20
+ ...overrides,
21
+ };
22
+ }
23
+ function addTrustedPeer(config, peerId) {
24
+ const trustedPeers = config.trustedPeers ?? new Set();
25
+ trustedPeers.add(peerId);
26
+ return {
27
+ ...config,
28
+ trustedPeers,
29
+ };
30
+ }
31
+ function setPeerLimit(config, peerId, peerConfig) {
32
+ const peerLimits = config.peerLimits ?? new Map();
33
+ peerLimits.set(peerId, peerConfig);
34
+ return {
35
+ ...config,
36
+ peerLimits,
37
+ };
38
+ }
39
+ function parseIntEnv(key, defaultValue) {
40
+ const value = process.env[key];
41
+ if (!value) {
42
+ return defaultValue;
43
+ }
44
+ const parsed = parseInt(value, 10);
45
+ return isNaN(parsed) ? defaultValue : parsed;
46
+ }
47
+ function parseBoolEnv(key, defaultValue) {
48
+ const value = process.env[key]?.toLowerCase();
49
+ if (!value) {
50
+ return defaultValue;
51
+ }
52
+ return value === 'true' || value === '1' || value === 'yes';
53
+ }
54
+ function isRateLimitingEnabled() {
55
+ return parseBoolEnv('RATE_LIMIT_ENABLED', true);
56
+ }
57
+ //# sourceMappingURL=rate-limit-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rate-limit-config.js","sourceRoot":"","sources":["../../src/security/rate-limit-config.ts"],"names":[],"mappings":";;;AAwBA,sDAKC;AAKD,wCAOC;AAKD,oCAWC;AA8BD,sDAEC;AA9EY,QAAA,yBAAyB,GAAoB;IACxD,oBAAoB,EAAE,WAAW,CAAC,2BAA2B,EAAE,IAAI,CAAC;IACpE,oBAAoB,EAAE,WAAW,CAAC,2BAA2B,EAAE,KAAK,CAAC;IACrE,SAAS,EAAE,WAAW,CAAC,uBAAuB,EAAE,IAAI,CAAC;IACrD,aAAa,EAAE,WAAW,CAAC,2BAA2B,EAAE,GAAG,CAAC;IAC5D,kBAAkB,EAAE,WAAW,CAAC,gCAAgC,EAAE,GAAG,CAAC;IACtE,sBAAsB,EAAE,WAAW,CAAC,6BAA6B,EAAE,EAAE,CAAC;IACtE,oBAAoB,EAAE,YAAY,CAAC,6BAA6B,EAAE,IAAI,CAAC;CACxE,CAAC;AAKF,SAAgB,qBAAqB,CAAC,SAAoC;IACxE,OAAO;QACL,GAAG,iCAAyB;QAC5B,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAKD,SAAgB,cAAc,CAAC,MAAuB,EAAE,MAAc;IACpE,MAAM,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,IAAI,GAAG,EAAE,CAAC;IACtD,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACzB,OAAO;QACL,GAAG,MAAM;QACT,YAAY;KACb,CAAC;AACJ,CAAC;AAKD,SAAgB,YAAY,CAC1B,MAAuB,EACvB,MAAc,EACd,UAA+B;IAE/B,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,IAAI,IAAI,GAAG,EAAE,CAAC;IAClD,UAAU,CAAC,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IACnC,OAAO;QACL,GAAG,MAAM;QACT,UAAU;KACX,CAAC;AACJ,CAAC;AAOD,SAAS,WAAW,CAAC,GAAW,EAAE,YAAoB;IACpD,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC/B,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,YAAY,CAAC;IACtB,CAAC;IACD,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IACnC,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC;AAC/C,CAAC;AAKD,SAAS,YAAY,CAAC,GAAW,EAAE,YAAqB;IACtD,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC;IAC9C,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,YAAY,CAAC;IACtB,CAAC;IACD,OAAO,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,KAAK,CAAC;AAC9D,CAAC;AAKD,SAAgB,qBAAqB;IACnC,OAAO,YAAY,CAAC,oBAAoB,EAAE,IAAI,CAAC,CAAC;AAClD,CAAC"}
@@ -0,0 +1,46 @@
1
+ import type { Logger } from '../utils/logger';
2
+ export type RequestType = 'BTP_CONNECTION' | 'BTP_MESSAGE' | 'ILP_PACKET' | 'SETTLEMENT' | 'HTTP_API';
3
+ export interface RateLimitConfig {
4
+ maxRequestsPerSecond: number;
5
+ maxRequestsPerMinute: number;
6
+ burstSize: number;
7
+ blockDuration: number;
8
+ violationThreshold: number;
9
+ violationWindowSeconds: number;
10
+ peerLimits?: Map<string, PeerRateLimitConfig>;
11
+ trustedPeers?: Set<string>;
12
+ adaptiveRateLimiting?: boolean;
13
+ }
14
+ export interface PeerRateLimitConfig {
15
+ maxRequestsPerSecond: number;
16
+ burstSize: number;
17
+ }
18
+ export interface RateLimitMetrics {
19
+ recordAllowed(peerId: string, requestType: RequestType): void;
20
+ recordThrottled(peerId: string, requestType: RequestType): void;
21
+ recordBlocked(peerId: string, requestType: RequestType): void;
22
+ }
23
+ export declare class RateLimiter {
24
+ private config;
25
+ private logger;
26
+ private tokenBuckets;
27
+ private blockedPeers;
28
+ private violationCounter;
29
+ private metrics?;
30
+ private adaptiveLimits;
31
+ constructor(config: RateLimitConfig, logger: Logger, metrics?: RateLimitMetrics);
32
+ checkLimit(peerId: string, requestType: RequestType): Promise<boolean>;
33
+ private getOrCreateBucket;
34
+ private getBucketConfig;
35
+ private handleViolation;
36
+ private blockPeer;
37
+ private unblockPeer;
38
+ increaseAdaptiveLimit(peerId: string): void;
39
+ private decreaseAdaptiveLimit;
40
+ getBlockedPeers(): string[];
41
+ getRequestsPerSecond(peerId: string): number;
42
+ unblock(peerId: string): void;
43
+ private validateConfig;
44
+ destroy(): void;
45
+ }
46
+ //# sourceMappingURL=rate-limiter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rate-limiter.d.ts","sourceRoot":"","sources":["../../src/security/rate-limiter.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAO9C,MAAM,MAAM,WAAW,GACnB,gBAAgB,GAChB,aAAa,GACb,YAAY,GACZ,YAAY,GACZ,UAAU,CAAC;AAKf,MAAM,WAAW,eAAe;IAE9B,oBAAoB,EAAE,MAAM,CAAC;IAE7B,oBAAoB,EAAE,MAAM,CAAC;IAE7B,SAAS,EAAE,MAAM,CAAC;IAElB,aAAa,EAAE,MAAM,CAAC;IAEtB,kBAAkB,EAAE,MAAM,CAAC;IAE3B,sBAAsB,EAAE,MAAM,CAAC;IAE/B,UAAU,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;IAE9C,YAAY,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAE3B,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AAKD,MAAM,WAAW,mBAAmB;IAClC,oBAAoB,EAAE,MAAM,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;CACnB;AAKD,MAAM,WAAW,gBAAgB;IAC/B,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9D,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAChE,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;CAC/D;AAcD,qBAAa,WAAW;IAQpB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,MAAM;IARhB,OAAO,CAAC,YAAY,CAAkC;IACtD,OAAO,CAAC,YAAY,CAAkC;IACtD,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,OAAO,CAAC,CAAmB;IACnC,OAAO,CAAC,cAAc,CAA6B;gBAGzC,MAAM,EAAE,eAAe,EACvB,MAAM,EAAE,MAAM,EACtB,OAAO,CAAC,EAAE,gBAAgB;IAatB,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IA2B5E,OAAO,CAAC,iBAAiB;IAazB,OAAO,CAAC,eAAe;IA0BvB,OAAO,CAAC,eAAe;IA0BvB,OAAO,CAAC,SAAS;IAgCjB,OAAO,CAAC,WAAW;IAiBnB,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAe3C,OAAO,CAAC,qBAAqB;IAW7B,eAAe,IAAI,MAAM,EAAE;IAO3B,oBAAoB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAe5C,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAW7B,OAAO,CAAC,cAAc;IAwBtB,OAAO,IAAI,IAAI;CAQhB"}