@toon-protocol/connector 2.6.1 → 3.3.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 (477) hide show
  1. package/package.json +2 -2
  2. package/dist/btp/btp-claim-types.d.ts +0 -52
  3. package/dist/btp/btp-claim-types.d.ts.map +0 -1
  4. package/dist/btp/btp-claim-types.js +0 -209
  5. package/dist/btp/btp-claim-types.js.map +0 -1
  6. package/dist/btp/btp-client-manager.d.ts +0 -30
  7. package/dist/btp/btp-client-manager.d.ts.map +0 -1
  8. package/dist/btp/btp-client-manager.js +0 -153
  9. package/dist/btp/btp-client-manager.js.map +0 -1
  10. package/dist/btp/btp-client.d.ts +0 -58
  11. package/dist/btp/btp-client.d.ts.map +0 -1
  12. package/dist/btp/btp-client.js +0 -485
  13. package/dist/btp/btp-client.js.map +0 -1
  14. package/dist/btp/btp-message-parser.d.ts +0 -4
  15. package/dist/btp/btp-message-parser.d.ts.map +0 -1
  16. package/dist/btp/btp-message-parser.js +0 -211
  17. package/dist/btp/btp-message-parser.js.map +0 -1
  18. package/dist/btp/btp-server.d.ts +0 -33
  19. package/dist/btp/btp-server.d.ts.map +0 -1
  20. package/dist/btp/btp-server.js +0 -485
  21. package/dist/btp/btp-server.js.map +0 -1
  22. package/dist/btp/btp-types.d.ts +0 -43
  23. package/dist/btp/btp-types.d.ts.map +0 -1
  24. package/dist/btp/btp-types.js +0 -44
  25. package/dist/btp/btp-types.js.map +0 -1
  26. package/dist/btp/inbound-claim-validator.d.ts +0 -20
  27. package/dist/btp/inbound-claim-validator.d.ts.map +0 -1
  28. package/dist/btp/inbound-claim-validator.js +0 -150
  29. package/dist/btp/inbound-claim-validator.js.map +0 -1
  30. package/dist/cli/index.d.ts +0 -3
  31. package/dist/cli/index.d.ts.map +0 -1
  32. package/dist/cli/index.js +0 -175
  33. package/dist/cli/index.js.map +0 -1
  34. package/dist/cli/onboarding-wizard.d.ts +0 -7
  35. package/dist/cli/onboarding-wizard.d.ts.map +0 -1
  36. package/dist/cli/onboarding-wizard.js +0 -257
  37. package/dist/cli/onboarding-wizard.js.map +0 -1
  38. package/dist/cli/types.d.ts +0 -38
  39. package/dist/cli/types.d.ts.map +0 -1
  40. package/dist/cli/types.js +0 -3
  41. package/dist/cli/types.js.map +0 -1
  42. package/dist/config/config-loader.d.ts +0 -24
  43. package/dist/config/config-loader.d.ts.map +0 -1
  44. package/dist/config/config-loader.js +0 -436
  45. package/dist/config/config-loader.js.map +0 -1
  46. package/dist/config/environment-validator.d.ts +0 -4
  47. package/dist/config/environment-validator.d.ts.map +0 -1
  48. package/dist/config/environment-validator.js +0 -239
  49. package/dist/config/environment-validator.js.map +0 -1
  50. package/dist/config/index.d.ts +0 -3
  51. package/dist/config/index.d.ts.map +0 -1
  52. package/dist/config/index.js +0 -7
  53. package/dist/config/index.js.map +0 -1
  54. package/dist/config/key-manager-config.d.ts +0 -7
  55. package/dist/config/key-manager-config.d.ts.map +0 -1
  56. package/dist/config/key-manager-config.js +0 -209
  57. package/dist/config/key-manager-config.js.map +0 -1
  58. package/dist/config/topology-validator.d.ts +0 -14
  59. package/dist/config/topology-validator.d.ts.map +0 -1
  60. package/dist/config/topology-validator.js +0 -142
  61. package/dist/config/topology-validator.js.map +0 -1
  62. package/dist/config/types.d.ts +0 -223
  63. package/dist/config/types.d.ts.map +0 -1
  64. package/dist/config/types.js +0 -52
  65. package/dist/config/types.js.map +0 -1
  66. package/dist/core/connector-node.d.ts +0 -91
  67. package/dist/core/connector-node.d.ts.map +0 -1
  68. package/dist/core/connector-node.js +0 -1322
  69. package/dist/core/connector-node.js.map +0 -1
  70. package/dist/core/local-delivery-client.d.ts +0 -16
  71. package/dist/core/local-delivery-client.d.ts.map +0 -1
  72. package/dist/core/local-delivery-client.js +0 -160
  73. package/dist/core/local-delivery-client.js.map +0 -1
  74. package/dist/core/packet-handler.d.ts +0 -57
  75. package/dist/core/packet-handler.d.ts.map +0 -1
  76. package/dist/core/packet-handler.js +0 -655
  77. package/dist/core/packet-handler.js.map +0 -1
  78. package/dist/core/payment-handler.d.ts +0 -25
  79. package/dist/core/payment-handler.d.ts.map +0 -1
  80. package/dist/core/payment-handler.js +0 -104
  81. package/dist/core/payment-handler.js.map +0 -1
  82. package/dist/discovery/index.d.ts +0 -3
  83. package/dist/discovery/index.d.ts.map +0 -1
  84. package/dist/discovery/index.js +0 -6
  85. package/dist/discovery/index.js.map +0 -1
  86. package/dist/discovery/peer-discovery-service.d.ts +0 -29
  87. package/dist/discovery/peer-discovery-service.d.ts.map +0 -1
  88. package/dist/discovery/peer-discovery-service.js +0 -230
  89. package/dist/discovery/peer-discovery-service.js.map +0 -1
  90. package/dist/discovery/types.d.ts +0 -38
  91. package/dist/discovery/types.d.ts.map +0 -1
  92. package/dist/discovery/types.js +0 -3
  93. package/dist/discovery/types.js.map +0 -1
  94. package/dist/encoding/oer-parser.d.ts +0 -39
  95. package/dist/encoding/oer-parser.d.ts.map +0 -1
  96. package/dist/encoding/oer-parser.js +0 -154
  97. package/dist/encoding/oer-parser.js.map +0 -1
  98. package/dist/facilitator/index.d.ts +0 -2
  99. package/dist/facilitator/index.d.ts.map +0 -1
  100. package/dist/facilitator/index.js +0 -7
  101. package/dist/facilitator/index.js.map +0 -1
  102. package/dist/facilitator/spsp-client.d.ts +0 -18
  103. package/dist/facilitator/spsp-client.d.ts.map +0 -1
  104. package/dist/facilitator/spsp-client.js +0 -95
  105. package/dist/facilitator/spsp-client.js.map +0 -1
  106. package/dist/http/admin-api-inventory.d.ts +0 -29
  107. package/dist/http/admin-api-inventory.d.ts.map +0 -1
  108. package/dist/http/admin-api-inventory.js +0 -480
  109. package/dist/http/admin-api-inventory.js.map +0 -1
  110. package/dist/http/admin-api.d.ts +0 -182
  111. package/dist/http/admin-api.d.ts.map +0 -1
  112. package/dist/http/admin-api.js +0 -1324
  113. package/dist/http/admin-api.js.map +0 -1
  114. package/dist/http/admin-server.d.ts +0 -49
  115. package/dist/http/admin-server.d.ts.map +0 -1
  116. package/dist/http/admin-server.js +0 -160
  117. package/dist/http/admin-server.js.map +0 -1
  118. package/dist/http/health-server.d.ts +0 -22
  119. package/dist/http/health-server.d.ts.map +0 -1
  120. package/dist/http/health-server.js +0 -192
  121. package/dist/http/health-server.js.map +0 -1
  122. package/dist/http/ilp-send-handler.d.ts +0 -15
  123. package/dist/http/ilp-send-handler.d.ts.map +0 -1
  124. package/dist/http/ilp-send-handler.js +0 -149
  125. package/dist/http/ilp-send-handler.js.map +0 -1
  126. package/dist/http/types.d.ts +0 -43
  127. package/dist/http/types.d.ts.map +0 -1
  128. package/dist/http/types.js +0 -3
  129. package/dist/http/types.js.map +0 -1
  130. package/dist/index.d.ts +0 -2
  131. package/dist/index.d.ts.map +0 -1
  132. package/dist/index.js +0 -5
  133. package/dist/index.js.map +0 -1
  134. package/dist/lib.d.ts +0 -22
  135. package/dist/lib.d.ts.map +0 -1
  136. package/dist/lib.js +0 -39
  137. package/dist/lib.js.map +0 -1
  138. package/dist/main.d.ts +0 -4
  139. package/dist/main.d.ts.map +0 -1
  140. package/dist/main.js +0 -79
  141. package/dist/main.js.map +0 -1
  142. package/dist/observability/metrics-registry.d.ts +0 -39
  143. package/dist/observability/metrics-registry.d.ts.map +0 -1
  144. package/dist/observability/metrics-registry.js +0 -151
  145. package/dist/observability/metrics-registry.js.map +0 -1
  146. package/dist/routing/packet-processor.d.ts +0 -36
  147. package/dist/routing/packet-processor.d.ts.map +0 -1
  148. package/dist/routing/packet-processor.js +0 -112
  149. package/dist/routing/packet-processor.js.map +0 -1
  150. package/dist/routing/packet-worker.d.ts +0 -10
  151. package/dist/routing/packet-worker.d.ts.map +0 -1
  152. package/dist/routing/packet-worker.js +0 -34
  153. package/dist/routing/packet-worker.js.map +0 -1
  154. package/dist/routing/routing-table.d.ts +0 -15
  155. package/dist/routing/routing-table.d.ts.map +0 -1
  156. package/dist/routing/routing-table.js +0 -63
  157. package/dist/routing/routing-table.js.map +0 -1
  158. package/dist/routing/worker-pool.d.ts +0 -43
  159. package/dist/routing/worker-pool.d.ts.map +0 -1
  160. package/dist/routing/worker-pool.js +0 -228
  161. package/dist/routing/worker-pool.js.map +0 -1
  162. package/dist/security/alert-notifier.d.ts +0 -34
  163. package/dist/security/alert-notifier.d.ts.map +0 -1
  164. package/dist/security/alert-notifier.js +0 -136
  165. package/dist/security/alert-notifier.js.map +0 -1
  166. package/dist/security/audit-logger.d.ts +0 -34
  167. package/dist/security/audit-logger.d.ts.map +0 -1
  168. package/dist/security/audit-logger.js +0 -132
  169. package/dist/security/audit-logger.js.map +0 -1
  170. package/dist/security/backends/environment-backend.d.ts +0 -15
  171. package/dist/security/backends/environment-backend.d.ts.map +0 -1
  172. package/dist/security/backends/environment-backend.js +0 -56
  173. package/dist/security/backends/environment-backend.js.map +0 -1
  174. package/dist/security/fraud-detector.d.ts +0 -79
  175. package/dist/security/fraud-detector.d.ts.map +0 -1
  176. package/dist/security/fraud-detector.js +0 -147
  177. package/dist/security/fraud-detector.js.map +0 -1
  178. package/dist/security/key-manager-signer.d.ts +0 -15
  179. package/dist/security/key-manager-signer.d.ts.map +0 -1
  180. package/dist/security/key-manager-signer.js +0 -91
  181. package/dist/security/key-manager-signer.js.map +0 -1
  182. package/dist/security/key-manager.d.ts +0 -69
  183. package/dist/security/key-manager.d.ts.map +0 -1
  184. package/dist/security/key-manager.js +0 -79
  185. package/dist/security/key-manager.js.map +0 -1
  186. package/dist/security/key-rotation-manager.d.ts +0 -27
  187. package/dist/security/key-rotation-manager.d.ts.map +0 -1
  188. package/dist/security/key-rotation-manager.js +0 -142
  189. package/dist/security/key-rotation-manager.js.map +0 -1
  190. package/dist/security/rate-limit-config.d.ts +0 -7
  191. package/dist/security/rate-limit-config.d.ts.map +0 -1
  192. package/dist/security/rate-limit-config.js +0 -57
  193. package/dist/security/rate-limit-config.js.map +0 -1
  194. package/dist/security/rate-limiter.d.ts +0 -46
  195. package/dist/security/rate-limiter.d.ts.map +0 -1
  196. package/dist/security/rate-limiter.js +0 -170
  197. package/dist/security/rate-limiter.js.map +0 -1
  198. package/dist/security/reputation-tracker.d.ts +0 -30
  199. package/dist/security/reputation-tracker.d.ts.map +0 -1
  200. package/dist/security/reputation-tracker.js +0 -111
  201. package/dist/security/reputation-tracker.js.map +0 -1
  202. package/dist/security/rules/balance-manipulation-rule.d.ts +0 -23
  203. package/dist/security/rules/balance-manipulation-rule.d.ts.map +0 -1
  204. package/dist/security/rules/balance-manipulation-rule.js +0 -70
  205. package/dist/security/rules/balance-manipulation-rule.js.map +0 -1
  206. package/dist/security/rules/double-spend-detection-rule.d.ts +0 -23
  207. package/dist/security/rules/double-spend-detection-rule.d.ts.map +0 -1
  208. package/dist/security/rules/double-spend-detection-rule.js +0 -61
  209. package/dist/security/rules/double-spend-detection-rule.js.map +0 -1
  210. package/dist/security/rules/rapid-channel-closure-rule.d.ts +0 -16
  211. package/dist/security/rules/rapid-channel-closure-rule.d.ts.map +0 -1
  212. package/dist/security/rules/rapid-channel-closure-rule.js +0 -57
  213. package/dist/security/rules/rapid-channel-closure-rule.js.map +0 -1
  214. package/dist/security/rules/sudden-traffic-spike-rule.d.ts +0 -18
  215. package/dist/security/rules/sudden-traffic-spike-rule.d.ts.map +0 -1
  216. package/dist/security/rules/sudden-traffic-spike-rule.js +0 -92
  217. package/dist/security/rules/sudden-traffic-spike-rule.js.map +0 -1
  218. package/dist/security/rules/unusual-settlement-amount-rule.d.ts +0 -12
  219. package/dist/security/rules/unusual-settlement-amount-rule.d.ts.map +0 -1
  220. package/dist/security/rules/unusual-settlement-amount-rule.js +0 -33
  221. package/dist/security/rules/unusual-settlement-amount-rule.js.map +0 -1
  222. package/dist/security/token-bucket.d.ts +0 -16
  223. package/dist/security/token-bucket.d.ts.map +0 -1
  224. package/dist/security/token-bucket.js +0 -49
  225. package/dist/security/token-bucket.js.map +0 -1
  226. package/dist/security/violation-counter.d.ts +0 -11
  227. package/dist/security/violation-counter.d.ts.map +0 -1
  228. package/dist/security/violation-counter.js +0 -61
  229. package/dist/security/violation-counter.js.map +0 -1
  230. package/dist/settlement/account-id-generator.d.ts +0 -4
  231. package/dist/settlement/account-id-generator.d.ts.map +0 -1
  232. package/dist/settlement/account-id-generator.js +0 -38
  233. package/dist/settlement/account-id-generator.js.map +0 -1
  234. package/dist/settlement/account-manager.d.ts +0 -51
  235. package/dist/settlement/account-manager.d.ts.map +0 -1
  236. package/dist/settlement/account-manager.js +0 -459
  237. package/dist/settlement/account-manager.js.map +0 -1
  238. package/dist/settlement/account-metadata.d.ts +0 -11
  239. package/dist/settlement/account-metadata.d.ts.map +0 -1
  240. package/dist/settlement/account-metadata.js +0 -40
  241. package/dist/settlement/account-metadata.js.map +0 -1
  242. package/dist/settlement/channel-manager.d.ts +0 -67
  243. package/dist/settlement/channel-manager.d.ts.map +0 -1
  244. package/dist/settlement/channel-manager.js +0 -226
  245. package/dist/settlement/channel-manager.js.map +0 -1
  246. package/dist/settlement/claim-receiver-db-schema.d.ts +0 -4
  247. package/dist/settlement/claim-receiver-db-schema.d.ts.map +0 -1
  248. package/dist/settlement/claim-receiver-db-schema.js +0 -25
  249. package/dist/settlement/claim-receiver-db-schema.js.map +0 -1
  250. package/dist/settlement/claim-receiver.d.ts +0 -67
  251. package/dist/settlement/claim-receiver.d.ts.map +0 -1
  252. package/dist/settlement/claim-receiver.js +0 -707
  253. package/dist/settlement/claim-receiver.js.map +0 -1
  254. package/dist/settlement/claim-redemption-service.d.ts +0 -39
  255. package/dist/settlement/claim-redemption-service.d.ts.map +0 -1
  256. package/dist/settlement/claim-redemption-service.js +0 -189
  257. package/dist/settlement/claim-redemption-service.js.map +0 -1
  258. package/dist/settlement/claim-sender-db-schema.d.ts +0 -3
  259. package/dist/settlement/claim-sender-db-schema.d.ts.map +0 -1
  260. package/dist/settlement/claim-sender-db-schema.js +0 -18
  261. package/dist/settlement/claim-sender-db-schema.js.map +0 -1
  262. package/dist/settlement/claim-sender.d.ts +0 -24
  263. package/dist/settlement/claim-sender.d.ts.map +0 -1
  264. package/dist/settlement/claim-sender.js +0 -146
  265. package/dist/settlement/claim-sender.js.map +0 -1
  266. package/dist/settlement/eip712-helper.d.ts +0 -13
  267. package/dist/settlement/eip712-helper.d.ts.map +0 -1
  268. package/dist/settlement/eip712-helper.js +0 -24
  269. package/dist/settlement/eip712-helper.js.map +0 -1
  270. package/dist/settlement/in-memory-ledger-client.d.ts +0 -40
  271. package/dist/settlement/in-memory-ledger-client.d.ts.map +0 -1
  272. package/dist/settlement/in-memory-ledger-client.js +0 -177
  273. package/dist/settlement/in-memory-ledger-client.js.map +0 -1
  274. package/dist/settlement/ledger-client.d.ts +0 -22
  275. package/dist/settlement/ledger-client.d.ts.map +0 -1
  276. package/dist/settlement/ledger-client.js +0 -3
  277. package/dist/settlement/ledger-client.js.map +0 -1
  278. package/dist/settlement/metrics-collector.d.ts +0 -29
  279. package/dist/settlement/metrics-collector.d.ts.map +0 -1
  280. package/dist/settlement/metrics-collector.js +0 -81
  281. package/dist/settlement/metrics-collector.js.map +0 -1
  282. package/dist/settlement/mina-payment-channel-sdk.d.ts +0 -73
  283. package/dist/settlement/mina-payment-channel-sdk.d.ts.map +0 -1
  284. package/dist/settlement/mina-payment-channel-sdk.js +0 -538
  285. package/dist/settlement/mina-payment-channel-sdk.js.map +0 -1
  286. package/dist/settlement/payment-channel-sdk.d.ts +0 -59
  287. package/dist/settlement/payment-channel-sdk.d.ts.map +0 -1
  288. package/dist/settlement/payment-channel-sdk.js +0 -677
  289. package/dist/settlement/payment-channel-sdk.js.map +0 -1
  290. package/dist/settlement/per-packet-claim-service.d.ts +0 -39
  291. package/dist/settlement/per-packet-claim-service.d.ts.map +0 -1
  292. package/dist/settlement/per-packet-claim-service.js +0 -342
  293. package/dist/settlement/per-packet-claim-service.js.map +0 -1
  294. package/dist/settlement/privacy/index.d.ts +0 -3
  295. package/dist/settlement/privacy/index.d.ts.map +0 -1
  296. package/dist/settlement/privacy/index.js +0 -11
  297. package/dist/settlement/privacy/index.js.map +0 -1
  298. package/dist/settlement/privacy/nip59-claim-wrapper.d.ts +0 -60
  299. package/dist/settlement/privacy/nip59-claim-wrapper.d.ts.map +0 -1
  300. package/dist/settlement/privacy/nip59-claim-wrapper.js +0 -361
  301. package/dist/settlement/privacy/nip59-claim-wrapper.js.map +0 -1
  302. package/dist/settlement/provider/chain-provider-registry.d.ts +0 -20
  303. package/dist/settlement/provider/chain-provider-registry.d.ts.map +0 -1
  304. package/dist/settlement/provider/chain-provider-registry.js +0 -53
  305. package/dist/settlement/provider/chain-provider-registry.js.map +0 -1
  306. package/dist/settlement/provider/evm-payment-channel-provider.d.ts +0 -31
  307. package/dist/settlement/provider/evm-payment-channel-provider.d.ts.map +0 -1
  308. package/dist/settlement/provider/evm-payment-channel-provider.js +0 -207
  309. package/dist/settlement/provider/evm-payment-channel-provider.js.map +0 -1
  310. package/dist/settlement/provider/index.d.ts +0 -6
  311. package/dist/settlement/provider/index.d.ts.map +0 -1
  312. package/dist/settlement/provider/index.js +0 -16
  313. package/dist/settlement/provider/index.js.map +0 -1
  314. package/dist/settlement/provider/mina-payment-channel-provider.d.ts +0 -43
  315. package/dist/settlement/provider/mina-payment-channel-provider.d.ts.map +0 -1
  316. package/dist/settlement/provider/mina-payment-channel-provider.js +0 -330
  317. package/dist/settlement/provider/mina-payment-channel-provider.js.map +0 -1
  318. package/dist/settlement/provider/payment-channel-provider.d.ts +0 -88
  319. package/dist/settlement/provider/payment-channel-provider.d.ts.map +0 -1
  320. package/dist/settlement/provider/payment-channel-provider.js +0 -3
  321. package/dist/settlement/provider/payment-channel-provider.js.map +0 -1
  322. package/dist/settlement/provider/solana-payment-channel-provider.d.ts +0 -38
  323. package/dist/settlement/provider/solana-payment-channel-provider.d.ts.map +0 -1
  324. package/dist/settlement/provider/solana-payment-channel-provider.js +0 -262
  325. package/dist/settlement/provider/solana-payment-channel-provider.js.map +0 -1
  326. package/dist/settlement/sent-claims-queries.d.ts +0 -23
  327. package/dist/settlement/sent-claims-queries.d.ts.map +0 -1
  328. package/dist/settlement/sent-claims-queries.js +0 -134
  329. package/dist/settlement/sent-claims-queries.js.map +0 -1
  330. package/dist/settlement/settlement-api.d.ts +0 -37
  331. package/dist/settlement/settlement-api.d.ts.map +0 -1
  332. package/dist/settlement/settlement-api.js +0 -172
  333. package/dist/settlement/settlement-api.js.map +0 -1
  334. package/dist/settlement/settlement-coordinator.d.ts +0 -47
  335. package/dist/settlement/settlement-coordinator.d.ts.map +0 -1
  336. package/dist/settlement/settlement-coordinator.js +0 -166
  337. package/dist/settlement/settlement-coordinator.js.map +0 -1
  338. package/dist/settlement/settlement-executor.d.ts +0 -51
  339. package/dist/settlement/settlement-executor.d.ts.map +0 -1
  340. package/dist/settlement/settlement-executor.js +0 -265
  341. package/dist/settlement/settlement-executor.js.map +0 -1
  342. package/dist/settlement/settlement-monitor.d.ts +0 -30
  343. package/dist/settlement/settlement-monitor.d.ts.map +0 -1
  344. package/dist/settlement/settlement-monitor.js +0 -141
  345. package/dist/settlement/settlement-monitor.js.map +0 -1
  346. package/dist/settlement/solana-payment-channel-sdk.d.ts +0 -79
  347. package/dist/settlement/solana-payment-channel-sdk.d.ts.map +0 -1
  348. package/dist/settlement/solana-payment-channel-sdk.js +0 -636
  349. package/dist/settlement/solana-payment-channel-sdk.js.map +0 -1
  350. package/dist/settlement/tigerbeetle-batch-writer.d.ts +0 -58
  351. package/dist/settlement/tigerbeetle-batch-writer.d.ts.map +0 -1
  352. package/dist/settlement/tigerbeetle-batch-writer.js +0 -162
  353. package/dist/settlement/tigerbeetle-batch-writer.js.map +0 -1
  354. package/dist/settlement/tigerbeetle-client.d.ts +0 -40
  355. package/dist/settlement/tigerbeetle-client.d.ts.map +0 -1
  356. package/dist/settlement/tigerbeetle-client.js +0 -279
  357. package/dist/settlement/tigerbeetle-client.js.map +0 -1
  358. package/dist/settlement/tigerbeetle-errors.d.ts +0 -23
  359. package/dist/settlement/tigerbeetle-errors.d.ts.map +0 -1
  360. package/dist/settlement/tigerbeetle-errors.js +0 -58
  361. package/dist/settlement/tigerbeetle-errors.js.map +0 -1
  362. package/dist/settlement/types.d.ts +0 -64
  363. package/dist/settlement/types.d.ts.map +0 -1
  364. package/dist/settlement/types.js +0 -42
  365. package/dist/settlement/types.js.map +0 -1
  366. package/dist/settlement/unified-settlement-executor.d.ts +0 -34
  367. package/dist/settlement/unified-settlement-executor.d.ts.map +0 -1
  368. package/dist/settlement/unified-settlement-executor.js +0 -145
  369. package/dist/settlement/unified-settlement-executor.js.map +0 -1
  370. package/dist/test-utils/index.d.ts +0 -3
  371. package/dist/test-utils/index.d.ts.map +0 -1
  372. package/dist/test-utils/index.js +0 -15
  373. package/dist/test-utils/index.js.map +0 -1
  374. package/dist/test-utils/isolated-test-env.d.ts +0 -31
  375. package/dist/test-utils/isolated-test-env.d.ts.map +0 -1
  376. package/dist/test-utils/isolated-test-env.js +0 -127
  377. package/dist/test-utils/isolated-test-env.js.map +0 -1
  378. package/dist/test-utils/mock-factories-patch.d.ts +0 -2
  379. package/dist/test-utils/mock-factories-patch.d.ts.map +0 -1
  380. package/dist/test-utils/mock-factories-patch.js +0 -3
  381. package/dist/test-utils/mock-factories-patch.js.map +0 -1
  382. package/dist/test-utils/mock-factories.d.ts +0 -22
  383. package/dist/test-utils/mock-factories.d.ts.map +0 -1
  384. package/dist/test-utils/mock-factories.js +0 -56
  385. package/dist/test-utils/mock-factories.js.map +0 -1
  386. package/dist/transport/direct-transport-provider.d.ts +0 -12
  387. package/dist/transport/direct-transport-provider.d.ts.map +0 -1
  388. package/dist/transport/direct-transport-provider.js +0 -27
  389. package/dist/transport/direct-transport-provider.js.map +0 -1
  390. package/dist/transport/index.d.ts +0 -7
  391. package/dist/transport/index.d.ts.map +0 -1
  392. package/dist/transport/index.js +0 -16
  393. package/dist/transport/index.js.map +0 -1
  394. package/dist/transport/managed-anon-client.d.ts +0 -47
  395. package/dist/transport/managed-anon-client.d.ts.map +0 -1
  396. package/dist/transport/managed-anon-client.js +0 -265
  397. package/dist/transport/managed-anon-client.js.map +0 -1
  398. package/dist/transport/probe-tcp-port.d.ts +0 -3
  399. package/dist/transport/probe-tcp-port.d.ts.map +0 -1
  400. package/dist/transport/probe-tcp-port.js +0 -59
  401. package/dist/transport/probe-tcp-port.js.map +0 -1
  402. package/dist/transport/socks-transport-provider.d.ts +0 -29
  403. package/dist/transport/socks-transport-provider.d.ts.map +0 -1
  404. package/dist/transport/socks-transport-provider.js +0 -136
  405. package/dist/transport/socks-transport-provider.js.map +0 -1
  406. package/dist/transport/socks-url.d.ts +0 -6
  407. package/dist/transport/socks-url.d.ts.map +0 -1
  408. package/dist/transport/socks-url.js +0 -29
  409. package/dist/transport/socks-url.js.map +0 -1
  410. package/dist/transport/transport-provider.d.ts +0 -9
  411. package/dist/transport/transport-provider.d.ts.map +0 -1
  412. package/dist/transport/transport-provider.js +0 -3
  413. package/dist/transport/transport-provider.js.map +0 -1
  414. package/dist/utils/connection-pool.d.ts +0 -42
  415. package/dist/utils/connection-pool.d.ts.map +0 -1
  416. package/dist/utils/connection-pool.js +0 -209
  417. package/dist/utils/connection-pool.js.map +0 -1
  418. package/dist/utils/evm-rpc-connection-pool.d.ts +0 -8
  419. package/dist/utils/evm-rpc-connection-pool.d.ts.map +0 -1
  420. package/dist/utils/evm-rpc-connection-pool.js +0 -40
  421. package/dist/utils/evm-rpc-connection-pool.js.map +0 -1
  422. package/dist/utils/logger.d.ts +0 -6
  423. package/dist/utils/logger.d.ts.map +0 -1
  424. package/dist/utils/logger.js +0 -58
  425. package/dist/utils/logger.js.map +0 -1
  426. package/dist/utils/optional-require.d.ts +0 -2
  427. package/dist/utils/optional-require.d.ts.map +0 -1
  428. package/dist/utils/optional-require.js +0 -54
  429. package/dist/utils/optional-require.js.map +0 -1
  430. package/dist/utils/redact.d.ts +0 -3
  431. package/dist/utils/redact.d.ts.map +0 -1
  432. package/dist/utils/redact.js +0 -21
  433. package/dist/utils/redact.js.map +0 -1
  434. package/dist/wallet/audit-logger.d.ts +0 -22
  435. package/dist/wallet/audit-logger.d.ts.map +0 -1
  436. package/dist/wallet/audit-logger.js +0 -120
  437. package/dist/wallet/audit-logger.js.map +0 -1
  438. package/dist/wallet/fraud-detector-interface.d.ts +0 -14
  439. package/dist/wallet/fraud-detector-interface.d.ts.map +0 -1
  440. package/dist/wallet/fraud-detector-interface.js +0 -3
  441. package/dist/wallet/fraud-detector-interface.js.map +0 -1
  442. package/dist/wallet/key-manager.d.ts +0 -6
  443. package/dist/wallet/key-manager.d.ts.map +0 -1
  444. package/dist/wallet/key-manager.js +0 -3
  445. package/dist/wallet/key-manager.js.map +0 -1
  446. package/dist/wallet/placeholder-fraud-detector.d.ts +0 -10
  447. package/dist/wallet/placeholder-fraud-detector.d.ts.map +0 -1
  448. package/dist/wallet/placeholder-fraud-detector.js +0 -10
  449. package/dist/wallet/placeholder-fraud-detector.js.map +0 -1
  450. package/dist/wallet/rate-limiter.d.ts +0 -26
  451. package/dist/wallet/rate-limiter.d.ts.map +0 -1
  452. package/dist/wallet/rate-limiter.js +0 -114
  453. package/dist/wallet/rate-limiter.js.map +0 -1
  454. package/dist/wallet/suspicious-activity-detector.d.ts +0 -25
  455. package/dist/wallet/suspicious-activity-detector.d.ts.map +0 -1
  456. package/dist/wallet/suspicious-activity-detector.js +0 -97
  457. package/dist/wallet/suspicious-activity-detector.js.map +0 -1
  458. package/dist/wallet/treasury-wallet.d.ts +0 -20
  459. package/dist/wallet/treasury-wallet.d.ts.map +0 -1
  460. package/dist/wallet/treasury-wallet.js +0 -151
  461. package/dist/wallet/treasury-wallet.js.map +0 -1
  462. package/dist/wallet/wallet-authentication.d.ts +0 -31
  463. package/dist/wallet/wallet-authentication.d.ts.map +0 -1
  464. package/dist/wallet/wallet-authentication.js +0 -102
  465. package/dist/wallet/wallet-authentication.js.map +0 -1
  466. package/dist/wallet/wallet-db-schema.d.ts +0 -11
  467. package/dist/wallet/wallet-db-schema.d.ts.map +0 -1
  468. package/dist/wallet/wallet-db-schema.js +0 -79
  469. package/dist/wallet/wallet-db-schema.js.map +0 -1
  470. package/dist/wallet/wallet-security.d.ts +0 -58
  471. package/dist/wallet/wallet-security.d.ts.map +0 -1
  472. package/dist/wallet/wallet-security.js +0 -148
  473. package/dist/wallet/wallet-security.js.map +0 -1
  474. package/dist/wallet/wallet-seed-manager.d.ts +0 -65
  475. package/dist/wallet/wallet-seed-manager.d.ts.map +0 -1
  476. package/dist/wallet/wallet-seed-manager.js +0 -418
  477. package/dist/wallet/wallet-seed-manager.js.map +0 -1
@@ -1,170 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RateLimiter = void 0;
4
- const token_bucket_1 = require("./token-bucket");
5
- const violation_counter_1 = require("./violation-counter");
6
- class RateLimiter {
7
- config;
8
- logger;
9
- tokenBuckets = new Map();
10
- blockedPeers = new Map();
11
- violationCounter;
12
- metrics;
13
- adaptiveLimits = new Map();
14
- constructor(config, logger, metrics) {
15
- this.config = config;
16
- this.logger = logger;
17
- this.validateConfig(config);
18
- this.violationCounter = new violation_counter_1.ViolationCounter(config.violationWindowSeconds);
19
- this.metrics = metrics;
20
- }
21
- async checkLimit(peerId, requestType) {
22
- if (this.blockedPeers.has(peerId)) {
23
- this.logger.debug({ peerId, requestType }, 'Request blocked by circuit breaker');
24
- this.metrics?.recordBlocked(peerId, requestType);
25
- return false;
26
- }
27
- const bucket = this.getOrCreateBucket(peerId);
28
- if (bucket.tryConsume()) {
29
- this.metrics?.recordAllowed(peerId, requestType);
30
- return true;
31
- }
32
- this.logger.warn({ peerId, requestType }, 'Request rate limited');
33
- this.metrics?.recordThrottled(peerId, requestType);
34
- this.handleViolation(peerId, requestType);
35
- return false;
36
- }
37
- getOrCreateBucket(peerId) {
38
- let bucket = this.tokenBuckets.get(peerId);
39
- if (!bucket) {
40
- const { capacity, refillRate } = this.getBucketConfig(peerId);
41
- bucket = new token_bucket_1.TokenBucket(capacity, refillRate);
42
- this.tokenBuckets.set(peerId, bucket);
43
- }
44
- return bucket;
45
- }
46
- getBucketConfig(peerId) {
47
- const peerConfig = this.config.peerLimits?.get(peerId);
48
- if (peerConfig) {
49
- return {
50
- capacity: peerConfig.burstSize,
51
- refillRate: peerConfig.maxRequestsPerSecond,
52
- };
53
- }
54
- let refillRate = this.config.maxRequestsPerSecond;
55
- if (this.config.adaptiveRateLimiting) {
56
- const multiplier = this.adaptiveLimits.get(peerId) ?? 1.0;
57
- refillRate = refillRate * multiplier;
58
- }
59
- return {
60
- capacity: this.config.burstSize,
61
- refillRate,
62
- };
63
- }
64
- handleViolation(peerId, requestType) {
65
- const violations = this.violationCounter.increment(peerId);
66
- if (this.config.adaptiveRateLimiting && !this.config.trustedPeers?.has(peerId)) {
67
- this.decreaseAdaptiveLimit(peerId);
68
- }
69
- if (violations >= this.config.violationThreshold) {
70
- if (this.config.trustedPeers?.has(peerId)) {
71
- this.logger.info({ peerId, violations, requestType }, 'Trusted peer exceeded violations but not blocked');
72
- return;
73
- }
74
- this.blockPeer(peerId, this.config.blockDuration);
75
- }
76
- }
77
- blockPeer(peerId, durationSeconds) {
78
- if (this.blockedPeers.has(peerId)) {
79
- return;
80
- }
81
- const violations = this.violationCounter.getCount(peerId);
82
- this.logger.warn({
83
- peerId,
84
- violations,
85
- blockDuration: durationSeconds,
86
- }, 'Peer blocked due to sustained rate limit violations');
87
- const unblockTimeout = setTimeout(() => {
88
- this.unblockPeer(peerId);
89
- }, durationSeconds * 1000);
90
- this.blockedPeers.set(peerId, {
91
- peerId,
92
- blockedAt: Date.now(),
93
- unblockTimeout,
94
- });
95
- }
96
- unblockPeer(peerId) {
97
- const blocked = this.blockedPeers.get(peerId);
98
- if (!blocked) {
99
- return;
100
- }
101
- this.logger.info({ peerId }, 'Peer unblocked');
102
- this.blockedPeers.delete(peerId);
103
- this.violationCounter.reset(peerId);
104
- this.adaptiveLimits.delete(peerId);
105
- }
106
- increaseAdaptiveLimit(peerId) {
107
- if (!this.config.adaptiveRateLimiting) {
108
- return;
109
- }
110
- const current = this.adaptiveLimits.get(peerId) ?? 1.0;
111
- const newLimit = Math.min(5.0, current * 1.1);
112
- this.adaptiveLimits.set(peerId, newLimit);
113
- this.logger.debug({ peerId, newMultiplier: newLimit }, 'Increased adaptive rate limit');
114
- }
115
- decreaseAdaptiveLimit(peerId) {
116
- const current = this.adaptiveLimits.get(peerId) ?? 1.0;
117
- const newLimit = Math.max(0.1, current * 0.9);
118
- this.adaptiveLimits.set(peerId, newLimit);
119
- this.logger.debug({ peerId, newMultiplier: newLimit }, 'Decreased adaptive rate limit');
120
- }
121
- getBlockedPeers() {
122
- return Array.from(this.blockedPeers.keys());
123
- }
124
- getRequestsPerSecond(peerId) {
125
- const bucket = this.tokenBuckets.get(peerId);
126
- if (!bucket) {
127
- return 0;
128
- }
129
- const available = bucket.getAvailableTokens();
130
- const { capacity, refillRate } = this.getBucketConfig(peerId);
131
- return Math.max(0, refillRate - (capacity - available));
132
- }
133
- unblock(peerId) {
134
- const blocked = this.blockedPeers.get(peerId);
135
- if (blocked) {
136
- clearTimeout(blocked.unblockTimeout);
137
- this.unblockPeer(peerId);
138
- }
139
- }
140
- validateConfig(config) {
141
- if (config.maxRequestsPerSecond <= 0) {
142
- throw new Error('maxRequestsPerSecond must be positive');
143
- }
144
- if (config.maxRequestsPerMinute <= 0) {
145
- throw new Error('maxRequestsPerMinute must be positive');
146
- }
147
- if (config.burstSize <= 0) {
148
- throw new Error('burstSize must be positive');
149
- }
150
- if (config.blockDuration <= 0) {
151
- throw new Error('blockDuration must be positive');
152
- }
153
- if (config.violationThreshold <= 0) {
154
- throw new Error('violationThreshold must be positive');
155
- }
156
- if (config.violationWindowSeconds <= 0) {
157
- throw new Error('violationWindowSeconds must be positive');
158
- }
159
- }
160
- destroy() {
161
- for (const blocked of this.blockedPeers.values()) {
162
- clearTimeout(blocked.unblockTimeout);
163
- }
164
- this.blockedPeers.clear();
165
- this.tokenBuckets.clear();
166
- this.adaptiveLimits.clear();
167
- }
168
- }
169
- exports.RateLimiter = RateLimiter;
170
- //# sourceMappingURL=rate-limiter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"rate-limiter.js","sourceRoot":"","sources":["../../src/security/rate-limiter.ts"],"names":[],"mappings":"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"}
@@ -1,30 +0,0 @@
1
- import { Logger } from 'pino';
2
- import { PeerReputationScore } from './fraud-detector';
3
- export interface ReputationTrackerConfig {
4
- autoPauseThreshold: number;
5
- decayRate: number;
6
- maxScore: number;
7
- }
8
- export interface FraudDetectionEvent {
9
- ruleName: string;
10
- severity: 'low' | 'medium' | 'high' | 'critical';
11
- peerId: string;
12
- timestamp: number;
13
- details?: {
14
- [key: string]: unknown;
15
- };
16
- }
17
- export declare class ReputationTracker {
18
- private readonly logger;
19
- private readonly config;
20
- private readonly reputationScores;
21
- constructor(logger: Logger, config: ReputationTrackerConfig);
22
- updateReputationScore(event: FraudDetectionEvent): Promise<void>;
23
- applyScoreDecay(peerId: string, currentTime: number): void;
24
- applyScoreDecayAll(currentTime: number): void;
25
- getReputationScore(peerId: string): PeerReputationScore | undefined;
26
- getAllReputationScores(): Map<string, PeerReputationScore>;
27
- shouldAutoPause(peerId: string): boolean;
28
- clearAll(): void;
29
- }
30
- //# sourceMappingURL=reputation-tracker.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"reputation-tracker.d.ts","sourceRoot":"","sources":["../../src/security/reputation-tracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAevD,MAAM,WAAW,uBAAuB;IAKtC,kBAAkB,EAAE,MAAM,CAAC;IAK3B,SAAS,EAAE,MAAM,CAAC;IAKlB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAKD,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;IACjD,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE;QACR,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;KACxB,CAAC;CACH;AAUD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA0B;IACjD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAmC;gBAExD,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,uBAAuB;IAe9C,qBAAqB,CAAC,KAAK,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC;IAuDtE,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,IAAI;IAmC1D,kBAAkB,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAS7C,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,mBAAmB,GAAG,SAAS;IAOnE,sBAAsB,IAAI,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC;IAO1D,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAYxC,QAAQ,IAAI,IAAI;CAGxB"}
@@ -1,111 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ReputationTracker = void 0;
4
- const SEVERITY_PENALTIES = {
5
- low: 1,
6
- medium: 5,
7
- high: 10,
8
- critical: 25,
9
- };
10
- class ReputationTracker {
11
- logger;
12
- config;
13
- reputationScores;
14
- constructor(logger, config) {
15
- this.logger = logger.child({ component: 'ReputationTracker' });
16
- this.config = config;
17
- this.reputationScores = new Map();
18
- this.logger.info('ReputationTracker initialized', {
19
- autoPauseThreshold: config.autoPauseThreshold,
20
- decayRate: config.decayRate,
21
- maxScore: config.maxScore,
22
- });
23
- }
24
- async updateReputationScore(event) {
25
- try {
26
- const { peerId, ruleName, severity, timestamp } = event;
27
- let score = this.reputationScores.get(peerId);
28
- if (!score) {
29
- score = {
30
- peerId,
31
- score: this.config.maxScore,
32
- lastUpdated: timestamp,
33
- violations: [],
34
- };
35
- this.reputationScores.set(peerId, score);
36
- }
37
- const penalty = SEVERITY_PENALTIES[severity];
38
- const newScore = Math.max(0, score.score - penalty);
39
- score.violations.push({
40
- timestamp,
41
- ruleViolated: ruleName,
42
- severity,
43
- penaltyApplied: penalty,
44
- });
45
- score.score = newScore;
46
- score.lastUpdated = timestamp;
47
- this.logger.info('Reputation score updated', {
48
- peerId,
49
- previousScore: score.score + penalty,
50
- newScore,
51
- penalty,
52
- severity,
53
- ruleName,
54
- violationCount: score.violations.length,
55
- });
56
- }
57
- catch (error) {
58
- this.logger.error('Failed to update reputation score', {
59
- peerId: event.peerId,
60
- error: error instanceof Error ? error.message : String(error),
61
- });
62
- }
63
- }
64
- applyScoreDecay(peerId, currentTime) {
65
- const score = this.reputationScores.get(peerId);
66
- if (!score) {
67
- return;
68
- }
69
- const msPerDay = 24 * 60 * 60 * 1000;
70
- const daysElapsed = Math.floor((currentTime - score.lastUpdated) / msPerDay);
71
- if (daysElapsed === 0) {
72
- return;
73
- }
74
- const decayAmount = daysElapsed * this.config.decayRate;
75
- const newScore = Math.min(this.config.maxScore, score.score + decayAmount);
76
- if (newScore !== score.score) {
77
- this.logger.debug('Score decay applied', {
78
- peerId,
79
- previousScore: score.score,
80
- newScore,
81
- daysElapsed,
82
- decayAmount,
83
- });
84
- score.score = newScore;
85
- score.lastUpdated = currentTime;
86
- }
87
- }
88
- applyScoreDecayAll(currentTime) {
89
- for (const [peerId] of Array.from(this.reputationScores)) {
90
- this.applyScoreDecay(peerId, currentTime);
91
- }
92
- }
93
- getReputationScore(peerId) {
94
- return this.reputationScores.get(peerId);
95
- }
96
- getAllReputationScores() {
97
- return new Map(this.reputationScores);
98
- }
99
- shouldAutoPause(peerId) {
100
- const score = this.reputationScores.get(peerId);
101
- if (!score) {
102
- return false;
103
- }
104
- return score.score < this.config.autoPauseThreshold;
105
- }
106
- clearAll() {
107
- this.reputationScores.clear();
108
- }
109
- }
110
- exports.ReputationTracker = ReputationTracker;
111
- //# sourceMappingURL=reputation-tracker.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"reputation-tracker.js","sourceRoot":"","sources":["../../src/security/reputation-tracker.ts"],"names":[],"mappings":"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"}
@@ -1,23 +0,0 @@
1
- import { FraudRule, FraudDetection, SettlementEvent, PacketEvent, ChannelEvent } from '../fraud-detector';
2
- export interface BalanceEvent extends SettlementEvent {
3
- previousBalance?: number;
4
- newBalance?: number;
5
- }
6
- interface BalanceHistory {
7
- peerId: string;
8
- balances: {
9
- balance: number;
10
- timestamp: number;
11
- }[];
12
- }
13
- export declare class BalanceManipulationRule implements FraudRule {
14
- readonly name = "BalanceManipulationRule";
15
- readonly severity: "critical";
16
- private readonly balanceHistory;
17
- constructor();
18
- check(event: SettlementEvent | PacketEvent | ChannelEvent): Promise<FraudDetection>;
19
- clearHistory(): void;
20
- getBalanceHistory(peerId: string): BalanceHistory | undefined;
21
- }
22
- export {};
23
- //# sourceMappingURL=balance-manipulation-rule.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"balance-manipulation-rule.d.ts","sourceRoot":"","sources":["../../../src/security/rules/balance-manipulation-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,cAAc,EACd,eAAe,EACf,WAAW,EACX,YAAY,EACb,MAAM,mBAAmB,CAAC;AAK3B,MAAM,WAAW,YAAa,SAAQ,eAAe;IACnD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAKD,UAAU,cAAc;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE;QACR,OAAO,EAAE,MAAM,CAAC;QAChB,SAAS,EAAE,MAAM,CAAC;KACnB,EAAE,CAAC;CACL;AASD,qBAAa,uBAAwB,YAAW,SAAS;IACvD,SAAgB,IAAI,6BAA6B;IACjD,SAAgB,QAAQ,EAAG,UAAU,CAAU;IAE/C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA8B;;IAShD,KAAK,CAAC,KAAK,EAAE,eAAe,GAAG,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC;IAqEzF,YAAY,IAAI,IAAI;IAOpB,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,GAAG,SAAS;CAGrE"}
@@ -1,70 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BalanceManipulationRule = void 0;
4
- class BalanceManipulationRule {
5
- name = 'BalanceManipulationRule';
6
- severity = 'critical';
7
- balanceHistory;
8
- constructor() {
9
- this.balanceHistory = new Map();
10
- }
11
- async check(event) {
12
- if (event.type !== 'settlement') {
13
- return { detected: false };
14
- }
15
- const balanceEvent = event;
16
- if (balanceEvent.newBalance === undefined) {
17
- return { detected: false };
18
- }
19
- if (balanceEvent.newBalance < 0) {
20
- return {
21
- detected: true,
22
- peerId: balanceEvent.peerId,
23
- details: {
24
- description: `Negative balance attempt detected: ${balanceEvent.newBalance}`,
25
- newBalance: balanceEvent.newBalance,
26
- previousBalance: balanceEvent.previousBalance,
27
- timestamp: balanceEvent.timestamp,
28
- },
29
- };
30
- }
31
- if (balanceEvent.previousBalance !== undefined) {
32
- let history = this.balanceHistory.get(balanceEvent.peerId);
33
- if (!history) {
34
- history = {
35
- peerId: balanceEvent.peerId,
36
- balances: [],
37
- };
38
- this.balanceHistory.set(balanceEvent.peerId, history);
39
- }
40
- const balanceDecrease = balanceEvent.previousBalance - balanceEvent.newBalance;
41
- if (balanceDecrease > 0 && balanceDecrease !== balanceEvent.amount) {
42
- return {
43
- detected: true,
44
- peerId: balanceEvent.peerId,
45
- details: {
46
- description: `Unexpected balance decrease detected: ${balanceDecrease} units (expected: ${balanceEvent.amount})`,
47
- previousBalance: balanceEvent.previousBalance,
48
- newBalance: balanceEvent.newBalance,
49
- expectedDecrease: balanceEvent.amount,
50
- actualDecrease: balanceDecrease,
51
- timestamp: balanceEvent.timestamp,
52
- },
53
- };
54
- }
55
- history.balances.push({
56
- balance: balanceEvent.newBalance,
57
- timestamp: balanceEvent.timestamp,
58
- });
59
- }
60
- return { detected: false };
61
- }
62
- clearHistory() {
63
- this.balanceHistory.clear();
64
- }
65
- getBalanceHistory(peerId) {
66
- return this.balanceHistory.get(peerId);
67
- }
68
- }
69
- exports.BalanceManipulationRule = BalanceManipulationRule;
70
- //# sourceMappingURL=balance-manipulation-rule.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"balance-manipulation-rule.js","sourceRoot":"","sources":["../../../src/security/rules/balance-manipulation-rule.ts"],"names":[],"mappings":";;;AAkCA,MAAa,uBAAuB;IAClB,IAAI,GAAG,yBAAyB,CAAC;IACjC,QAAQ,GAAG,UAAmB,CAAC;IAE9B,cAAc,CAA8B;IAE7D;QACE,IAAI,CAAC,cAAc,GAAG,IAAI,GAAG,EAAE,CAAC;IAClC,CAAC;IAKM,KAAK,CAAC,KAAK,CAAC,KAAmD;QAEpE,IAAI,KAAK,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;YAChC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,YAAY,GAAG,KAAqB,CAAC;QAG3C,IAAI,YAAY,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YAC1C,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAGD,IAAI,YAAY,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC;YAChC,OAAO;gBACL,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,OAAO,EAAE;oBACP,WAAW,EAAE,sCAAsC,YAAY,CAAC,UAAU,EAAE;oBAC5E,UAAU,EAAE,YAAY,CAAC,UAAU;oBACnC,eAAe,EAAE,YAAY,CAAC,eAAe;oBAC7C,SAAS,EAAE,YAAY,CAAC,SAAS;iBAClC;aACF,CAAC;QACJ,CAAC;QAGD,IAAI,YAAY,CAAC,eAAe,KAAK,SAAS,EAAE,CAAC;YAE/C,IAAI,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YAC3D,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,GAAG;oBACR,MAAM,EAAE,YAAY,CAAC,MAAM;oBAC3B,QAAQ,EAAE,EAAE;iBACb,CAAC;gBACF,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;YACxD,CAAC;YAGD,MAAM,eAAe,GAAG,YAAY,CAAC,eAAe,GAAG,YAAY,CAAC,UAAU,CAAC;YAC/E,IAAI,eAAe,GAAG,CAAC,IAAI,eAAe,KAAK,YAAY,CAAC,MAAM,EAAE,CAAC;gBACnE,OAAO;oBACL,QAAQ,EAAE,IAAI;oBACd,MAAM,EAAE,YAAY,CAAC,MAAM;oBAC3B,OAAO,EAAE;wBACP,WAAW,EAAE,yCAAyC,eAAe,qBAAqB,YAAY,CAAC,MAAM,GAAG;wBAChH,eAAe,EAAE,YAAY,CAAC,eAAe;wBAC7C,UAAU,EAAE,YAAY,CAAC,UAAU;wBACnC,gBAAgB,EAAE,YAAY,CAAC,MAAM;wBACrC,cAAc,EAAE,eAAe;wBAC/B,SAAS,EAAE,YAAY,CAAC,SAAS;qBAClC;iBACF,CAAC;YACJ,CAAC;YAGD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACpB,OAAO,EAAE,YAAY,CAAC,UAAU;gBAChC,SAAS,EAAE,YAAY,CAAC,SAAS;aAClC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAKM,YAAY;QACjB,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;IAKM,iBAAiB,CAAC,MAAc;QACrC,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;CACF;AA5FD,0DA4FC"}
@@ -1,23 +0,0 @@
1
- import { FraudRule, FraudDetection, SettlementEvent, PacketEvent, ChannelEvent } from '../fraud-detector';
2
- interface ClaimHistory {
3
- peerId: string;
4
- channelId: string;
5
- claims: {
6
- amount: number;
7
- timestamp: number;
8
- }[];
9
- }
10
- export interface ClaimEvent extends SettlementEvent {
11
- claimAmount?: number;
12
- }
13
- export declare class DoubleSpendDetectionRule implements FraudRule {
14
- readonly name = "DoubleSpendDetectionRule";
15
- readonly severity: "critical";
16
- private readonly claimHistory;
17
- constructor();
18
- check(event: SettlementEvent | PacketEvent | ChannelEvent): Promise<FraudDetection>;
19
- clearHistory(): void;
20
- getClaimHistory(peerId: string, channelId: string): ClaimHistory | undefined;
21
- }
22
- export {};
23
- //# sourceMappingURL=double-spend-detection-rule.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"double-spend-detection-rule.d.ts","sourceRoot":"","sources":["../../../src/security/rules/double-spend-detection-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,cAAc,EACd,eAAe,EACf,WAAW,EACX,YAAY,EACb,MAAM,mBAAmB,CAAC;AAK3B,UAAU,YAAY;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE;QACN,MAAM,EAAE,MAAM,CAAC;QACf,SAAS,EAAE,MAAM,CAAC;KACnB,EAAE,CAAC;CACL;AAKD,MAAM,WAAW,UAAW,SAAQ,eAAe;IACjD,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AASD,qBAAa,wBAAyB,YAAW,SAAS;IACxD,SAAgB,IAAI,8BAA8B;IAClD,SAAgB,QAAQ,EAAG,UAAU,CAAU;IAE/C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAA4B;;IAS5C,KAAK,CAAC,KAAK,EAAE,eAAe,GAAG,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC;IA0DzF,YAAY,IAAI,IAAI;IAOpB,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS;CAGpF"}
@@ -1,61 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DoubleSpendDetectionRule = void 0;
4
- class DoubleSpendDetectionRule {
5
- name = 'DoubleSpendDetectionRule';
6
- severity = 'critical';
7
- claimHistory;
8
- constructor() {
9
- this.claimHistory = new Map();
10
- }
11
- async check(event) {
12
- if (event.type !== 'settlement') {
13
- return { detected: false };
14
- }
15
- const settlementEvent = event;
16
- if (!settlementEvent.channelId || settlementEvent.claimAmount === undefined) {
17
- return { detected: false };
18
- }
19
- const historyKey = `${settlementEvent.peerId}:${settlementEvent.channelId}`;
20
- let history = this.claimHistory.get(historyKey);
21
- if (!history) {
22
- history = {
23
- peerId: settlementEvent.peerId,
24
- channelId: settlementEvent.channelId,
25
- claims: [],
26
- };
27
- this.claimHistory.set(historyKey, history);
28
- }
29
- const previousClaims = history.claims;
30
- if (previousClaims.length > 0) {
31
- const lastClaim = previousClaims[previousClaims.length - 1];
32
- if (lastClaim && settlementEvent.claimAmount < lastClaim.amount) {
33
- return {
34
- detected: true,
35
- peerId: settlementEvent.peerId,
36
- details: {
37
- description: `Double-spend attempt detected: Claim amount ${settlementEvent.claimAmount} is lower than previous claim ${lastClaim.amount}`,
38
- currentClaimAmount: settlementEvent.claimAmount,
39
- previousClaimAmount: lastClaim.amount,
40
- channelId: settlementEvent.channelId,
41
- timestamp: settlementEvent.timestamp,
42
- previousClaimTimestamp: lastClaim.timestamp,
43
- },
44
- };
45
- }
46
- }
47
- history.claims.push({
48
- amount: settlementEvent.claimAmount,
49
- timestamp: settlementEvent.timestamp,
50
- });
51
- return { detected: false };
52
- }
53
- clearHistory() {
54
- this.claimHistory.clear();
55
- }
56
- getClaimHistory(peerId, channelId) {
57
- return this.claimHistory.get(`${peerId}:${channelId}`);
58
- }
59
- }
60
- exports.DoubleSpendDetectionRule = DoubleSpendDetectionRule;
61
- //# sourceMappingURL=double-spend-detection-rule.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"double-spend-detection-rule.js","sourceRoot":"","sources":["../../../src/security/rules/double-spend-detection-rule.ts"],"names":[],"mappings":";;;AAkCA,MAAa,wBAAwB;IACnB,IAAI,GAAG,0BAA0B,CAAC;IAClC,QAAQ,GAAG,UAAmB,CAAC;IAE9B,YAAY,CAA4B;IAEzD;QACE,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,EAAE,CAAC;IAChC,CAAC;IAKM,KAAK,CAAC,KAAK,CAAC,KAAmD;QAEpE,IAAI,KAAK,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;YAChC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,eAAe,GAAG,KAAmB,CAAC;QAG5C,IAAI,CAAC,eAAe,CAAC,SAAS,IAAI,eAAe,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;YAC5E,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,UAAU,GAAG,GAAG,eAAe,CAAC,MAAM,IAAI,eAAe,CAAC,SAAS,EAAE,CAAC;QAG5E,IAAI,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,GAAG;gBACR,MAAM,EAAE,eAAe,CAAC,MAAM;gBAC9B,SAAS,EAAE,eAAe,CAAC,SAAS;gBACpC,MAAM,EAAE,EAAE;aACX,CAAC;YACF,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAC7C,CAAC;QAGD,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC;QACtC,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,MAAM,SAAS,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAC5D,IAAI,SAAS,IAAI,eAAe,CAAC,WAAW,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC;gBAChE,OAAO;oBACL,QAAQ,EAAE,IAAI;oBACd,MAAM,EAAE,eAAe,CAAC,MAAM;oBAC9B,OAAO,EAAE;wBACP,WAAW,EAAE,+CAA+C,eAAe,CAAC,WAAW,iCAAiC,SAAS,CAAC,MAAM,EAAE;wBAC1I,kBAAkB,EAAE,eAAe,CAAC,WAAW;wBAC/C,mBAAmB,EAAE,SAAS,CAAC,MAAM;wBACrC,SAAS,EAAE,eAAe,CAAC,SAAS;wBACpC,SAAS,EAAE,eAAe,CAAC,SAAS;wBACpC,sBAAsB,EAAE,SAAS,CAAC,SAAS;qBAC5C;iBACF,CAAC;YACJ,CAAC;QACH,CAAC;QAGD,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC;YAClB,MAAM,EAAE,eAAe,CAAC,WAAW;YACnC,SAAS,EAAE,eAAe,CAAC,SAAS;SACrC,CAAC,CAAC;QAEH,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAKM,YAAY;QACjB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;IAKM,eAAe,CAAC,MAAc,EAAE,SAAiB;QACtD,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,MAAM,IAAI,SAAS,EAAE,CAAC,CAAC;IACzD,CAAC;CACF;AAjFD,4DAiFC"}
@@ -1,16 +0,0 @@
1
- import { FraudRule, FraudDetection, SettlementEvent, PacketEvent, ChannelEvent } from '../fraud-detector';
2
- export interface RapidChannelClosureConfig {
3
- maxClosures: number;
4
- timeWindow: number;
5
- }
6
- export declare class RapidChannelClosureRule implements FraudRule {
7
- readonly name = "RapidChannelClosureRule";
8
- readonly severity: "high";
9
- private readonly config;
10
- private readonly closureHistory;
11
- constructor(config: RapidChannelClosureConfig);
12
- check(event: SettlementEvent | PacketEvent | ChannelEvent): Promise<FraudDetection>;
13
- private cleanupOldClosures;
14
- clearHistory(): void;
15
- }
16
- //# sourceMappingURL=rapid-channel-closure-rule.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"rapid-channel-closure-rule.d.ts","sourceRoot":"","sources":["../../../src/security/rules/rapid-channel-closure-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,cAAc,EACd,eAAe,EACf,WAAW,EACX,YAAY,EACb,MAAM,mBAAmB,CAAC;AAK3B,MAAM,WAAW,yBAAyB;IAIxC,WAAW,EAAE,MAAM,CAAC;IAKpB,UAAU,EAAE,MAAM,CAAC;CACpB;AAmBD,qBAAa,uBAAwB,YAAW,SAAS;IACvD,SAAgB,IAAI,6BAA6B;IACjD,SAAgB,QAAQ,EAAG,MAAM,CAAU;IAE3C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4B;IACnD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA8B;gBAEjD,MAAM,EAAE,yBAAyB;IAQhC,KAAK,CAAC,KAAK,EAAE,eAAe,GAAG,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC;IAkDhG,OAAO,CAAC,kBAAkB;IAQnB,YAAY,IAAI,IAAI;CAG5B"}
@@ -1,57 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RapidChannelClosureRule = void 0;
4
- class RapidChannelClosureRule {
5
- name = 'RapidChannelClosureRule';
6
- severity = 'high';
7
- config;
8
- closureHistory;
9
- constructor(config) {
10
- this.config = config;
11
- this.closureHistory = new Map();
12
- }
13
- async check(event) {
14
- if (event.type !== 'channel' || event.action !== 'close') {
15
- return { detected: false };
16
- }
17
- const channelEvent = event;
18
- const now = channelEvent.timestamp;
19
- let history = this.closureHistory.get(channelEvent.peerId);
20
- if (!history) {
21
- history = {
22
- peerId: channelEvent.peerId,
23
- closures: [],
24
- };
25
- this.closureHistory.set(channelEvent.peerId, history);
26
- }
27
- history.closures.push({
28
- channelId: channelEvent.channelId,
29
- timestamp: now,
30
- });
31
- this.cleanupOldClosures(history, now);
32
- if (history.closures.length > this.config.maxClosures) {
33
- const closureCount = history.closures.length;
34
- return {
35
- detected: true,
36
- peerId: channelEvent.peerId,
37
- details: {
38
- description: `Rapid channel closures detected: ${closureCount} closures in ${this.config.timeWindow / 1000}s (threshold: ${this.config.maxClosures})`,
39
- closureCount,
40
- maxClosures: this.config.maxClosures,
41
- timeWindow: this.config.timeWindow,
42
- channelIds: history.closures.map((c) => c.channelId),
43
- },
44
- };
45
- }
46
- return { detected: false };
47
- }
48
- cleanupOldClosures(history, now) {
49
- const cutoffTime = now - this.config.timeWindow;
50
- history.closures = history.closures.filter((closure) => closure.timestamp >= cutoffTime);
51
- }
52
- clearHistory() {
53
- this.closureHistory.clear();
54
- }
55
- }
56
- exports.RapidChannelClosureRule = RapidChannelClosureRule;
57
- //# sourceMappingURL=rapid-channel-closure-rule.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"rapid-channel-closure-rule.js","sourceRoot":"","sources":["../../../src/security/rules/rapid-channel-closure-rule.ts"],"names":[],"mappings":";;;AAwCA,MAAa,uBAAuB;IAClB,IAAI,GAAG,yBAAyB,CAAC;IACjC,QAAQ,GAAG,MAAe,CAAC;IAE1B,MAAM,CAA4B;IAClC,cAAc,CAA8B;IAE7D,YAAY,MAAiC;QAC3C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,cAAc,GAAG,IAAI,GAAG,EAAE,CAAC;IAClC,CAAC;IAKM,KAAK,CAAC,KAAK,CAAC,KAAmD;QAEpE,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,OAAO,EAAE,CAAC;YACzD,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,YAAY,GAAG,KAAqB,CAAC;QAC3C,MAAM,GAAG,GAAG,YAAY,CAAC,SAAS,CAAC;QAGnC,IAAI,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC3D,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,GAAG;gBACR,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,QAAQ,EAAE,EAAE;aACb,CAAC;YACF,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACxD,CAAC;QAGD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;YACpB,SAAS,EAAE,YAAY,CAAC,SAAS;YACjC,SAAS,EAAE,GAAG;SACf,CAAC,CAAC;QAGH,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAGtC,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;YACtD,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;YAC7C,OAAO;gBACL,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,OAAO,EAAE;oBACP,WAAW,EAAE,oCAAoC,YAAY,gBAAgB,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,iBAAiB,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG;oBACrJ,YAAY;oBACZ,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW;oBACpC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU;oBAClC,UAAU,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;iBACrD;aACF,CAAC;QACJ,CAAC;QAED,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAKO,kBAAkB,CAAC,OAAuB,EAAE,GAAW;QAC7D,MAAM,UAAU,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;QAChD,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,IAAI,UAAU,CAAC,CAAC;IAC3F,CAAC;IAKM,YAAY;QACjB,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;CACF;AA5ED,0DA4EC"}
@@ -1,18 +0,0 @@
1
- import { FraudRule, FraudDetection, SettlementEvent, PacketEvent, ChannelEvent } from '../fraud-detector';
2
- export interface SuddenTrafficSpikeConfig {
3
- spikeThreshold: number;
4
- timeWindow: number;
5
- }
6
- export declare class SuddenTrafficSpikeRule implements FraudRule {
7
- readonly name = "SuddenTrafficSpikeRule";
8
- readonly severity: "medium";
9
- private readonly config;
10
- private readonly trafficHistory;
11
- constructor(config: SuddenTrafficSpikeConfig);
12
- check(event: SettlementEvent | PacketEvent | ChannelEvent): Promise<FraudDetection>;
13
- private cleanupOldEntries;
14
- private calculateCurrentRate;
15
- private calculateHistoricalAverage;
16
- clearHistory(): void;
17
- }
18
- //# sourceMappingURL=sudden-traffic-spike-rule.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sudden-traffic-spike-rule.d.ts","sourceRoot":"","sources":["../../../src/security/rules/sudden-traffic-spike-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,cAAc,EACd,eAAe,EACf,WAAW,EACX,YAAY,EACb,MAAM,mBAAmB,CAAC;AAK3B,MAAM,WAAW,wBAAwB;IAIvC,cAAc,EAAE,MAAM,CAAC;IAKvB,UAAU,EAAE,MAAM,CAAC;CACpB;AAkBD,qBAAa,sBAAuB,YAAW,SAAS;IACtD,SAAgB,IAAI,4BAA4B;IAChD,SAAgB,QAAQ,EAAG,QAAQ,CAAU;IAE7C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA2B;IAClD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA8B;gBAEjD,MAAM,EAAE,wBAAwB;IAQ/B,KAAK,CAAC,KAAK,EAAE,eAAe,GAAG,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC;IA4DhG,OAAO,CAAC,iBAAiB;IAuBzB,OAAO,CAAC,oBAAoB;IAkB5B,OAAO,CAAC,0BAA0B;IAe3B,YAAY,IAAI,IAAI;CAG5B"}