@skillsmith/core 0.5.5 → 0.5.6

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 (1632) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/__tests__/errors.test.d.ts +5 -0
  4. package/dist/__tests__/errors.test.d.ts.map +1 -0
  5. package/dist/__tests__/errors.test.js +115 -0
  6. package/dist/__tests__/errors.test.js.map +1 -0
  7. package/dist/activation/ActivationManager.d.ts +148 -0
  8. package/dist/activation/ActivationManager.d.ts.map +1 -0
  9. package/dist/activation/ActivationManager.js +291 -0
  10. package/dist/activation/ActivationManager.js.map +1 -0
  11. package/dist/activation/ZeroConfigActivator.d.ts +126 -0
  12. package/dist/activation/ZeroConfigActivator.d.ts.map +1 -0
  13. package/dist/activation/ZeroConfigActivator.js +259 -0
  14. package/dist/activation/ZeroConfigActivator.js.map +1 -0
  15. package/dist/activation/index.d.ts +8 -0
  16. package/dist/activation/index.d.ts.map +1 -0
  17. package/dist/activation/index.js +8 -0
  18. package/dist/activation/index.js.map +1 -0
  19. package/dist/analysis/CodebaseAnalyzer.d.ts +45 -0
  20. package/dist/analysis/CodebaseAnalyzer.d.ts.map +1 -0
  21. package/dist/analysis/CodebaseAnalyzer.js +187 -0
  22. package/dist/analysis/CodebaseAnalyzer.js.map +1 -0
  23. package/dist/analysis/DependencyMerger.d.ts +39 -0
  24. package/dist/analysis/DependencyMerger.d.ts.map +1 -0
  25. package/dist/analysis/DependencyMerger.js +191 -0
  26. package/dist/analysis/DependencyMerger.js.map +1 -0
  27. package/dist/analysis/DependencyMerger.test.d.ts +2 -0
  28. package/dist/analysis/DependencyMerger.test.d.ts.map +1 -0
  29. package/dist/analysis/DependencyMerger.test.js +258 -0
  30. package/dist/analysis/DependencyMerger.test.js.map +1 -0
  31. package/dist/analysis/McpReferenceExtractor.d.ts +42 -0
  32. package/dist/analysis/McpReferenceExtractor.d.ts.map +1 -0
  33. package/dist/analysis/McpReferenceExtractor.js +92 -0
  34. package/dist/analysis/McpReferenceExtractor.js.map +1 -0
  35. package/dist/analysis/McpReferenceExtractor.test.d.ts +2 -0
  36. package/dist/analysis/McpReferenceExtractor.test.d.ts.map +1 -0
  37. package/dist/analysis/McpReferenceExtractor.test.js +262 -0
  38. package/dist/analysis/McpReferenceExtractor.test.js.map +1 -0
  39. package/dist/analysis/__tests__/incremental.test.d.ts +13 -0
  40. package/dist/analysis/__tests__/incremental.test.d.ts.map +1 -0
  41. package/dist/analysis/__tests__/incremental.test.js +515 -0
  42. package/dist/analysis/__tests__/incremental.test.js.map +1 -0
  43. package/dist/analysis/__tests__/integration.test.d.ts +14 -0
  44. package/dist/analysis/__tests__/integration.test.d.ts.map +1 -0
  45. package/dist/analysis/__tests__/integration.test.js +1059 -0
  46. package/dist/analysis/__tests__/integration.test.js.map +1 -0
  47. package/dist/analysis/__tests__/metrics.test.d.ts +9 -0
  48. package/dist/analysis/__tests__/metrics.test.d.ts.map +1 -0
  49. package/dist/analysis/__tests__/metrics.test.js +369 -0
  50. package/dist/analysis/__tests__/metrics.test.js.map +1 -0
  51. package/dist/analysis/__tests__/performance.test.d.ts +15 -0
  52. package/dist/analysis/__tests__/performance.test.d.ts.map +1 -0
  53. package/dist/analysis/__tests__/performance.test.js +402 -0
  54. package/dist/analysis/__tests__/performance.test.js.map +1 -0
  55. package/dist/analysis/adapters/__tests__/go.test.d.ts +12 -0
  56. package/dist/analysis/adapters/__tests__/go.test.d.ts.map +1 -0
  57. package/dist/analysis/adapters/__tests__/go.test.js +561 -0
  58. package/dist/analysis/adapters/__tests__/go.test.js.map +1 -0
  59. package/dist/analysis/adapters/__tests__/python.test.d.ts +11 -0
  60. package/dist/analysis/adapters/__tests__/python.test.d.ts.map +1 -0
  61. package/dist/analysis/adapters/__tests__/python.test.js +669 -0
  62. package/dist/analysis/adapters/__tests__/python.test.js.map +1 -0
  63. package/dist/analysis/adapters/__tests__/rust.test.d.ts +12 -0
  64. package/dist/analysis/adapters/__tests__/rust.test.d.ts.map +1 -0
  65. package/dist/analysis/adapters/__tests__/rust.test.js +676 -0
  66. package/dist/analysis/adapters/__tests__/rust.test.js.map +1 -0
  67. package/dist/analysis/adapters/__tests__/typescript.test.d.ts +14 -0
  68. package/dist/analysis/adapters/__tests__/typescript.test.d.ts.map +1 -0
  69. package/dist/analysis/adapters/__tests__/typescript.test.js +381 -0
  70. package/dist/analysis/adapters/__tests__/typescript.test.js.map +1 -0
  71. package/dist/analysis/adapters/base.d.ts +83 -0
  72. package/dist/analysis/adapters/base.d.ts.map +1 -0
  73. package/dist/analysis/adapters/base.js +40 -0
  74. package/dist/analysis/adapters/base.js.map +1 -0
  75. package/dist/analysis/adapters/factory.d.ts +150 -0
  76. package/dist/analysis/adapters/factory.d.ts.map +1 -0
  77. package/dist/analysis/adapters/factory.js +244 -0
  78. package/dist/analysis/adapters/factory.js.map +1 -0
  79. package/dist/analysis/adapters/go.d.ts +131 -0
  80. package/dist/analysis/adapters/go.d.ts.map +1 -0
  81. package/dist/analysis/adapters/go.js +414 -0
  82. package/dist/analysis/adapters/go.js.map +1 -0
  83. package/dist/analysis/adapters/index.d.ts +20 -0
  84. package/dist/analysis/adapters/index.d.ts.map +1 -0
  85. package/dist/analysis/adapters/index.js +23 -0
  86. package/dist/analysis/adapters/index.js.map +1 -0
  87. package/dist/analysis/adapters/java-parsers.d.ts +64 -0
  88. package/dist/analysis/adapters/java-parsers.d.ts.map +1 -0
  89. package/dist/analysis/adapters/java-parsers.js +121 -0
  90. package/dist/analysis/adapters/java-parsers.js.map +1 -0
  91. package/dist/analysis/adapters/java.d.ts +104 -0
  92. package/dist/analysis/adapters/java.d.ts.map +1 -0
  93. package/dist/analysis/adapters/java.js +296 -0
  94. package/dist/analysis/adapters/java.js.map +1 -0
  95. package/dist/analysis/adapters/python-frameworks.d.ts +21 -0
  96. package/dist/analysis/adapters/python-frameworks.d.ts.map +1 -0
  97. package/dist/analysis/adapters/python-frameworks.js +86 -0
  98. package/dist/analysis/adapters/python-frameworks.js.map +1 -0
  99. package/dist/analysis/adapters/python.d.ts +120 -0
  100. package/dist/analysis/adapters/python.d.ts.map +1 -0
  101. package/dist/analysis/adapters/python.js +345 -0
  102. package/dist/analysis/adapters/python.js.map +1 -0
  103. package/dist/analysis/adapters/rust-parsers.d.ts +33 -0
  104. package/dist/analysis/adapters/rust-parsers.d.ts.map +1 -0
  105. package/dist/analysis/adapters/rust-parsers.js +94 -0
  106. package/dist/analysis/adapters/rust-parsers.js.map +1 -0
  107. package/dist/analysis/adapters/rust.d.ts +74 -0
  108. package/dist/analysis/adapters/rust.d.ts.map +1 -0
  109. package/dist/analysis/adapters/rust.js +377 -0
  110. package/dist/analysis/adapters/rust.js.map +1 -0
  111. package/dist/analysis/adapters/typescript.d.ts +68 -0
  112. package/dist/analysis/adapters/typescript.d.ts.map +1 -0
  113. package/dist/analysis/adapters/typescript.js +79 -0
  114. package/dist/analysis/adapters/typescript.js.map +1 -0
  115. package/dist/analysis/aggregator.d.ts +193 -0
  116. package/dist/analysis/aggregator.d.ts.map +1 -0
  117. package/dist/analysis/aggregator.js +283 -0
  118. package/dist/analysis/aggregator.js.map +1 -0
  119. package/dist/analysis/cache.d.ts +180 -0
  120. package/dist/analysis/cache.d.ts.map +1 -0
  121. package/dist/analysis/cache.js +279 -0
  122. package/dist/analysis/cache.js.map +1 -0
  123. package/dist/analysis/file-streamer.d.ts +136 -0
  124. package/dist/analysis/file-streamer.d.ts.map +1 -0
  125. package/dist/analysis/file-streamer.js +291 -0
  126. package/dist/analysis/file-streamer.js.map +1 -0
  127. package/dist/analysis/framework-detector.d.ts +47 -0
  128. package/dist/analysis/framework-detector.d.ts.map +1 -0
  129. package/dist/analysis/framework-detector.js +151 -0
  130. package/dist/analysis/framework-detector.js.map +1 -0
  131. package/dist/analysis/incremental-parser.d.ts +186 -0
  132. package/dist/analysis/incremental-parser.d.ts.map +1 -0
  133. package/dist/analysis/incremental-parser.js +291 -0
  134. package/dist/analysis/incremental-parser.js.map +1 -0
  135. package/dist/analysis/incremental.d.ts +186 -0
  136. package/dist/analysis/incremental.d.ts.map +1 -0
  137. package/dist/analysis/incremental.js +247 -0
  138. package/dist/analysis/incremental.js.map +1 -0
  139. package/dist/analysis/index.d.ts +37 -0
  140. package/dist/analysis/index.d.ts.map +1 -0
  141. package/dist/analysis/index.js +61 -0
  142. package/dist/analysis/index.js.map +1 -0
  143. package/dist/analysis/language-detector.d.ts +76 -0
  144. package/dist/analysis/language-detector.d.ts.map +1 -0
  145. package/dist/analysis/language-detector.js +205 -0
  146. package/dist/analysis/language-detector.js.map +1 -0
  147. package/dist/analysis/language-detector.patterns.d.ts +17 -0
  148. package/dist/analysis/language-detector.patterns.d.ts.map +1 -0
  149. package/dist/analysis/language-detector.patterns.js +413 -0
  150. package/dist/analysis/language-detector.patterns.js.map +1 -0
  151. package/dist/analysis/language-detector.types.d.ts +48 -0
  152. package/dist/analysis/language-detector.types.d.ts.map +1 -0
  153. package/dist/analysis/language-detector.types.js +6 -0
  154. package/dist/analysis/language-detector.types.js.map +1 -0
  155. package/dist/analysis/memory-monitor.d.ts +199 -0
  156. package/dist/analysis/memory-monitor.d.ts.map +1 -0
  157. package/dist/analysis/memory-monitor.js +271 -0
  158. package/dist/analysis/memory-monitor.js.map +1 -0
  159. package/dist/analysis/metrics.d.ts +103 -0
  160. package/dist/analysis/metrics.d.ts.map +1 -0
  161. package/dist/analysis/metrics.implementations.d.ts +39 -0
  162. package/dist/analysis/metrics.implementations.d.ts.map +1 -0
  163. package/dist/analysis/metrics.implementations.js +114 -0
  164. package/dist/analysis/metrics.implementations.js.map +1 -0
  165. package/dist/analysis/metrics.js +334 -0
  166. package/dist/analysis/metrics.js.map +1 -0
  167. package/dist/analysis/metrics.types.d.ts +79 -0
  168. package/dist/analysis/metrics.types.d.ts.map +1 -0
  169. package/dist/analysis/metrics.types.js +6 -0
  170. package/dist/analysis/metrics.types.js.map +1 -0
  171. package/dist/analysis/parsers.d.ts +43 -0
  172. package/dist/analysis/parsers.d.ts.map +1 -0
  173. package/dist/analysis/parsers.js +219 -0
  174. package/dist/analysis/parsers.js.map +1 -0
  175. package/dist/analysis/router.d.ts +264 -0
  176. package/dist/analysis/router.d.ts.map +1 -0
  177. package/dist/analysis/router.js +398 -0
  178. package/dist/analysis/router.js.map +1 -0
  179. package/dist/analysis/router.test.d.ts +2 -0
  180. package/dist/analysis/router.test.d.ts.map +1 -0
  181. package/dist/analysis/router.test.js +411 -0
  182. package/dist/analysis/router.test.js.map +1 -0
  183. package/dist/analysis/tree-cache.d.ts +208 -0
  184. package/dist/analysis/tree-cache.d.ts.map +1 -0
  185. package/dist/analysis/tree-cache.js +288 -0
  186. package/dist/analysis/tree-cache.js.map +1 -0
  187. package/dist/analysis/tree-sitter/manager.d.ts +141 -0
  188. package/dist/analysis/tree-sitter/manager.d.ts.map +1 -0
  189. package/dist/analysis/tree-sitter/manager.js +246 -0
  190. package/dist/analysis/tree-sitter/manager.js.map +1 -0
  191. package/dist/analysis/tree-sitter/pythonExtractor.d.ts +45 -0
  192. package/dist/analysis/tree-sitter/pythonExtractor.d.ts.map +1 -0
  193. package/dist/analysis/tree-sitter/pythonExtractor.js +264 -0
  194. package/dist/analysis/tree-sitter/pythonExtractor.js.map +1 -0
  195. package/dist/analysis/tree-sitter/pythonExtractor.test.d.ts +12 -0
  196. package/dist/analysis/tree-sitter/pythonExtractor.test.d.ts.map +1 -0
  197. package/dist/analysis/tree-sitter/pythonExtractor.test.js +74 -0
  198. package/dist/analysis/tree-sitter/pythonExtractor.test.js.map +1 -0
  199. package/dist/analysis/tree-sitter/pythonIncremental.d.ts +93 -0
  200. package/dist/analysis/tree-sitter/pythonIncremental.d.ts.map +1 -0
  201. package/dist/analysis/tree-sitter/pythonIncremental.hardening.test.d.ts +22 -0
  202. package/dist/analysis/tree-sitter/pythonIncremental.hardening.test.d.ts.map +1 -0
  203. package/dist/analysis/tree-sitter/pythonIncremental.hardening.test.js +229 -0
  204. package/dist/analysis/tree-sitter/pythonIncremental.hardening.test.js.map +1 -0
  205. package/dist/analysis/tree-sitter/pythonIncremental.js +287 -0
  206. package/dist/analysis/tree-sitter/pythonIncremental.js.map +1 -0
  207. package/dist/analysis/tree-sitter/pythonIncremental.test.d.ts +17 -0
  208. package/dist/analysis/tree-sitter/pythonIncremental.test.d.ts.map +1 -0
  209. package/dist/analysis/tree-sitter/pythonIncremental.test.js +142 -0
  210. package/dist/analysis/tree-sitter/pythonIncremental.test.js.map +1 -0
  211. package/dist/analysis/tree-sitter/queries/python.d.ts +43 -0
  212. package/dist/analysis/tree-sitter/queries/python.d.ts.map +1 -0
  213. package/dist/analysis/tree-sitter/queries/python.js +88 -0
  214. package/dist/analysis/tree-sitter/queries/python.js.map +1 -0
  215. package/dist/analysis/tree-sitter/queryExtractionMatchesOrExceedsRegex.test.d.ts +13 -0
  216. package/dist/analysis/tree-sitter/queryExtractionMatchesOrExceedsRegex.test.d.ts.map +1 -0
  217. package/dist/analysis/tree-sitter/queryExtractionMatchesOrExceedsRegex.test.js +174 -0
  218. package/dist/analysis/tree-sitter/queryExtractionMatchesOrExceedsRegex.test.js.map +1 -0
  219. package/dist/analysis/types.d.ts +203 -0
  220. package/dist/analysis/types.d.ts.map +1 -0
  221. package/dist/analysis/types.js +58 -0
  222. package/dist/analysis/types.js.map +1 -0
  223. package/dist/analysis/worker-pool.d.ts +114 -0
  224. package/dist/analysis/worker-pool.d.ts.map +1 -0
  225. package/dist/analysis/worker-pool.js +266 -0
  226. package/dist/analysis/worker-pool.js.map +1 -0
  227. package/dist/analysis/worker-types.d.ts +64 -0
  228. package/dist/analysis/worker-types.d.ts.map +1 -0
  229. package/dist/analysis/worker-types.js +11 -0
  230. package/dist/analysis/worker-types.js.map +1 -0
  231. package/dist/analysis/worker-utils.d.ts +49 -0
  232. package/dist/analysis/worker-utils.d.ts.map +1 -0
  233. package/dist/analysis/worker-utils.js +206 -0
  234. package/dist/analysis/worker-utils.js.map +1 -0
  235. package/dist/analytics/AnalyticsRepository.d.ts +97 -0
  236. package/dist/analytics/AnalyticsRepository.d.ts.map +1 -0
  237. package/dist/analytics/AnalyticsRepository.helpers.d.ts +28 -0
  238. package/dist/analytics/AnalyticsRepository.helpers.d.ts.map +1 -0
  239. package/dist/analytics/AnalyticsRepository.helpers.js +90 -0
  240. package/dist/analytics/AnalyticsRepository.helpers.js.map +1 -0
  241. package/dist/analytics/AnalyticsRepository.js +245 -0
  242. package/dist/analytics/AnalyticsRepository.js.map +1 -0
  243. package/dist/analytics/AnalyticsRepository.types.d.ts +82 -0
  244. package/dist/analytics/AnalyticsRepository.types.d.ts.map +1 -0
  245. package/dist/analytics/AnalyticsRepository.types.js +8 -0
  246. package/dist/analytics/AnalyticsRepository.types.js.map +1 -0
  247. package/dist/analytics/ExperimentService.d.ts +70 -0
  248. package/dist/analytics/ExperimentService.d.ts.map +1 -0
  249. package/dist/analytics/ExperimentService.js +251 -0
  250. package/dist/analytics/ExperimentService.js.map +1 -0
  251. package/dist/analytics/ROIDashboardService.csv.d.ts +11 -0
  252. package/dist/analytics/ROIDashboardService.csv.d.ts.map +1 -0
  253. package/dist/analytics/ROIDashboardService.csv.js +43 -0
  254. package/dist/analytics/ROIDashboardService.csv.js.map +1 -0
  255. package/dist/analytics/ROIDashboardService.d.ts +116 -0
  256. package/dist/analytics/ROIDashboardService.d.ts.map +1 -0
  257. package/dist/analytics/ROIDashboardService.js +377 -0
  258. package/dist/analytics/ROIDashboardService.js.map +1 -0
  259. package/dist/analytics/UsageAnalyticsService.d.ts +55 -0
  260. package/dist/analytics/UsageAnalyticsService.d.ts.map +1 -0
  261. package/dist/analytics/UsageAnalyticsService.js +180 -0
  262. package/dist/analytics/UsageAnalyticsService.js.map +1 -0
  263. package/dist/analytics/anonymizer.d.ts +53 -0
  264. package/dist/analytics/anonymizer.d.ts.map +1 -0
  265. package/dist/analytics/anonymizer.js +107 -0
  266. package/dist/analytics/anonymizer.js.map +1 -0
  267. package/dist/analytics/constants.d.ts +19 -0
  268. package/dist/analytics/constants.d.ts.map +1 -0
  269. package/dist/analytics/constants.js +19 -0
  270. package/dist/analytics/constants.js.map +1 -0
  271. package/dist/analytics/index.d.ts +23 -0
  272. package/dist/analytics/index.d.ts.map +1 -0
  273. package/dist/analytics/index.js +23 -0
  274. package/dist/analytics/index.js.map +1 -0
  275. package/dist/analytics/metrics-aggregator.d.ts +98 -0
  276. package/dist/analytics/metrics-aggregator.d.ts.map +1 -0
  277. package/dist/analytics/metrics-aggregator.js +176 -0
  278. package/dist/analytics/metrics-aggregator.js.map +1 -0
  279. package/dist/analytics/metrics-exporter.d.ts +148 -0
  280. package/dist/analytics/metrics-exporter.d.ts.map +1 -0
  281. package/dist/analytics/metrics-exporter.js +244 -0
  282. package/dist/analytics/metrics-exporter.js.map +1 -0
  283. package/dist/analytics/schema.d.ts +20 -0
  284. package/dist/analytics/schema.d.ts.map +1 -0
  285. package/dist/analytics/schema.js +265 -0
  286. package/dist/analytics/schema.js.map +1 -0
  287. package/dist/analytics/storage.d.ts +82 -0
  288. package/dist/analytics/storage.d.ts.map +1 -0
  289. package/dist/analytics/storage.js +191 -0
  290. package/dist/analytics/storage.js.map +1 -0
  291. package/dist/analytics/types.d.ts +277 -0
  292. package/dist/analytics/types.d.ts.map +1 -0
  293. package/dist/analytics/types.js +10 -0
  294. package/dist/analytics/types.js.map +1 -0
  295. package/dist/analytics/usage-tracker.d.ts +138 -0
  296. package/dist/analytics/usage-tracker.d.ts.map +1 -0
  297. package/dist/analytics/usage-tracker.js +226 -0
  298. package/dist/analytics/usage-tracker.js.map +1 -0
  299. package/dist/api/cache.d.ts +131 -0
  300. package/dist/api/cache.d.ts.map +1 -0
  301. package/dist/api/cache.js +264 -0
  302. package/dist/api/cache.js.map +1 -0
  303. package/dist/api/client.cache.d.ts +34 -0
  304. package/dist/api/client.cache.d.ts.map +1 -0
  305. package/dist/api/client.cache.js +37 -0
  306. package/dist/api/client.cache.js.map +1 -0
  307. package/dist/api/client.d.ts +55 -0
  308. package/dist/api/client.d.ts.map +1 -0
  309. package/dist/api/client.events.d.ts +39 -0
  310. package/dist/api/client.events.d.ts.map +1 -0
  311. package/dist/api/client.events.js +86 -0
  312. package/dist/api/client.events.js.map +1 -0
  313. package/dist/api/client.health.d.ts +26 -0
  314. package/dist/api/client.health.d.ts.map +1 -0
  315. package/dist/api/client.health.js +74 -0
  316. package/dist/api/client.health.js.map +1 -0
  317. package/dist/api/client.js +297 -0
  318. package/dist/api/client.js.map +1 -0
  319. package/dist/api/client.token-refresh.d.ts +3 -0
  320. package/dist/api/client.token-refresh.d.ts.map +1 -0
  321. package/dist/api/client.token-refresh.js +19 -0
  322. package/dist/api/client.token-refresh.js.map +1 -0
  323. package/dist/api/client.token-refresh.test.d.ts +2 -0
  324. package/dist/api/client.token-refresh.test.d.ts.map +1 -0
  325. package/dist/api/client.token-refresh.test.js +73 -0
  326. package/dist/api/client.token-refresh.test.js.map +1 -0
  327. package/dist/api/client.types.d.ts +111 -0
  328. package/dist/api/client.types.d.ts.map +1 -0
  329. package/dist/api/client.types.js +22 -0
  330. package/dist/api/client.types.js.map +1 -0
  331. package/dist/api/event-batcher.d.ts +81 -0
  332. package/dist/api/event-batcher.d.ts.map +1 -0
  333. package/dist/api/event-batcher.js +191 -0
  334. package/dist/api/event-batcher.js.map +1 -0
  335. package/dist/api/index.d.ts +13 -0
  336. package/dist/api/index.d.ts.map +1 -0
  337. package/dist/api/index.js +19 -0
  338. package/dist/api/index.js.map +1 -0
  339. package/dist/api/schemas.d.ts +451 -0
  340. package/dist/api/schemas.d.ts.map +1 -0
  341. package/dist/api/schemas.js +131 -0
  342. package/dist/api/schemas.js.map +1 -0
  343. package/dist/api/types.d.ts +264 -0
  344. package/dist/api/types.d.ts.map +1 -0
  345. package/dist/api/types.js +9 -0
  346. package/dist/api/types.js.map +1 -0
  347. package/dist/api/utils.d.ts +54 -0
  348. package/dist/api/utils.d.ts.map +1 -0
  349. package/dist/api/utils.js +104 -0
  350. package/dist/api/utils.js.map +1 -0
  351. package/dist/audit/remote-audit.d.ts +28 -0
  352. package/dist/audit/remote-audit.d.ts.map +1 -0
  353. package/dist/audit/remote-audit.js +90 -0
  354. package/dist/audit/remote-audit.js.map +1 -0
  355. package/dist/audit/remote-audit.test.d.ts +2 -0
  356. package/dist/audit/remote-audit.test.d.ts.map +1 -0
  357. package/dist/audit/remote-audit.test.js +81 -0
  358. package/dist/audit/remote-audit.test.js.map +1 -0
  359. package/dist/benchmarks/BenchmarkRunner.d.ts +89 -0
  360. package/dist/benchmarks/BenchmarkRunner.d.ts.map +1 -0
  361. package/dist/benchmarks/BenchmarkRunner.js +336 -0
  362. package/dist/benchmarks/BenchmarkRunner.js.map +1 -0
  363. package/dist/benchmarks/IndexBenchmark.d.ts +101 -0
  364. package/dist/benchmarks/IndexBenchmark.d.ts.map +1 -0
  365. package/dist/benchmarks/IndexBenchmark.js +314 -0
  366. package/dist/benchmarks/IndexBenchmark.js.map +1 -0
  367. package/dist/benchmarks/MemoryProfiler.d.ts +8 -0
  368. package/dist/benchmarks/MemoryProfiler.d.ts.map +1 -0
  369. package/dist/benchmarks/MemoryProfiler.js +8 -0
  370. package/dist/benchmarks/MemoryProfiler.js.map +1 -0
  371. package/dist/benchmarks/SearchBenchmark.d.ts +71 -0
  372. package/dist/benchmarks/SearchBenchmark.d.ts.map +1 -0
  373. package/dist/benchmarks/SearchBenchmark.js +321 -0
  374. package/dist/benchmarks/SearchBenchmark.js.map +1 -0
  375. package/dist/benchmarks/cacheBenchmark.d.ts +75 -0
  376. package/dist/benchmarks/cacheBenchmark.d.ts.map +1 -0
  377. package/dist/benchmarks/cacheBenchmark.js +325 -0
  378. package/dist/benchmarks/cacheBenchmark.js.map +1 -0
  379. package/dist/benchmarks/cli.d.ts +17 -0
  380. package/dist/benchmarks/cli.d.ts.map +1 -0
  381. package/dist/benchmarks/cli.js +140 -0
  382. package/dist/benchmarks/cli.js.map +1 -0
  383. package/dist/benchmarks/comparator.d.ts +38 -0
  384. package/dist/benchmarks/comparator.d.ts.map +1 -0
  385. package/dist/benchmarks/comparator.js +81 -0
  386. package/dist/benchmarks/comparator.js.map +1 -0
  387. package/dist/benchmarks/embeddingBenchmark.d.ts +86 -0
  388. package/dist/benchmarks/embeddingBenchmark.d.ts.map +1 -0
  389. package/dist/benchmarks/embeddingBenchmark.js +329 -0
  390. package/dist/benchmarks/embeddingBenchmark.js.map +1 -0
  391. package/dist/benchmarks/formatters.d.ts +30 -0
  392. package/dist/benchmarks/formatters.d.ts.map +1 -0
  393. package/dist/benchmarks/formatters.js +88 -0
  394. package/dist/benchmarks/formatters.js.map +1 -0
  395. package/dist/benchmarks/incrementalParseBenchmark.d.ts +18 -0
  396. package/dist/benchmarks/incrementalParseBenchmark.d.ts.map +1 -0
  397. package/dist/benchmarks/incrementalParseBenchmark.js +121 -0
  398. package/dist/benchmarks/incrementalParseBenchmark.js.map +1 -0
  399. package/dist/benchmarks/index.d.ts +55 -0
  400. package/dist/benchmarks/index.d.ts.map +1 -0
  401. package/dist/benchmarks/index.js +208 -0
  402. package/dist/benchmarks/index.js.map +1 -0
  403. package/dist/benchmarks/memory/MemoryProfiler.d.ts +165 -0
  404. package/dist/benchmarks/memory/MemoryProfiler.d.ts.map +1 -0
  405. package/dist/benchmarks/memory/MemoryProfiler.js +312 -0
  406. package/dist/benchmarks/memory/MemoryProfiler.js.map +1 -0
  407. package/dist/benchmarks/memory/baseline-manager.d.ts +64 -0
  408. package/dist/benchmarks/memory/baseline-manager.d.ts.map +1 -0
  409. package/dist/benchmarks/memory/baseline-manager.js +95 -0
  410. package/dist/benchmarks/memory/baseline-manager.js.map +1 -0
  411. package/dist/benchmarks/memory/index.d.ts +12 -0
  412. package/dist/benchmarks/memory/index.d.ts.map +1 -0
  413. package/dist/benchmarks/memory/index.js +12 -0
  414. package/dist/benchmarks/memory/index.js.map +1 -0
  415. package/dist/benchmarks/memory/leak-detector.d.ts +23 -0
  416. package/dist/benchmarks/memory/leak-detector.d.ts.map +1 -0
  417. package/dist/benchmarks/memory/leak-detector.js +46 -0
  418. package/dist/benchmarks/memory/leak-detector.js.map +1 -0
  419. package/dist/benchmarks/memory/regression-detector.d.ts +17 -0
  420. package/dist/benchmarks/memory/regression-detector.d.ts.map +1 -0
  421. package/dist/benchmarks/memory/regression-detector.js +56 -0
  422. package/dist/benchmarks/memory/regression-detector.js.map +1 -0
  423. package/dist/benchmarks/memory/types.d.ts +111 -0
  424. package/dist/benchmarks/memory/types.d.ts.map +1 -0
  425. package/dist/benchmarks/memory/types.js +7 -0
  426. package/dist/benchmarks/memory/types.js.map +1 -0
  427. package/dist/benchmarks/memory/utils.d.ts +17 -0
  428. package/dist/benchmarks/memory/utils.d.ts.map +1 -0
  429. package/dist/benchmarks/memory/utils.js +29 -0
  430. package/dist/benchmarks/memory/utils.js.map +1 -0
  431. package/dist/benchmarks/stats.d.ts +56 -0
  432. package/dist/benchmarks/stats.d.ts.map +1 -0
  433. package/dist/benchmarks/stats.js +86 -0
  434. package/dist/benchmarks/stats.js.map +1 -0
  435. package/dist/benchmarks/types.d.ts +175 -0
  436. package/dist/benchmarks/types.d.ts.map +1 -0
  437. package/dist/benchmarks/types.js +20 -0
  438. package/dist/benchmarks/types.js.map +1 -0
  439. package/dist/billing/BillingService.d.ts +101 -0
  440. package/dist/billing/BillingService.d.ts.map +1 -0
  441. package/dist/billing/BillingService.helpers.d.ts +15 -0
  442. package/dist/billing/BillingService.helpers.d.ts.map +1 -0
  443. package/dist/billing/BillingService.helpers.js +45 -0
  444. package/dist/billing/BillingService.helpers.js.map +1 -0
  445. package/dist/billing/BillingService.js +263 -0
  446. package/dist/billing/BillingService.js.map +1 -0
  447. package/dist/billing/BillingService.types.d.ts +52 -0
  448. package/dist/billing/BillingService.types.d.ts.map +1 -0
  449. package/dist/billing/BillingService.types.js +6 -0
  450. package/dist/billing/BillingService.types.js.map +1 -0
  451. package/dist/billing/GDPRComplianceService.d.ts +81 -0
  452. package/dist/billing/GDPRComplianceService.d.ts.map +1 -0
  453. package/dist/billing/GDPRComplianceService.js +361 -0
  454. package/dist/billing/GDPRComplianceService.js.map +1 -0
  455. package/dist/billing/StripeClient.d.ts +119 -0
  456. package/dist/billing/StripeClient.d.ts.map +1 -0
  457. package/dist/billing/StripeClient.js +405 -0
  458. package/dist/billing/StripeClient.js.map +1 -0
  459. package/dist/billing/StripeReconciliationJob.d.ts +50 -0
  460. package/dist/billing/StripeReconciliationJob.d.ts.map +1 -0
  461. package/dist/billing/StripeReconciliationJob.js +365 -0
  462. package/dist/billing/StripeReconciliationJob.js.map +1 -0
  463. package/dist/billing/StripeWebhookHandler.d.ts +49 -0
  464. package/dist/billing/StripeWebhookHandler.d.ts.map +1 -0
  465. package/dist/billing/StripeWebhookHandler.js +162 -0
  466. package/dist/billing/StripeWebhookHandler.js.map +1 -0
  467. package/dist/billing/gdpr-types.d.ts +103 -0
  468. package/dist/billing/gdpr-types.d.ts.map +1 -0
  469. package/dist/billing/gdpr-types.js +7 -0
  470. package/dist/billing/gdpr-types.js.map +1 -0
  471. package/dist/billing/index.d.ts +18 -0
  472. package/dist/billing/index.d.ts.map +1 -0
  473. package/dist/billing/index.js +19 -0
  474. package/dist/billing/index.js.map +1 -0
  475. package/dist/billing/reconciliation-helpers.d.ts +16 -0
  476. package/dist/billing/reconciliation-helpers.d.ts.map +1 -0
  477. package/dist/billing/reconciliation-helpers.js +53 -0
  478. package/dist/billing/reconciliation-helpers.js.map +1 -0
  479. package/dist/billing/reconciliation-types.d.ts +71 -0
  480. package/dist/billing/reconciliation-types.d.ts.map +1 -0
  481. package/dist/billing/reconciliation-types.js +7 -0
  482. package/dist/billing/reconciliation-types.js.map +1 -0
  483. package/dist/billing/stripe-client-types.d.ts +45 -0
  484. package/dist/billing/stripe-client-types.d.ts.map +1 -0
  485. package/dist/billing/stripe-client-types.js +7 -0
  486. package/dist/billing/stripe-client-types.js.map +1 -0
  487. package/dist/billing/stripe-helpers.d.ts +17 -0
  488. package/dist/billing/stripe-helpers.d.ts.map +1 -0
  489. package/dist/billing/stripe-helpers.js +50 -0
  490. package/dist/billing/stripe-helpers.js.map +1 -0
  491. package/dist/billing/types.d.ts +266 -0
  492. package/dist/billing/types.d.ts.map +1 -0
  493. package/dist/billing/types.js +23 -0
  494. package/dist/billing/types.js.map +1 -0
  495. package/dist/billing/webhook-handlers.d.ts +56 -0
  496. package/dist/billing/webhook-handlers.d.ts.map +1 -0
  497. package/dist/billing/webhook-handlers.js +303 -0
  498. package/dist/billing/webhook-handlers.js.map +1 -0
  499. package/dist/billing/webhook-types.d.ts +42 -0
  500. package/dist/billing/webhook-types.d.ts.map +1 -0
  501. package/dist/billing/webhook-types.js +7 -0
  502. package/dist/billing/webhook-types.js.map +1 -0
  503. package/dist/cache/CacheEntry.d.ts +101 -0
  504. package/dist/cache/CacheEntry.d.ts.map +1 -0
  505. package/dist/cache/CacheEntry.js +238 -0
  506. package/dist/cache/CacheEntry.js.map +1 -0
  507. package/dist/cache/CacheManager.d.ts +178 -0
  508. package/dist/cache/CacheManager.d.ts.map +1 -0
  509. package/dist/cache/CacheManager.js +367 -0
  510. package/dist/cache/CacheManager.js.map +1 -0
  511. package/dist/cache/TieredCache.d.ts +110 -0
  512. package/dist/cache/TieredCache.d.ts.map +1 -0
  513. package/dist/cache/TieredCache.js +334 -0
  514. package/dist/cache/TieredCache.js.map +1 -0
  515. package/dist/cache/index.d.ts +75 -0
  516. package/dist/cache/index.d.ts.map +1 -0
  517. package/dist/cache/index.js +110 -0
  518. package/dist/cache/index.js.map +1 -0
  519. package/dist/cache/lru.d.ts +68 -0
  520. package/dist/cache/lru.d.ts.map +1 -0
  521. package/dist/cache/lru.js +105 -0
  522. package/dist/cache/lru.js.map +1 -0
  523. package/dist/cache/sqlite.d.ts +73 -0
  524. package/dist/cache/sqlite.d.ts.map +1 -0
  525. package/dist/cache/sqlite.js +178 -0
  526. package/dist/cache/sqlite.js.map +1 -0
  527. package/dist/config/index.d.ts +170 -0
  528. package/dist/config/index.d.ts.map +1 -0
  529. package/dist/config/index.js +341 -0
  530. package/dist/config/index.js.map +1 -0
  531. package/dist/config/index.test.d.ts +11 -0
  532. package/dist/config/index.test.d.ts.map +1 -0
  533. package/dist/config/index.test.js +288 -0
  534. package/dist/config/index.test.js.map +1 -0
  535. package/dist/config/token-credentials.d.ts +13 -0
  536. package/dist/config/token-credentials.d.ts.map +1 -0
  537. package/dist/config/token-credentials.js +126 -0
  538. package/dist/config/token-credentials.js.map +1 -0
  539. package/dist/config/token-credentials.test.d.ts +10 -0
  540. package/dist/config/token-credentials.test.d.ts.map +1 -0
  541. package/dist/config/token-credentials.test.js +91 -0
  542. package/dist/config/token-credentials.test.js.map +1 -0
  543. package/dist/data/generic-triggers.d.ts +24 -0
  544. package/dist/data/generic-triggers.d.ts.map +1 -0
  545. package/dist/data/generic-triggers.js +19 -0
  546. package/dist/data/generic-triggers.js.map +1 -0
  547. package/dist/data/generic-triggers.json +35 -0
  548. package/dist/db/createDatabase.d.ts +94 -0
  549. package/dist/db/createDatabase.d.ts.map +1 -0
  550. package/dist/db/createDatabase.js +159 -0
  551. package/dist/db/createDatabase.js.map +1 -0
  552. package/dist/db/database-interface.d.ts +141 -0
  553. package/dist/db/database-interface.d.ts.map +1 -0
  554. package/dist/db/database-interface.js +14 -0
  555. package/dist/db/database-interface.js.map +1 -0
  556. package/dist/db/drivers/betterSqlite3Driver.d.ts +48 -0
  557. package/dist/db/drivers/betterSqlite3Driver.d.ts.map +1 -0
  558. package/dist/db/drivers/betterSqlite3Driver.js +138 -0
  559. package/dist/db/drivers/betterSqlite3Driver.js.map +1 -0
  560. package/dist/db/drivers/index.d.ts +8 -0
  561. package/dist/db/drivers/index.d.ts.map +1 -0
  562. package/dist/db/drivers/index.js +8 -0
  563. package/dist/db/drivers/index.js.map +1 -0
  564. package/dist/db/drivers/sqljsDriver.d.ts +91 -0
  565. package/dist/db/drivers/sqljsDriver.d.ts.map +1 -0
  566. package/dist/db/drivers/sqljsDriver.js +334 -0
  567. package/dist/db/drivers/sqljsDriver.js.map +1 -0
  568. package/dist/db/migration-runner.d.ts +44 -0
  569. package/dist/db/migration-runner.d.ts.map +1 -0
  570. package/dist/db/migration-runner.js +175 -0
  571. package/dist/db/migration-runner.js.map +1 -0
  572. package/dist/db/migration-types.d.ts +101 -0
  573. package/dist/db/migration-types.d.ts.map +1 -0
  574. package/dist/db/migration-types.js +6 -0
  575. package/dist/db/migration-types.js.map +1 -0
  576. package/dist/db/migration.d.ts +32 -0
  577. package/dist/db/migration.d.ts.map +1 -0
  578. package/dist/db/migration.js +240 -0
  579. package/dist/db/migration.js.map +1 -0
  580. package/dist/db/migrations/v10-dependencies.d.ts +18 -0
  581. package/dist/db/migrations/v10-dependencies.d.ts.map +1 -0
  582. package/dist/db/migrations/v10-dependencies.js +50 -0
  583. package/dist/db/migrations/v10-dependencies.js.map +1 -0
  584. package/dist/db/migrations/v12-risk-score-history.d.ts +10 -0
  585. package/dist/db/migrations/v12-risk-score-history.d.ts.map +1 -0
  586. package/dist/db/migrations/v12-risk-score-history.js +25 -0
  587. package/dist/db/migrations/v12-risk-score-history.js.map +1 -0
  588. package/dist/db/migrations/v13-team-tables.d.ts +11 -0
  589. package/dist/db/migrations/v13-team-tables.d.ts.map +1 -0
  590. package/dist/db/migrations/v13-team-tables.js +14 -0
  591. package/dist/db/migrations/v13-team-tables.js.map +1 -0
  592. package/dist/db/migrations/v2-phase5-columns.d.ts +7 -0
  593. package/dist/db/migrations/v2-phase5-columns.d.ts.map +1 -0
  594. package/dist/db/migrations/v2-phase5-columns.js +16 -0
  595. package/dist/db/migrations/v2-phase5-columns.js.map +1 -0
  596. package/dist/db/migrations/v3-sync-tables.d.ts +6 -0
  597. package/dist/db/migrations/v3-sync-tables.d.ts.map +1 -0
  598. package/dist/db/migrations/v3-sync-tables.js +41 -0
  599. package/dist/db/migrations/v3-sync-tables.js.map +1 -0
  600. package/dist/db/migrations/v4-security-columns.d.ts +7 -0
  601. package/dist/db/migrations/v4-security-columns.d.ts.map +1 -0
  602. package/dist/db/migrations/v4-security-columns.js +17 -0
  603. package/dist/db/migrations/v4-security-columns.js.map +1 -0
  604. package/dist/db/migrations/v5-skill-versions.d.ts +30 -0
  605. package/dist/db/migrations/v5-skill-versions.d.ts.map +1 -0
  606. package/dist/db/migrations/v5-skill-versions.js +45 -0
  607. package/dist/db/migrations/v5-skill-versions.js.map +1 -0
  608. package/dist/db/migrations/v5b-change-type.d.ts +19 -0
  609. package/dist/db/migrations/v5b-change-type.d.ts.map +1 -0
  610. package/dist/db/migrations/v5b-change-type.js +22 -0
  611. package/dist/db/migrations/v5b-change-type.js.map +1 -0
  612. package/dist/db/migrations/v6-advisories.d.ts +32 -0
  613. package/dist/db/migrations/v6-advisories.d.ts.map +1 -0
  614. package/dist/db/migrations/v6-advisories.js +53 -0
  615. package/dist/db/migrations/v6-advisories.js.map +1 -0
  616. package/dist/db/migrations/v7-compatibility.d.ts +21 -0
  617. package/dist/db/migrations/v7-compatibility.d.ts.map +1 -0
  618. package/dist/db/migrations/v7-compatibility.js +23 -0
  619. package/dist/db/migrations/v7-compatibility.js.map +1 -0
  620. package/dist/db/migrations/v8-co-installs.d.ts +21 -0
  621. package/dist/db/migrations/v8-co-installs.d.ts.map +1 -0
  622. package/dist/db/migrations/v8-co-installs.js +33 -0
  623. package/dist/db/migrations/v8-co-installs.js.map +1 -0
  624. package/dist/db/quarantine-approvals-schema.d.ts +37 -0
  625. package/dist/db/quarantine-approvals-schema.d.ts.map +1 -0
  626. package/dist/db/quarantine-approvals-schema.js +71 -0
  627. package/dist/db/quarantine-approvals-schema.js.map +1 -0
  628. package/dist/db/quarantine-schema.d.ts +81 -0
  629. package/dist/db/quarantine-schema.d.ts.map +1 -0
  630. package/dist/db/quarantine-schema.js +110 -0
  631. package/dist/db/quarantine-schema.js.map +1 -0
  632. package/dist/db/schema-sql.d.ts +16 -0
  633. package/dist/db/schema-sql.d.ts.map +1 -0
  634. package/dist/db/schema-sql.js +161 -0
  635. package/dist/db/schema-sql.js.map +1 -0
  636. package/dist/db/schema.d.ts +62 -0
  637. package/dist/db/schema.d.ts.map +1 -0
  638. package/dist/db/schema.js +131 -0
  639. package/dist/db/schema.js.map +1 -0
  640. package/dist/embeddings/embedding-types.d.ts +44 -0
  641. package/dist/embeddings/embedding-types.d.ts.map +1 -0
  642. package/dist/embeddings/embedding-types.js +6 -0
  643. package/dist/embeddings/embedding-types.js.map +1 -0
  644. package/dist/embeddings/embedding-utils.d.ts +42 -0
  645. package/dist/embeddings/embedding-utils.d.ts.map +1 -0
  646. package/dist/embeddings/embedding-utils.js +121 -0
  647. package/dist/embeddings/embedding-utils.js.map +1 -0
  648. package/dist/embeddings/hnsw-store.d.ts +72 -0
  649. package/dist/embeddings/hnsw-store.d.ts.map +1 -0
  650. package/dist/embeddings/hnsw-store.helpers.d.ts +83 -0
  651. package/dist/embeddings/hnsw-store.helpers.d.ts.map +1 -0
  652. package/dist/embeddings/hnsw-store.helpers.js +147 -0
  653. package/dist/embeddings/hnsw-store.helpers.js.map +1 -0
  654. package/dist/embeddings/hnsw-store.js +352 -0
  655. package/dist/embeddings/hnsw-store.js.map +1 -0
  656. package/dist/embeddings/hnsw-store.types.d.ts +172 -0
  657. package/dist/embeddings/hnsw-store.types.d.ts.map +1 -0
  658. package/dist/embeddings/hnsw-store.types.js +26 -0
  659. package/dist/embeddings/hnsw-store.types.js.map +1 -0
  660. package/dist/embeddings/index.d.ts +98 -0
  661. package/dist/embeddings/index.d.ts.map +1 -0
  662. package/dist/embeddings/index.js +246 -0
  663. package/dist/embeddings/index.js.map +1 -0
  664. package/dist/errors/SkillsmithError.d.ts +118 -0
  665. package/dist/errors/SkillsmithError.d.ts.map +1 -0
  666. package/dist/errors/SkillsmithError.js +194 -0
  667. package/dist/errors/SkillsmithError.js.map +1 -0
  668. package/dist/errors/index.d.ts +36 -0
  669. package/dist/errors/index.d.ts.map +1 -0
  670. package/dist/errors/index.js +36 -0
  671. package/dist/errors/index.js.map +1 -0
  672. package/dist/errors.d.ts +73 -0
  673. package/dist/errors.d.ts.map +1 -0
  674. package/dist/errors.js +124 -0
  675. package/dist/errors.js.map +1 -0
  676. package/dist/exports/repositories.d.ts +28 -0
  677. package/dist/exports/repositories.d.ts.map +1 -0
  678. package/dist/exports/repositories.js +61 -0
  679. package/dist/exports/repositories.js.map +1 -0
  680. package/dist/exports/services.d.ts +37 -0
  681. package/dist/exports/services.d.ts.map +1 -0
  682. package/dist/exports/services.js +86 -0
  683. package/dist/exports/services.js.map +1 -0
  684. package/dist/exports/types.d.ts +22 -0
  685. package/dist/exports/types.d.ts.map +1 -0
  686. package/dist/exports/types.js +12 -0
  687. package/dist/exports/types.js.map +1 -0
  688. package/dist/index.d.ts +35 -0
  689. package/dist/index.d.ts.map +1 -0
  690. package/dist/index.js +82 -0
  691. package/dist/index.js.map +1 -0
  692. package/dist/index.test.d.ts +2 -0
  693. package/dist/index.test.d.ts.map +1 -0
  694. package/dist/index.test.js +35 -0
  695. package/dist/index.test.js.map +1 -0
  696. package/dist/indexer/GitHubIndexer.d.ts +109 -0
  697. package/dist/indexer/GitHubIndexer.d.ts.map +1 -0
  698. package/dist/indexer/GitHubIndexer.js +215 -0
  699. package/dist/indexer/GitHubIndexer.js.map +1 -0
  700. package/dist/indexer/PartitionStrategy.d.ts +115 -0
  701. package/dist/indexer/PartitionStrategy.d.ts.map +1 -0
  702. package/dist/indexer/PartitionStrategy.js +207 -0
  703. package/dist/indexer/PartitionStrategy.js.map +1 -0
  704. package/dist/indexer/SkillParser.coverage.test.d.ts +10 -0
  705. package/dist/indexer/SkillParser.coverage.test.d.ts.map +1 -0
  706. package/dist/indexer/SkillParser.coverage.test.js +76 -0
  707. package/dist/indexer/SkillParser.coverage.test.js.map +1 -0
  708. package/dist/indexer/SkillParser.d.ts +145 -0
  709. package/dist/indexer/SkillParser.d.ts.map +1 -0
  710. package/dist/indexer/SkillParser.js +346 -0
  711. package/dist/indexer/SkillParser.js.map +1 -0
  712. package/dist/indexer/SkillParser.test.d.ts +2 -0
  713. package/dist/indexer/SkillParser.test.d.ts.map +1 -0
  714. package/dist/indexer/SkillParser.test.js +375 -0
  715. package/dist/indexer/SkillParser.test.js.map +1 -0
  716. package/dist/indexer/SwarmIndexer.d.ts +163 -0
  717. package/dist/indexer/SwarmIndexer.d.ts.map +1 -0
  718. package/dist/indexer/SwarmIndexer.js +300 -0
  719. package/dist/indexer/SwarmIndexer.js.map +1 -0
  720. package/dist/indexer/index.d.ts +12 -0
  721. package/dist/indexer/index.d.ts.map +1 -0
  722. package/dist/indexer/index.js +16 -0
  723. package/dist/indexer/index.js.map +1 -0
  724. package/dist/learning/PatternStore.d.ts +43 -0
  725. package/dist/learning/PatternStore.d.ts.map +1 -0
  726. package/dist/learning/PatternStore.helpers.d.ts +106 -0
  727. package/dist/learning/PatternStore.helpers.d.ts.map +1 -0
  728. package/dist/learning/PatternStore.helpers.js +337 -0
  729. package/dist/learning/PatternStore.helpers.js.map +1 -0
  730. package/dist/learning/PatternStore.js +315 -0
  731. package/dist/learning/PatternStore.js.map +1 -0
  732. package/dist/learning/PatternStore.queries.d.ts +83 -0
  733. package/dist/learning/PatternStore.queries.d.ts.map +1 -0
  734. package/dist/learning/PatternStore.queries.js +189 -0
  735. package/dist/learning/PatternStore.queries.js.map +1 -0
  736. package/dist/learning/PatternStore.types.d.ts +308 -0
  737. package/dist/learning/PatternStore.types.d.ts.map +1 -0
  738. package/dist/learning/PatternStore.types.js +44 -0
  739. package/dist/learning/PatternStore.types.js.map +1 -0
  740. package/dist/learning/ReasoningBankIntegration.d.ts +63 -0
  741. package/dist/learning/ReasoningBankIntegration.d.ts.map +1 -0
  742. package/dist/learning/ReasoningBankIntegration.helpers.d.ts +49 -0
  743. package/dist/learning/ReasoningBankIntegration.helpers.d.ts.map +1 -0
  744. package/dist/learning/ReasoningBankIntegration.helpers.js +180 -0
  745. package/dist/learning/ReasoningBankIntegration.helpers.js.map +1 -0
  746. package/dist/learning/ReasoningBankIntegration.js +258 -0
  747. package/dist/learning/ReasoningBankIntegration.js.map +1 -0
  748. package/dist/learning/ReasoningBankIntegration.types.d.ts +167 -0
  749. package/dist/learning/ReasoningBankIntegration.types.d.ts.map +1 -0
  750. package/dist/learning/ReasoningBankIntegration.types.js +51 -0
  751. package/dist/learning/ReasoningBankIntegration.types.js.map +1 -0
  752. package/dist/learning/index.d.ts +15 -0
  753. package/dist/learning/index.d.ts.map +1 -0
  754. package/dist/learning/index.js +15 -0
  755. package/dist/learning/index.js.map +1 -0
  756. package/dist/learning/interfaces.d.ts +338 -0
  757. package/dist/learning/interfaces.d.ts.map +1 -0
  758. package/dist/learning/interfaces.js +13 -0
  759. package/dist/learning/interfaces.js.map +1 -0
  760. package/dist/learning/types.d.ts +284 -0
  761. package/dist/learning/types.d.ts.map +1 -0
  762. package/dist/learning/types.js +112 -0
  763. package/dist/learning/types.js.map +1 -0
  764. package/dist/matching/OverlapDetector.d.ts +152 -0
  765. package/dist/matching/OverlapDetector.d.ts.map +1 -0
  766. package/dist/matching/OverlapDetector.js +218 -0
  767. package/dist/matching/OverlapDetector.js.map +1 -0
  768. package/dist/matching/SkillMatcher.d.ts +125 -0
  769. package/dist/matching/SkillMatcher.d.ts.map +1 -0
  770. package/dist/matching/SkillMatcher.js +206 -0
  771. package/dist/matching/SkillMatcher.js.map +1 -0
  772. package/dist/matching/index.d.ts +14 -0
  773. package/dist/matching/index.d.ts.map +1 -0
  774. package/dist/matching/index.js +12 -0
  775. package/dist/matching/index.js.map +1 -0
  776. package/dist/pipeline/DailyIndexPipeline.d.ts +48 -0
  777. package/dist/pipeline/DailyIndexPipeline.d.ts.map +1 -0
  778. package/dist/pipeline/DailyIndexPipeline.js +246 -0
  779. package/dist/pipeline/DailyIndexPipeline.js.map +1 -0
  780. package/dist/pipeline/index.d.ts +9 -0
  781. package/dist/pipeline/index.d.ts.map +1 -0
  782. package/dist/pipeline/index.js +9 -0
  783. package/dist/pipeline/index.js.map +1 -0
  784. package/dist/pipeline/pipeline-types.d.ts +132 -0
  785. package/dist/pipeline/pipeline-types.d.ts.map +1 -0
  786. package/dist/pipeline/pipeline-types.js +6 -0
  787. package/dist/pipeline/pipeline-types.js.map +1 -0
  788. package/dist/repositories/AdvisoryRepository.d.ts +80 -0
  789. package/dist/repositories/AdvisoryRepository.d.ts.map +1 -0
  790. package/dist/repositories/AdvisoryRepository.js +128 -0
  791. package/dist/repositories/AdvisoryRepository.js.map +1 -0
  792. package/dist/repositories/AdvisoryRepository.test.d.ts +6 -0
  793. package/dist/repositories/AdvisoryRepository.test.d.ts.map +1 -0
  794. package/dist/repositories/AdvisoryRepository.test.js +149 -0
  795. package/dist/repositories/AdvisoryRepository.test.js.map +1 -0
  796. package/dist/repositories/CacheRepository.d.ts +60 -0
  797. package/dist/repositories/CacheRepository.d.ts.map +1 -0
  798. package/dist/repositories/CacheRepository.js +148 -0
  799. package/dist/repositories/CacheRepository.js.map +1 -0
  800. package/dist/repositories/CoInstallRepository.d.ts +68 -0
  801. package/dist/repositories/CoInstallRepository.d.ts.map +1 -0
  802. package/dist/repositories/CoInstallRepository.js +122 -0
  803. package/dist/repositories/CoInstallRepository.js.map +1 -0
  804. package/dist/repositories/IndexerRepository.d.ts +127 -0
  805. package/dist/repositories/IndexerRepository.d.ts.map +1 -0
  806. package/dist/repositories/IndexerRepository.js +281 -0
  807. package/dist/repositories/IndexerRepository.js.map +1 -0
  808. package/dist/repositories/QuarantineRepository.d.ts +8 -0
  809. package/dist/repositories/QuarantineRepository.d.ts.map +1 -0
  810. package/dist/repositories/QuarantineRepository.js +8 -0
  811. package/dist/repositories/QuarantineRepository.js.map +1 -0
  812. package/dist/repositories/RiskScoreHistoryRepository.d.ts +37 -0
  813. package/dist/repositories/RiskScoreHistoryRepository.d.ts.map +1 -0
  814. package/dist/repositories/RiskScoreHistoryRepository.js +66 -0
  815. package/dist/repositories/RiskScoreHistoryRepository.js.map +1 -0
  816. package/dist/repositories/SkillDependencyRepository.d.ts +73 -0
  817. package/dist/repositories/SkillDependencyRepository.d.ts.map +1 -0
  818. package/dist/repositories/SkillDependencyRepository.js +199 -0
  819. package/dist/repositories/SkillDependencyRepository.js.map +1 -0
  820. package/dist/repositories/SkillRepository.d.ts +78 -0
  821. package/dist/repositories/SkillRepository.d.ts.map +1 -0
  822. package/dist/repositories/SkillRepository.js +235 -0
  823. package/dist/repositories/SkillRepository.js.map +1 -0
  824. package/dist/repositories/SkillVersionRepository.d.ts +82 -0
  825. package/dist/repositories/SkillVersionRepository.d.ts.map +1 -0
  826. package/dist/repositories/SkillVersionRepository.js +118 -0
  827. package/dist/repositories/SkillVersionRepository.js.map +1 -0
  828. package/dist/repositories/SyncConfigRepository.d.ts +91 -0
  829. package/dist/repositories/SyncConfigRepository.d.ts.map +1 -0
  830. package/dist/repositories/SyncConfigRepository.js +202 -0
  831. package/dist/repositories/SyncConfigRepository.js.map +1 -0
  832. package/dist/repositories/SyncHistoryRepository.d.ts +104 -0
  833. package/dist/repositories/SyncHistoryRepository.d.ts.map +1 -0
  834. package/dist/repositories/SyncHistoryRepository.js +235 -0
  835. package/dist/repositories/SyncHistoryRepository.js.map +1 -0
  836. package/dist/repositories/quarantine/ApprovalRepository.d.ts +148 -0
  837. package/dist/repositories/quarantine/ApprovalRepository.d.ts.map +1 -0
  838. package/dist/repositories/quarantine/ApprovalRepository.js +212 -0
  839. package/dist/repositories/quarantine/ApprovalRepository.js.map +1 -0
  840. package/dist/repositories/quarantine/QuarantineRepository.d.ts +168 -0
  841. package/dist/repositories/quarantine/QuarantineRepository.d.ts.map +1 -0
  842. package/dist/repositories/quarantine/QuarantineRepository.js +344 -0
  843. package/dist/repositories/quarantine/QuarantineRepository.js.map +1 -0
  844. package/dist/repositories/quarantine/index.d.ts +12 -0
  845. package/dist/repositories/quarantine/index.d.ts.map +1 -0
  846. package/dist/repositories/quarantine/index.js +11 -0
  847. package/dist/repositories/quarantine/index.js.map +1 -0
  848. package/dist/repositories/quarantine/queries.d.ts +58 -0
  849. package/dist/repositories/quarantine/queries.d.ts.map +1 -0
  850. package/dist/repositories/quarantine/queries.js +88 -0
  851. package/dist/repositories/quarantine/queries.js.map +1 -0
  852. package/dist/repositories/quarantine/query-builder.d.ts +44 -0
  853. package/dist/repositories/quarantine/query-builder.d.ts.map +1 -0
  854. package/dist/repositories/quarantine/query-builder.js +87 -0
  855. package/dist/repositories/quarantine/query-builder.js.map +1 -0
  856. package/dist/repositories/quarantine/types.d.ts +155 -0
  857. package/dist/repositories/quarantine/types.d.ts.map +1 -0
  858. package/dist/repositories/quarantine/types.js +13 -0
  859. package/dist/repositories/quarantine/types.js.map +1 -0
  860. package/dist/routing/SONARouter.d.ts +56 -0
  861. package/dist/routing/SONARouter.d.ts.map +1 -0
  862. package/dist/routing/SONARouter.helpers.d.ts +112 -0
  863. package/dist/routing/SONARouter.helpers.d.ts.map +1 -0
  864. package/dist/routing/SONARouter.helpers.js +184 -0
  865. package/dist/routing/SONARouter.helpers.js.map +1 -0
  866. package/dist/routing/SONARouter.js +366 -0
  867. package/dist/routing/SONARouter.js.map +1 -0
  868. package/dist/routing/expert-types.d.ts +109 -0
  869. package/dist/routing/expert-types.d.ts.map +1 -0
  870. package/dist/routing/expert-types.js +162 -0
  871. package/dist/routing/expert-types.js.map +1 -0
  872. package/dist/routing/index.d.ts +9 -0
  873. package/dist/routing/index.d.ts.map +1 -0
  874. package/dist/routing/index.js +10 -0
  875. package/dist/routing/index.js.map +1 -0
  876. package/dist/routing/request-types.d.ts +113 -0
  877. package/dist/routing/request-types.d.ts.map +1 -0
  878. package/dist/routing/request-types.js +9 -0
  879. package/dist/routing/request-types.js.map +1 -0
  880. package/dist/routing/types.d.ts +129 -0
  881. package/dist/routing/types.d.ts.map +1 -0
  882. package/dist/routing/types.js +53 -0
  883. package/dist/routing/types.js.map +1 -0
  884. package/dist/scoring/QualityScorer.d.ts +188 -0
  885. package/dist/scoring/QualityScorer.d.ts.map +1 -0
  886. package/dist/scoring/QualityScorer.js +342 -0
  887. package/dist/scoring/QualityScorer.js.map +1 -0
  888. package/dist/scoring/index.d.ts +10 -0
  889. package/dist/scoring/index.d.ts.map +1 -0
  890. package/dist/scoring/index.js +10 -0
  891. package/dist/scoring/index.js.map +1 -0
  892. package/dist/scoring/quality-score.d.ts +49 -0
  893. package/dist/scoring/quality-score.d.ts.map +1 -0
  894. package/dist/scoring/quality-score.js +73 -0
  895. package/dist/scoring/quality-score.js.map +1 -0
  896. package/dist/scripts/__tests__/scan-imported-skills.test.d.ts +6 -0
  897. package/dist/scripts/__tests__/scan-imported-skills.test.d.ts.map +1 -0
  898. package/dist/scripts/__tests__/scan-imported-skills.test.js +373 -0
  899. package/dist/scripts/__tests__/scan-imported-skills.test.js.map +1 -0
  900. package/dist/scripts/github-import/blocklist.d.ts +65 -0
  901. package/dist/scripts/github-import/blocklist.d.ts.map +1 -0
  902. package/dist/scripts/github-import/blocklist.js +124 -0
  903. package/dist/scripts/github-import/blocklist.js.map +1 -0
  904. package/dist/scripts/github-import/checkpoint.d.ts +21 -0
  905. package/dist/scripts/github-import/checkpoint.d.ts.map +1 -0
  906. package/dist/scripts/github-import/checkpoint.js +52 -0
  907. package/dist/scripts/github-import/checkpoint.js.map +1 -0
  908. package/dist/scripts/github-import/deduplication.d.ts +15 -0
  909. package/dist/scripts/github-import/deduplication.d.ts.map +1 -0
  910. package/dist/scripts/github-import/deduplication.js +33 -0
  911. package/dist/scripts/github-import/deduplication.js.map +1 -0
  912. package/dist/scripts/github-import/github-auth.d.ts +17 -0
  913. package/dist/scripts/github-import/github-auth.d.ts.map +1 -0
  914. package/dist/scripts/github-import/github-auth.js +201 -0
  915. package/dist/scripts/github-import/github-auth.js.map +1 -0
  916. package/dist/scripts/github-import/github-client.d.ts +57 -0
  917. package/dist/scripts/github-import/github-client.d.ts.map +1 -0
  918. package/dist/scripts/github-import/github-client.js +274 -0
  919. package/dist/scripts/github-import/github-client.js.map +1 -0
  920. package/dist/scripts/github-import/index.d.ts +30 -0
  921. package/dist/scripts/github-import/index.d.ts.map +1 -0
  922. package/dist/scripts/github-import/index.js +194 -0
  923. package/dist/scripts/github-import/index.js.map +1 -0
  924. package/dist/scripts/github-import/output.d.ts +12 -0
  925. package/dist/scripts/github-import/output.d.ts.map +1 -0
  926. package/dist/scripts/github-import/output.js +34 -0
  927. package/dist/scripts/github-import/output.js.map +1 -0
  928. package/dist/scripts/github-import/signal-of-intent.d.ts +87 -0
  929. package/dist/scripts/github-import/signal-of-intent.d.ts.map +1 -0
  930. package/dist/scripts/github-import/signal-of-intent.js +213 -0
  931. package/dist/scripts/github-import/signal-of-intent.js.map +1 -0
  932. package/dist/scripts/github-import/types.d.ts +136 -0
  933. package/dist/scripts/github-import/types.d.ts.map +1 -0
  934. package/dist/scripts/github-import/types.js +47 -0
  935. package/dist/scripts/github-import/types.js.map +1 -0
  936. package/dist/scripts/github-import/utils.d.ts +13 -0
  937. package/dist/scripts/github-import/utils.d.ts.map +1 -0
  938. package/dist/scripts/github-import/utils.js +28 -0
  939. package/dist/scripts/github-import/utils.js.map +1 -0
  940. package/dist/scripts/import-github-skills.d.ts +15 -0
  941. package/dist/scripts/import-github-skills.d.ts.map +1 -0
  942. package/dist/scripts/import-github-skills.js +240 -0
  943. package/dist/scripts/import-github-skills.js.map +1 -0
  944. package/dist/scripts/import-to-database.d.ts +60 -0
  945. package/dist/scripts/import-to-database.d.ts.map +1 -0
  946. package/dist/scripts/import-to-database.js +307 -0
  947. package/dist/scripts/import-to-database.js.map +1 -0
  948. package/dist/scripts/ingest-lenny-skills.d.ts +40 -0
  949. package/dist/scripts/ingest-lenny-skills.d.ts.map +1 -0
  950. package/dist/scripts/ingest-lenny-skills.js +346 -0
  951. package/dist/scripts/ingest-lenny-skills.js.map +1 -0
  952. package/dist/scripts/merge-skills.d.ts +34 -0
  953. package/dist/scripts/merge-skills.d.ts.map +1 -0
  954. package/dist/scripts/merge-skills.js +271 -0
  955. package/dist/scripts/merge-skills.js.map +1 -0
  956. package/dist/scripts/merge-types.d.ts +72 -0
  957. package/dist/scripts/merge-types.d.ts.map +1 -0
  958. package/dist/scripts/merge-types.js +7 -0
  959. package/dist/scripts/merge-types.js.map +1 -0
  960. package/dist/scripts/merge-utils.d.ts +23 -0
  961. package/dist/scripts/merge-utils.d.ts.map +1 -0
  962. package/dist/scripts/merge-utils.js +150 -0
  963. package/dist/scripts/merge-utils.js.map +1 -0
  964. package/dist/scripts/review-categories.d.ts +41 -0
  965. package/dist/scripts/review-categories.d.ts.map +1 -0
  966. package/dist/scripts/review-categories.js +316 -0
  967. package/dist/scripts/review-categories.js.map +1 -0
  968. package/dist/scripts/review-lenny-skills.d.ts +26 -0
  969. package/dist/scripts/review-lenny-skills.d.ts.map +1 -0
  970. package/dist/scripts/review-lenny-skills.js +215 -0
  971. package/dist/scripts/review-lenny-skills.js.map +1 -0
  972. package/dist/scripts/scan-imported-skills.d.ts +15 -0
  973. package/dist/scripts/scan-imported-skills.d.ts.map +1 -0
  974. package/dist/scripts/scan-imported-skills.js +16 -0
  975. package/dist/scripts/scan-imported-skills.js.map +1 -0
  976. package/dist/scripts/skill-scanner/allowlist.d.ts +38 -0
  977. package/dist/scripts/skill-scanner/allowlist.d.ts.map +1 -0
  978. package/dist/scripts/skill-scanner/allowlist.js +178 -0
  979. package/dist/scripts/skill-scanner/allowlist.js.map +1 -0
  980. package/dist/scripts/skill-scanner/categorizer.d.ts +43 -0
  981. package/dist/scripts/skill-scanner/categorizer.d.ts.map +1 -0
  982. package/dist/scripts/skill-scanner/categorizer.js +61 -0
  983. package/dist/scripts/skill-scanner/categorizer.js.map +1 -0
  984. package/dist/scripts/skill-scanner/file-scanner.d.ts +43 -0
  985. package/dist/scripts/skill-scanner/file-scanner.d.ts.map +1 -0
  986. package/dist/scripts/skill-scanner/file-scanner.js +90 -0
  987. package/dist/scripts/skill-scanner/file-scanner.js.map +1 -0
  988. package/dist/scripts/skill-scanner/index.d.ts +29 -0
  989. package/dist/scripts/skill-scanner/index.d.ts.map +1 -0
  990. package/dist/scripts/skill-scanner/index.js +134 -0
  991. package/dist/scripts/skill-scanner/index.js.map +1 -0
  992. package/dist/scripts/skill-scanner/logger.d.ts +110 -0
  993. package/dist/scripts/skill-scanner/logger.d.ts.map +1 -0
  994. package/dist/scripts/skill-scanner/logger.js +358 -0
  995. package/dist/scripts/skill-scanner/logger.js.map +1 -0
  996. package/dist/scripts/skill-scanner/reporter.d.ts +56 -0
  997. package/dist/scripts/skill-scanner/reporter.d.ts.map +1 -0
  998. package/dist/scripts/skill-scanner/reporter.js +218 -0
  999. package/dist/scripts/skill-scanner/reporter.js.map +1 -0
  1000. package/dist/scripts/skill-scanner/scanner.d.ts +55 -0
  1001. package/dist/scripts/skill-scanner/scanner.d.ts.map +1 -0
  1002. package/dist/scripts/skill-scanner/scanner.js +269 -0
  1003. package/dist/scripts/skill-scanner/scanner.js.map +1 -0
  1004. package/dist/scripts/skill-scanner/trust-scorer.d.ts +73 -0
  1005. package/dist/scripts/skill-scanner/trust-scorer.d.ts.map +1 -0
  1006. package/dist/scripts/skill-scanner/trust-scorer.js +81 -0
  1007. package/dist/scripts/skill-scanner/trust-scorer.js.map +1 -0
  1008. package/dist/scripts/skill-scanner/types.d.ts +192 -0
  1009. package/dist/scripts/skill-scanner/types.d.ts.map +1 -0
  1010. package/dist/scripts/skill-scanner/types.js +7 -0
  1011. package/dist/scripts/skill-scanner/types.js.map +1 -0
  1012. package/dist/scripts/sync-to-supabase.d.ts +10 -0
  1013. package/dist/scripts/sync-to-supabase.d.ts.map +1 -0
  1014. package/dist/scripts/sync-to-supabase.js +93 -0
  1015. package/dist/scripts/sync-to-supabase.js.map +1 -0
  1016. package/dist/scripts/validate-skills.d.ts +11 -0
  1017. package/dist/scripts/validate-skills.d.ts.map +1 -0
  1018. package/dist/scripts/validate-skills.js +59 -0
  1019. package/dist/scripts/validate-skills.js.map +1 -0
  1020. package/dist/scripts/validation/deduplication.d.ts +23 -0
  1021. package/dist/scripts/validation/deduplication.d.ts.map +1 -0
  1022. package/dist/scripts/validation/deduplication.js +127 -0
  1023. package/dist/scripts/validation/deduplication.js.map +1 -0
  1024. package/dist/scripts/validation/field-validators.d.ts +9 -0
  1025. package/dist/scripts/validation/field-validators.d.ts.map +1 -0
  1026. package/dist/scripts/validation/field-validators.js +135 -0
  1027. package/dist/scripts/validation/field-validators.js.map +1 -0
  1028. package/dist/scripts/validation/index.d.ts +29 -0
  1029. package/dist/scripts/validation/index.d.ts.map +1 -0
  1030. package/dist/scripts/validation/index.js +83 -0
  1031. package/dist/scripts/validation/index.js.map +1 -0
  1032. package/dist/scripts/validation/normalizers.d.ts +29 -0
  1033. package/dist/scripts/validation/normalizers.d.ts.map +1 -0
  1034. package/dist/scripts/validation/normalizers.js +79 -0
  1035. package/dist/scripts/validation/normalizers.js.map +1 -0
  1036. package/dist/scripts/validation/pipeline.d.ts +13 -0
  1037. package/dist/scripts/validation/pipeline.d.ts.map +1 -0
  1038. package/dist/scripts/validation/pipeline.js +126 -0
  1039. package/dist/scripts/validation/pipeline.js.map +1 -0
  1040. package/dist/scripts/validation/types.d.ts +138 -0
  1041. package/dist/scripts/validation/types.d.ts.map +1 -0
  1042. package/dist/scripts/validation/types.js +43 -0
  1043. package/dist/scripts/validation/types.js.map +1 -0
  1044. package/dist/search/hybrid.d.ts +96 -0
  1045. package/dist/search/hybrid.d.ts.map +1 -0
  1046. package/dist/search/hybrid.js +307 -0
  1047. package/dist/search/hybrid.js.map +1 -0
  1048. package/dist/search/index.d.ts +6 -0
  1049. package/dist/search/index.d.ts.map +1 -0
  1050. package/dist/search/index.js +5 -0
  1051. package/dist/search/index.js.map +1 -0
  1052. package/dist/security/AuditLogger.d.ts +126 -0
  1053. package/dist/security/AuditLogger.d.ts.map +1 -0
  1054. package/dist/security/AuditLogger.js +389 -0
  1055. package/dist/security/AuditLogger.js.map +1 -0
  1056. package/dist/security/SkillSandbox.d.ts +156 -0
  1057. package/dist/security/SkillSandbox.d.ts.map +1 -0
  1058. package/dist/security/SkillSandbox.js +303 -0
  1059. package/dist/security/SkillSandbox.js.map +1 -0
  1060. package/dist/security/__tests__/pathValidation.test.d.ts +8 -0
  1061. package/dist/security/__tests__/pathValidation.test.d.ts.map +1 -0
  1062. package/dist/security/__tests__/pathValidation.test.js +249 -0
  1063. package/dist/security/__tests__/pathValidation.test.js.map +1 -0
  1064. package/dist/security/audit-types.d.ts +96 -0
  1065. package/dist/security/audit-types.d.ts.map +1 -0
  1066. package/dist/security/audit-types.js +15 -0
  1067. package/dist/security/audit-types.js.map +1 -0
  1068. package/dist/security/index.d.ts +23 -0
  1069. package/dist/security/index.d.ts.map +1 -0
  1070. package/dist/security/index.js +26 -0
  1071. package/dist/security/index.js.map +1 -0
  1072. package/dist/security/pathValidation.d.ts +95 -0
  1073. package/dist/security/pathValidation.d.ts.map +1 -0
  1074. package/dist/security/pathValidation.js +216 -0
  1075. package/dist/security/pathValidation.js.map +1 -0
  1076. package/dist/security/rate-limiter/RateLimiter.d.ts +86 -0
  1077. package/dist/security/rate-limiter/RateLimiter.d.ts.map +1 -0
  1078. package/dist/security/rate-limiter/RateLimiter.js +260 -0
  1079. package/dist/security/rate-limiter/RateLimiter.js.map +1 -0
  1080. package/dist/security/rate-limiter/constants.d.ts +15 -0
  1081. package/dist/security/rate-limiter/constants.d.ts.map +1 -0
  1082. package/dist/security/rate-limiter/constants.js +15 -0
  1083. package/dist/security/rate-limiter/constants.js.map +1 -0
  1084. package/dist/security/rate-limiter/errors.d.ts +22 -0
  1085. package/dist/security/rate-limiter/errors.d.ts.map +1 -0
  1086. package/dist/security/rate-limiter/errors.js +32 -0
  1087. package/dist/security/rate-limiter/errors.js.map +1 -0
  1088. package/dist/security/rate-limiter/index.d.ts +12 -0
  1089. package/dist/security/rate-limiter/index.d.ts.map +1 -0
  1090. package/dist/security/rate-limiter/index.js +16 -0
  1091. package/dist/security/rate-limiter/index.js.map +1 -0
  1092. package/dist/security/rate-limiter/metrics-manager.d.ts +55 -0
  1093. package/dist/security/rate-limiter/metrics-manager.d.ts.map +1 -0
  1094. package/dist/security/rate-limiter/metrics-manager.js +144 -0
  1095. package/dist/security/rate-limiter/metrics-manager.js.map +1 -0
  1096. package/dist/security/rate-limiter/presets.d.ts +64 -0
  1097. package/dist/security/rate-limiter/presets.d.ts.map +1 -0
  1098. package/dist/security/rate-limiter/presets.js +65 -0
  1099. package/dist/security/rate-limiter/presets.js.map +1 -0
  1100. package/dist/security/rate-limiter/queue-manager.d.ts +59 -0
  1101. package/dist/security/rate-limiter/queue-manager.d.ts.map +1 -0
  1102. package/dist/security/rate-limiter/queue-manager.js +189 -0
  1103. package/dist/security/rate-limiter/queue-manager.js.map +1 -0
  1104. package/dist/security/rate-limiter/storage.d.ts +34 -0
  1105. package/dist/security/rate-limiter/storage.d.ts.map +1 -0
  1106. package/dist/security/rate-limiter/storage.js +80 -0
  1107. package/dist/security/rate-limiter/storage.js.map +1 -0
  1108. package/dist/security/rate-limiter/token-bucket.d.ts +44 -0
  1109. package/dist/security/rate-limiter/token-bucket.d.ts.map +1 -0
  1110. package/dist/security/rate-limiter/token-bucket.js +99 -0
  1111. package/dist/security/rate-limiter/token-bucket.js.map +1 -0
  1112. package/dist/security/rate-limiter/types.d.ts +104 -0
  1113. package/dist/security/rate-limiter/types.d.ts.map +1 -0
  1114. package/dist/security/rate-limiter/types.js +7 -0
  1115. package/dist/security/rate-limiter/types.js.map +1 -0
  1116. package/dist/security/risk-trend.d.ts +21 -0
  1117. package/dist/security/risk-trend.d.ts.map +1 -0
  1118. package/dist/security/risk-trend.js +81 -0
  1119. package/dist/security/risk-trend.js.map +1 -0
  1120. package/dist/security/sanitization.d.ts +124 -0
  1121. package/dist/security/sanitization.d.ts.map +1 -0
  1122. package/dist/security/sanitization.js +388 -0
  1123. package/dist/security/sanitization.js.map +1 -0
  1124. package/dist/security/scanner/SecurityScanner.d.ts +45 -0
  1125. package/dist/security/scanner/SecurityScanner.d.ts.map +1 -0
  1126. package/dist/security/scanner/SecurityScanner.formatters.d.ts +49 -0
  1127. package/dist/security/scanner/SecurityScanner.formatters.d.ts.map +1 -0
  1128. package/dist/security/scanner/SecurityScanner.formatters.js +139 -0
  1129. package/dist/security/scanner/SecurityScanner.formatters.js.map +1 -0
  1130. package/dist/security/scanner/SecurityScanner.helpers.d.ts +80 -0
  1131. package/dist/security/scanner/SecurityScanner.helpers.d.ts.map +1 -0
  1132. package/dist/security/scanner/SecurityScanner.helpers.js +292 -0
  1133. package/dist/security/scanner/SecurityScanner.helpers.js.map +1 -0
  1134. package/dist/security/scanner/SecurityScanner.js +371 -0
  1135. package/dist/security/scanner/SecurityScanner.js.map +1 -0
  1136. package/dist/security/scanner/SecurityScanner.ssrf.d.ts +15 -0
  1137. package/dist/security/scanner/SecurityScanner.ssrf.d.ts.map +1 -0
  1138. package/dist/security/scanner/SecurityScanner.ssrf.js +76 -0
  1139. package/dist/security/scanner/SecurityScanner.ssrf.js.map +1 -0
  1140. package/dist/security/scanner/index.d.ts +11 -0
  1141. package/dist/security/scanner/index.d.ts.map +1 -0
  1142. package/dist/security/scanner/index.js +14 -0
  1143. package/dist/security/scanner/index.js.map +1 -0
  1144. package/dist/security/scanner/patterns.d.ts +39 -0
  1145. package/dist/security/scanner/patterns.d.ts.map +1 -0
  1146. package/dist/security/scanner/patterns.js +295 -0
  1147. package/dist/security/scanner/patterns.js.map +1 -0
  1148. package/dist/security/scanner/regex-utils.d.ts +33 -0
  1149. package/dist/security/scanner/regex-utils.d.ts.map +1 -0
  1150. package/dist/security/scanner/regex-utils.js +41 -0
  1151. package/dist/security/scanner/regex-utils.js.map +1 -0
  1152. package/dist/security/scanner/types.d.ts +77 -0
  1153. package/dist/security/scanner/types.d.ts.map +1 -0
  1154. package/dist/security/scanner/types.js +7 -0
  1155. package/dist/security/scanner/types.js.map +1 -0
  1156. package/dist/security/scanner/weights.d.ts +15 -0
  1157. package/dist/security/scanner/weights.d.ts.map +1 -0
  1158. package/dist/security/scanner/weights.js +31 -0
  1159. package/dist/security/scanner/weights.js.map +1 -0
  1160. package/dist/security/stripe-validators.d.ts +92 -0
  1161. package/dist/security/stripe-validators.d.ts.map +1 -0
  1162. package/dist/security/stripe-validators.js +139 -0
  1163. package/dist/security/stripe-validators.js.map +1 -0
  1164. package/dist/services/SearchService.d.ts +64 -0
  1165. package/dist/services/SearchService.d.ts.map +1 -0
  1166. package/dist/services/SearchService.helpers.d.ts +42 -0
  1167. package/dist/services/SearchService.helpers.d.ts.map +1 -0
  1168. package/dist/services/SearchService.helpers.js +132 -0
  1169. package/dist/services/SearchService.helpers.js.map +1 -0
  1170. package/dist/services/SearchService.js +320 -0
  1171. package/dist/services/SearchService.js.map +1 -0
  1172. package/dist/services/SearchService.types.d.ts +54 -0
  1173. package/dist/services/SearchService.types.d.ts.map +1 -0
  1174. package/dist/services/SearchService.types.js +7 -0
  1175. package/dist/services/SearchService.types.js.map +1 -0
  1176. package/dist/services/SkillAnalyzer.d.ts +37 -0
  1177. package/dist/services/SkillAnalyzer.d.ts.map +1 -0
  1178. package/dist/services/SkillAnalyzer.helpers.d.ts +103 -0
  1179. package/dist/services/SkillAnalyzer.helpers.d.ts.map +1 -0
  1180. package/dist/services/SkillAnalyzer.helpers.js +237 -0
  1181. package/dist/services/SkillAnalyzer.helpers.js.map +1 -0
  1182. package/dist/services/SkillAnalyzer.js +270 -0
  1183. package/dist/services/SkillAnalyzer.js.map +1 -0
  1184. package/dist/services/SkillAnalyzer.types.d.ts +110 -0
  1185. package/dist/services/SkillAnalyzer.types.d.ts.map +1 -0
  1186. package/dist/services/SkillAnalyzer.types.js +9 -0
  1187. package/dist/services/SkillAnalyzer.types.js.map +1 -0
  1188. package/dist/services/SkillDecomposer.d.ts +37 -0
  1189. package/dist/services/SkillDecomposer.d.ts.map +1 -0
  1190. package/dist/services/SkillDecomposer.helpers.d.ts +75 -0
  1191. package/dist/services/SkillDecomposer.helpers.d.ts.map +1 -0
  1192. package/dist/services/SkillDecomposer.helpers.js +277 -0
  1193. package/dist/services/SkillDecomposer.helpers.js.map +1 -0
  1194. package/dist/services/SkillDecomposer.js +116 -0
  1195. package/dist/services/SkillDecomposer.js.map +1 -0
  1196. package/dist/services/SkillDecomposer.types.d.ts +104 -0
  1197. package/dist/services/SkillDecomposer.types.d.ts.map +1 -0
  1198. package/dist/services/SkillDecomposer.types.js +9 -0
  1199. package/dist/services/SkillDecomposer.types.js.map +1 -0
  1200. package/dist/services/SubagentGenerator.d.ts +77 -0
  1201. package/dist/services/SubagentGenerator.d.ts.map +1 -0
  1202. package/dist/services/SubagentGenerator.js +352 -0
  1203. package/dist/services/SubagentGenerator.js.map +1 -0
  1204. package/dist/services/TaskRunner.d.ts +151 -0
  1205. package/dist/services/TaskRunner.d.ts.map +1 -0
  1206. package/dist/services/TaskRunner.js +362 -0
  1207. package/dist/services/TaskRunner.js.map +1 -0
  1208. package/dist/services/TaskRunner.process.d.ts +33 -0
  1209. package/dist/services/TaskRunner.process.d.ts.map +1 -0
  1210. package/dist/services/TaskRunner.process.js +70 -0
  1211. package/dist/services/TaskRunner.process.js.map +1 -0
  1212. package/dist/services/TaskRunner.types.d.ts +76 -0
  1213. package/dist/services/TaskRunner.types.d.ts.map +1 -0
  1214. package/dist/services/TaskRunner.types.js +22 -0
  1215. package/dist/services/TaskRunner.types.js.map +1 -0
  1216. package/dist/services/TransformationService.d.ts +167 -0
  1217. package/dist/services/TransformationService.d.ts.map +1 -0
  1218. package/dist/services/TransformationService.js +315 -0
  1219. package/dist/services/TransformationService.js.map +1 -0
  1220. package/dist/services/__tests__/SkillAnalyzer.test.d.ts +6 -0
  1221. package/dist/services/__tests__/SkillAnalyzer.test.d.ts.map +1 -0
  1222. package/dist/services/__tests__/SkillAnalyzer.test.js +177 -0
  1223. package/dist/services/__tests__/SkillAnalyzer.test.js.map +1 -0
  1224. package/dist/services/__tests__/SkillDecomposer.test.d.ts +6 -0
  1225. package/dist/services/__tests__/SkillDecomposer.test.d.ts.map +1 -0
  1226. package/dist/services/__tests__/SkillDecomposer.test.js +235 -0
  1227. package/dist/services/__tests__/SkillDecomposer.test.js.map +1 -0
  1228. package/dist/services/__tests__/SubagentGenerator.test.d.ts +6 -0
  1229. package/dist/services/__tests__/SubagentGenerator.test.d.ts.map +1 -0
  1230. package/dist/services/__tests__/SubagentGenerator.test.js +174 -0
  1231. package/dist/services/__tests__/SubagentGenerator.test.js.map +1 -0
  1232. package/dist/services/__tests__/TaskRunner.process.test.d.ts +13 -0
  1233. package/dist/services/__tests__/TaskRunner.process.test.d.ts.map +1 -0
  1234. package/dist/services/__tests__/TaskRunner.process.test.js +91 -0
  1235. package/dist/services/__tests__/TaskRunner.process.test.js.map +1 -0
  1236. package/dist/services/__tests__/TaskRunner.test.d.ts +7 -0
  1237. package/dist/services/__tests__/TaskRunner.test.d.ts.map +1 -0
  1238. package/dist/services/__tests__/TaskRunner.test.js +316 -0
  1239. package/dist/services/__tests__/TaskRunner.test.js.map +1 -0
  1240. package/dist/services/__tests__/TransformationService.test.d.ts +6 -0
  1241. package/dist/services/__tests__/TransformationService.test.d.ts.map +1 -0
  1242. package/dist/services/__tests__/TransformationService.test.js +244 -0
  1243. package/dist/services/__tests__/TransformationService.test.js.map +1 -0
  1244. package/dist/services/index.d.ts +9 -0
  1245. package/dist/services/index.d.ts.map +1 -0
  1246. package/dist/services/index.js +10 -0
  1247. package/dist/services/index.js.map +1 -0
  1248. package/dist/services/quarantine/QuarantineService.d.ts +136 -0
  1249. package/dist/services/quarantine/QuarantineService.d.ts.map +1 -0
  1250. package/dist/services/quarantine/QuarantineService.js +267 -0
  1251. package/dist/services/quarantine/QuarantineService.js.map +1 -0
  1252. package/dist/services/quarantine/QuarantineService.multiapproval.d.ts +57 -0
  1253. package/dist/services/quarantine/QuarantineService.multiapproval.d.ts.map +1 -0
  1254. package/dist/services/quarantine/QuarantineService.multiapproval.js +211 -0
  1255. package/dist/services/quarantine/QuarantineService.multiapproval.js.map +1 -0
  1256. package/dist/services/quarantine/index.d.ts +10 -0
  1257. package/dist/services/quarantine/index.d.ts.map +1 -0
  1258. package/dist/services/quarantine/index.js +14 -0
  1259. package/dist/services/quarantine/index.js.map +1 -0
  1260. package/dist/services/quarantine/types.d.ts +127 -0
  1261. package/dist/services/quarantine/types.d.ts.map +1 -0
  1262. package/dist/services/quarantine/types.js +59 -0
  1263. package/dist/services/quarantine/types.js.map +1 -0
  1264. package/dist/services/skill-config-schema.d.ts +68 -0
  1265. package/dist/services/skill-config-schema.d.ts.map +1 -0
  1266. package/dist/services/skill-config-schema.js +76 -0
  1267. package/dist/services/skill-config-schema.js.map +1 -0
  1268. package/dist/services/skill-installation.feedback.d.ts +24 -0
  1269. package/dist/services/skill-installation.feedback.d.ts.map +1 -0
  1270. package/dist/services/skill-installation.feedback.js +37 -0
  1271. package/dist/services/skill-installation.feedback.js.map +1 -0
  1272. package/dist/services/skill-installation.helpers.d.ts +88 -0
  1273. package/dist/services/skill-installation.helpers.d.ts.map +1 -0
  1274. package/dist/services/skill-installation.helpers.js +377 -0
  1275. package/dist/services/skill-installation.helpers.js.map +1 -0
  1276. package/dist/services/skill-installation.service.d.ts +37 -0
  1277. package/dist/services/skill-installation.service.d.ts.map +1 -0
  1278. package/dist/services/skill-installation.service.js +432 -0
  1279. package/dist/services/skill-installation.service.js.map +1 -0
  1280. package/dist/services/skill-installation.types.d.ts +166 -0
  1281. package/dist/services/skill-installation.types.d.ts.map +1 -0
  1282. package/dist/services/skill-installation.types.js +38 -0
  1283. package/dist/services/skill-installation.types.js.map +1 -0
  1284. package/dist/services/skill-manifest.d.ts +20 -0
  1285. package/dist/services/skill-manifest.d.ts.map +1 -0
  1286. package/dist/services/skill-manifest.js +84 -0
  1287. package/dist/services/skill-manifest.js.map +1 -0
  1288. package/dist/session/SessionContext.d.ts +116 -0
  1289. package/dist/session/SessionContext.d.ts.map +1 -0
  1290. package/dist/session/SessionContext.js +134 -0
  1291. package/dist/session/SessionContext.js.map +1 -0
  1292. package/dist/session/SessionHealthMonitor.d.ts +86 -0
  1293. package/dist/session/SessionHealthMonitor.d.ts.map +1 -0
  1294. package/dist/session/SessionHealthMonitor.js +233 -0
  1295. package/dist/session/SessionHealthMonitor.js.map +1 -0
  1296. package/dist/session/SessionManager.d.ts +91 -0
  1297. package/dist/session/SessionManager.d.ts.map +1 -0
  1298. package/dist/session/SessionManager.helpers.d.ts +42 -0
  1299. package/dist/session/SessionManager.helpers.d.ts.map +1 -0
  1300. package/dist/session/SessionManager.helpers.js +88 -0
  1301. package/dist/session/SessionManager.helpers.js.map +1 -0
  1302. package/dist/session/SessionManager.js +229 -0
  1303. package/dist/session/SessionManager.js.map +1 -0
  1304. package/dist/session/SessionManager.memory.d.ts +68 -0
  1305. package/dist/session/SessionManager.memory.d.ts.map +1 -0
  1306. package/dist/session/SessionManager.memory.js +170 -0
  1307. package/dist/session/SessionManager.memory.js.map +1 -0
  1308. package/dist/session/SessionManager.types.d.ts +51 -0
  1309. package/dist/session/SessionManager.types.d.ts.map +1 -0
  1310. package/dist/session/SessionManager.types.js +27 -0
  1311. package/dist/session/SessionManager.types.js.map +1 -0
  1312. package/dist/session/SessionRecovery.d.ts +84 -0
  1313. package/dist/session/SessionRecovery.d.ts.map +1 -0
  1314. package/dist/session/SessionRecovery.js +258 -0
  1315. package/dist/session/SessionRecovery.js.map +1 -0
  1316. package/dist/session/health-checks.d.ts +37 -0
  1317. package/dist/session/health-checks.d.ts.map +1 -0
  1318. package/dist/session/health-checks.js +64 -0
  1319. package/dist/session/health-checks.js.map +1 -0
  1320. package/dist/session/health-types.d.ts +78 -0
  1321. package/dist/session/health-types.d.ts.map +1 -0
  1322. package/dist/session/health-types.js +16 -0
  1323. package/dist/session/health-types.js.map +1 -0
  1324. package/dist/session/index.d.ts +44 -0
  1325. package/dist/session/index.d.ts.map +1 -0
  1326. package/dist/session/index.js +53 -0
  1327. package/dist/session/index.js.map +1 -0
  1328. package/dist/session/metrics-collector.d.ts +23 -0
  1329. package/dist/session/metrics-collector.d.ts.map +1 -0
  1330. package/dist/session/metrics-collector.js +44 -0
  1331. package/dist/session/metrics-collector.js.map +1 -0
  1332. package/dist/session/typed-event-emitter.d.ts +70 -0
  1333. package/dist/session/typed-event-emitter.d.ts.map +1 -0
  1334. package/dist/session/typed-event-emitter.js +79 -0
  1335. package/dist/session/typed-event-emitter.js.map +1 -0
  1336. package/dist/sources/BaseSourceAdapter.d.ts +144 -0
  1337. package/dist/sources/BaseSourceAdapter.d.ts.map +1 -0
  1338. package/dist/sources/BaseSourceAdapter.js +287 -0
  1339. package/dist/sources/BaseSourceAdapter.js.map +1 -0
  1340. package/dist/sources/GitHubSourceAdapter.d.ts +98 -0
  1341. package/dist/sources/GitHubSourceAdapter.d.ts.map +1 -0
  1342. package/dist/sources/GitHubSourceAdapter.js +269 -0
  1343. package/dist/sources/GitHubSourceAdapter.js.map +1 -0
  1344. package/dist/sources/GitLabSourceAdapter.d.ts +102 -0
  1345. package/dist/sources/GitLabSourceAdapter.d.ts.map +1 -0
  1346. package/dist/sources/GitLabSourceAdapter.js +310 -0
  1347. package/dist/sources/GitLabSourceAdapter.js.map +1 -0
  1348. package/dist/sources/ISourceAdapter.d.ts +110 -0
  1349. package/dist/sources/ISourceAdapter.d.ts.map +1 -0
  1350. package/dist/sources/ISourceAdapter.js +19 -0
  1351. package/dist/sources/ISourceAdapter.js.map +1 -0
  1352. package/dist/sources/LocalFilesystemAdapter.d.ts +206 -0
  1353. package/dist/sources/LocalFilesystemAdapter.d.ts.map +1 -0
  1354. package/dist/sources/LocalFilesystemAdapter.helpers.d.ts +92 -0
  1355. package/dist/sources/LocalFilesystemAdapter.helpers.d.ts.map +1 -0
  1356. package/dist/sources/LocalFilesystemAdapter.helpers.js +157 -0
  1357. package/dist/sources/LocalFilesystemAdapter.helpers.js.map +1 -0
  1358. package/dist/sources/LocalFilesystemAdapter.js +399 -0
  1359. package/dist/sources/LocalFilesystemAdapter.js.map +1 -0
  1360. package/dist/sources/LocalFilesystemAdapter.scan.d.ts +78 -0
  1361. package/dist/sources/LocalFilesystemAdapter.scan.d.ts.map +1 -0
  1362. package/dist/sources/LocalFilesystemAdapter.scan.js +118 -0
  1363. package/dist/sources/LocalFilesystemAdapter.scan.js.map +1 -0
  1364. package/dist/sources/RawUrlSourceAdapter.d.ts +128 -0
  1365. package/dist/sources/RawUrlSourceAdapter.d.ts.map +1 -0
  1366. package/dist/sources/RawUrlSourceAdapter.js +282 -0
  1367. package/dist/sources/RawUrlSourceAdapter.js.map +1 -0
  1368. package/dist/sources/SourceAdapterRegistry.d.ts +156 -0
  1369. package/dist/sources/SourceAdapterRegistry.d.ts.map +1 -0
  1370. package/dist/sources/SourceAdapterRegistry.js +242 -0
  1371. package/dist/sources/SourceAdapterRegistry.js.map +1 -0
  1372. package/dist/sources/SourceIndexer.d.ts +121 -0
  1373. package/dist/sources/SourceIndexer.d.ts.map +1 -0
  1374. package/dist/sources/SourceIndexer.js +285 -0
  1375. package/dist/sources/SourceIndexer.js.map +1 -0
  1376. package/dist/sources/index.d.ts +45 -0
  1377. package/dist/sources/index.d.ts.map +1 -0
  1378. package/dist/sources/index.js +51 -0
  1379. package/dist/sources/index.js.map +1 -0
  1380. package/dist/sources/shared.d.ts +125 -0
  1381. package/dist/sources/shared.d.ts.map +1 -0
  1382. package/dist/sources/shared.js +191 -0
  1383. package/dist/sources/shared.js.map +1 -0
  1384. package/dist/sources/types.d.ts +232 -0
  1385. package/dist/sources/types.d.ts.map +1 -0
  1386. package/dist/sources/types.js +6 -0
  1387. package/dist/sources/types.js.map +1 -0
  1388. package/dist/src/api/schemas.d.ts +88 -88
  1389. package/dist/src/api/schemas.d.ts.map +1 -1
  1390. package/dist/src/db/schema.d.ts +8 -1
  1391. package/dist/src/db/schema.d.ts.map +1 -1
  1392. package/dist/src/db/schema.js +12 -6
  1393. package/dist/src/db/schema.js.map +1 -1
  1394. package/dist/src/index.d.ts +1 -1
  1395. package/dist/src/index.js +1 -1
  1396. package/dist/src/scripts/validation/types.d.ts +24 -14
  1397. package/dist/src/scripts/validation/types.d.ts.map +1 -1
  1398. package/dist/src/services/skill-config-schema.d.ts +36 -4
  1399. package/dist/src/services/skill-config-schema.d.ts.map +1 -1
  1400. package/dist/src/webhooks/webhook-schemas.d.ts +1213 -118
  1401. package/dist/src/webhooks/webhook-schemas.d.ts.map +1 -1
  1402. package/dist/sync/BackgroundSyncService.d.ts +90 -0
  1403. package/dist/sync/BackgroundSyncService.d.ts.map +1 -0
  1404. package/dist/sync/BackgroundSyncService.js +214 -0
  1405. package/dist/sync/BackgroundSyncService.js.map +1 -0
  1406. package/dist/sync/SyncEngine.d.ts +88 -0
  1407. package/dist/sync/SyncEngine.d.ts.map +1 -0
  1408. package/dist/sync/SyncEngine.js +341 -0
  1409. package/dist/sync/SyncEngine.js.map +1 -0
  1410. package/dist/sync/index.d.ts +11 -0
  1411. package/dist/sync/index.d.ts.map +1 -0
  1412. package/dist/sync/index.js +14 -0
  1413. package/dist/sync/index.js.map +1 -0
  1414. package/dist/telemetry/index.d.ts +26 -0
  1415. package/dist/telemetry/index.d.ts.map +1 -0
  1416. package/dist/telemetry/index.js +34 -0
  1417. package/dist/telemetry/index.js.map +1 -0
  1418. package/dist/telemetry/metric-helpers.d.ts +47 -0
  1419. package/dist/telemetry/metric-helpers.d.ts.map +1 -0
  1420. package/dist/telemetry/metric-helpers.js +96 -0
  1421. package/dist/telemetry/metric-helpers.js.map +1 -0
  1422. package/dist/telemetry/metric-types.d.ts +73 -0
  1423. package/dist/telemetry/metric-types.d.ts.map +1 -0
  1424. package/dist/telemetry/metric-types.js +9 -0
  1425. package/dist/telemetry/metric-types.js.map +1 -0
  1426. package/dist/telemetry/metrics.d.ts +60 -0
  1427. package/dist/telemetry/metrics.d.ts.map +1 -0
  1428. package/dist/telemetry/metrics.js +228 -0
  1429. package/dist/telemetry/metrics.js.map +1 -0
  1430. package/dist/telemetry/posthog.d.ts +147 -0
  1431. package/dist/telemetry/posthog.d.ts.map +1 -0
  1432. package/dist/telemetry/posthog.js +213 -0
  1433. package/dist/telemetry/posthog.js.map +1 -0
  1434. package/dist/telemetry/prometheus.d.ts +81 -0
  1435. package/dist/telemetry/prometheus.d.ts.map +1 -0
  1436. package/dist/telemetry/prometheus.js +252 -0
  1437. package/dist/telemetry/prometheus.js.map +1 -0
  1438. package/dist/telemetry/span-utils.d.ts +30 -0
  1439. package/dist/telemetry/span-utils.d.ts.map +1 -0
  1440. package/dist/telemetry/span-utils.js +62 -0
  1441. package/dist/telemetry/span-utils.js.map +1 -0
  1442. package/dist/telemetry/tracer-imports.d.ts +13 -0
  1443. package/dist/telemetry/tracer-imports.d.ts.map +1 -0
  1444. package/dist/telemetry/tracer-imports.js +26 -0
  1445. package/dist/telemetry/tracer-imports.js.map +1 -0
  1446. package/dist/telemetry/tracer-types.d.ts +91 -0
  1447. package/dist/telemetry/tracer-types.d.ts.map +1 -0
  1448. package/dist/telemetry/tracer-types.js +6 -0
  1449. package/dist/telemetry/tracer-types.js.map +1 -0
  1450. package/dist/telemetry/tracer.d.ts +34 -0
  1451. package/dist/telemetry/tracer.d.ts.map +1 -0
  1452. package/dist/telemetry/tracer.js +242 -0
  1453. package/dist/telemetry/tracer.js.map +1 -0
  1454. package/dist/testing/MultiLLMProvider.d.ts +97 -0
  1455. package/dist/testing/MultiLLMProvider.d.ts.map +1 -0
  1456. package/dist/testing/MultiLLMProvider.helpers.d.ts +54 -0
  1457. package/dist/testing/MultiLLMProvider.helpers.d.ts.map +1 -0
  1458. package/dist/testing/MultiLLMProvider.helpers.js +126 -0
  1459. package/dist/testing/MultiLLMProvider.helpers.js.map +1 -0
  1460. package/dist/testing/MultiLLMProvider.js +321 -0
  1461. package/dist/testing/MultiLLMProvider.js.map +1 -0
  1462. package/dist/testing/MultiLLMProvider.metrics.d.ts +33 -0
  1463. package/dist/testing/MultiLLMProvider.metrics.d.ts.map +1 -0
  1464. package/dist/testing/MultiLLMProvider.metrics.js +87 -0
  1465. package/dist/testing/MultiLLMProvider.metrics.js.map +1 -0
  1466. package/dist/testing/MultiLLMProvider.selection.d.ts +77 -0
  1467. package/dist/testing/MultiLLMProvider.selection.d.ts.map +1 -0
  1468. package/dist/testing/MultiLLMProvider.selection.js +151 -0
  1469. package/dist/testing/MultiLLMProvider.selection.js.map +1 -0
  1470. package/dist/testing/MultiLLMProvider.types.d.ts +253 -0
  1471. package/dist/testing/MultiLLMProvider.types.d.ts.map +1 -0
  1472. package/dist/testing/MultiLLMProvider.types.js +111 -0
  1473. package/dist/testing/MultiLLMProvider.types.js.map +1 -0
  1474. package/dist/testing/index.d.ts +8 -0
  1475. package/dist/testing/index.d.ts.map +1 -0
  1476. package/dist/testing/index.js +9 -0
  1477. package/dist/testing/index.js.map +1 -0
  1478. package/dist/tests/db/migration.test.js +8 -6
  1479. package/dist/tests/db/migration.test.js.map +1 -1
  1480. package/dist/triggers/ContextScorer.d.ts +118 -0
  1481. package/dist/triggers/ContextScorer.d.ts.map +1 -0
  1482. package/dist/triggers/ContextScorer.js +265 -0
  1483. package/dist/triggers/ContextScorer.js.map +1 -0
  1484. package/dist/triggers/TriggerDetector.d.ts +42 -0
  1485. package/dist/triggers/TriggerDetector.d.ts.map +1 -0
  1486. package/dist/triggers/TriggerDetector.js +158 -0
  1487. package/dist/triggers/TriggerDetector.js.map +1 -0
  1488. package/dist/triggers/__tests__/ContextScorer.test.d.ts +6 -0
  1489. package/dist/triggers/__tests__/ContextScorer.test.d.ts.map +1 -0
  1490. package/dist/triggers/__tests__/ContextScorer.test.js +307 -0
  1491. package/dist/triggers/__tests__/ContextScorer.test.js.map +1 -0
  1492. package/dist/triggers/__tests__/TriggerDetector.test.d.ts +6 -0
  1493. package/dist/triggers/__tests__/TriggerDetector.test.d.ts.map +1 -0
  1494. package/dist/triggers/__tests__/TriggerDetector.test.js +249 -0
  1495. package/dist/triggers/__tests__/TriggerDetector.test.js.map +1 -0
  1496. package/dist/triggers/index.d.ts +8 -0
  1497. package/dist/triggers/index.d.ts.map +1 -0
  1498. package/dist/triggers/index.js +8 -0
  1499. package/dist/triggers/index.js.map +1 -0
  1500. package/dist/triggers/trigger-constants.d.ts +22 -0
  1501. package/dist/triggers/trigger-constants.d.ts.map +1 -0
  1502. package/dist/triggers/trigger-constants.js +185 -0
  1503. package/dist/triggers/trigger-constants.js.map +1 -0
  1504. package/dist/triggers/trigger-types.d.ts +90 -0
  1505. package/dist/triggers/trigger-types.d.ts.map +1 -0
  1506. package/dist/triggers/trigger-types.js +6 -0
  1507. package/dist/triggers/trigger-types.js.map +1 -0
  1508. package/dist/types/dependencies.d.ts +85 -0
  1509. package/dist/types/dependencies.d.ts.map +1 -0
  1510. package/dist/types/dependencies.js +11 -0
  1511. package/dist/types/dependencies.js.map +1 -0
  1512. package/dist/types/skill.d.ts +133 -0
  1513. package/dist/types/skill.d.ts.map +1 -0
  1514. package/dist/types/skill.js +15 -0
  1515. package/dist/types/skill.js.map +1 -0
  1516. package/dist/types.d.ts +156 -0
  1517. package/dist/types.d.ts.map +1 -0
  1518. package/dist/types.js +14 -0
  1519. package/dist/types.js.map +1 -0
  1520. package/dist/utils/github-url.d.ts +57 -0
  1521. package/dist/utils/github-url.d.ts.map +1 -0
  1522. package/dist/utils/github-url.js +88 -0
  1523. package/dist/utils/github-url.js.map +1 -0
  1524. package/dist/utils/index.d.ts +9 -0
  1525. package/dist/utils/index.d.ts.map +1 -0
  1526. package/dist/utils/index.js +12 -0
  1527. package/dist/utils/index.js.map +1 -0
  1528. package/dist/utils/logger.d.ts +172 -0
  1529. package/dist/utils/logger.d.ts.map +1 -0
  1530. package/dist/utils/logger.js +291 -0
  1531. package/dist/utils/logger.js.map +1 -0
  1532. package/dist/utils/rate-limit.d.ts +39 -0
  1533. package/dist/utils/rate-limit.d.ts.map +1 -0
  1534. package/dist/utils/rate-limit.js +48 -0
  1535. package/dist/utils/rate-limit.js.map +1 -0
  1536. package/dist/utils/rate-limit.test.d.ts +11 -0
  1537. package/dist/utils/rate-limit.test.d.ts.map +1 -0
  1538. package/dist/utils/rate-limit.test.js +86 -0
  1539. package/dist/utils/rate-limit.test.js.map +1 -0
  1540. package/dist/utils/retry.d.ts +97 -0
  1541. package/dist/utils/retry.d.ts.map +1 -0
  1542. package/dist/utils/retry.js +267 -0
  1543. package/dist/utils/retry.js.map +1 -0
  1544. package/dist/utils/safe-fs.d.ts +63 -0
  1545. package/dist/utils/safe-fs.d.ts.map +1 -0
  1546. package/dist/utils/safe-fs.js +119 -0
  1547. package/dist/utils/safe-fs.js.map +1 -0
  1548. package/dist/utils/version-check.d.ts +41 -0
  1549. package/dist/utils/version-check.d.ts.map +1 -0
  1550. package/dist/utils/version-check.js +60 -0
  1551. package/dist/utils/version-check.js.map +1 -0
  1552. package/dist/utils/version-check.test.d.ts +2 -0
  1553. package/dist/utils/version-check.test.d.ts.map +1 -0
  1554. package/dist/utils/version-check.test.js +113 -0
  1555. package/dist/utils/version-check.test.js.map +1 -0
  1556. package/dist/validation/index.d.ts +18 -0
  1557. package/dist/validation/index.d.ts.map +1 -0
  1558. package/dist/validation/index.js +22 -0
  1559. package/dist/validation/index.js.map +1 -0
  1560. package/dist/validation/input-validators.d.ts +68 -0
  1561. package/dist/validation/input-validators.d.ts.map +1 -0
  1562. package/dist/validation/input-validators.js +133 -0
  1563. package/dist/validation/input-validators.js.map +1 -0
  1564. package/dist/validation/path-validators.d.ts +23 -0
  1565. package/dist/validation/path-validators.d.ts.map +1 -0
  1566. package/dist/validation/path-validators.js +47 -0
  1567. package/dist/validation/path-validators.js.map +1 -0
  1568. package/dist/validation/url-validators.d.ts +55 -0
  1569. package/dist/validation/url-validators.d.ts.map +1 -0
  1570. package/dist/validation/url-validators.js +267 -0
  1571. package/dist/validation/url-validators.js.map +1 -0
  1572. package/dist/validation/validation-error.d.ts +14 -0
  1573. package/dist/validation/validation-error.d.ts.map +1 -0
  1574. package/dist/validation/validation-error.js +19 -0
  1575. package/dist/validation/validation-error.js.map +1 -0
  1576. package/dist/versioning/change-classifier.d.ts +38 -0
  1577. package/dist/versioning/change-classifier.d.ts.map +1 -0
  1578. package/dist/versioning/change-classifier.js +187 -0
  1579. package/dist/versioning/change-classifier.js.map +1 -0
  1580. package/dist/versioning/change-classifier.test.d.ts +6 -0
  1581. package/dist/versioning/change-classifier.test.d.ts.map +1 -0
  1582. package/dist/versioning/change-classifier.test.js +275 -0
  1583. package/dist/versioning/change-classifier.test.js.map +1 -0
  1584. package/dist/versioning/update-risk.d.ts +50 -0
  1585. package/dist/versioning/update-risk.d.ts.map +1 -0
  1586. package/dist/versioning/update-risk.js +80 -0
  1587. package/dist/versioning/update-risk.js.map +1 -0
  1588. package/dist/versioning/update-risk.test.d.ts +6 -0
  1589. package/dist/versioning/update-risk.test.d.ts.map +1 -0
  1590. package/dist/versioning/update-risk.test.js +200 -0
  1591. package/dist/versioning/update-risk.test.js.map +1 -0
  1592. package/dist/webhooks/WebhookDeadLetterRepository.d.ts +178 -0
  1593. package/dist/webhooks/WebhookDeadLetterRepository.d.ts.map +1 -0
  1594. package/dist/webhooks/WebhookDeadLetterRepository.js +196 -0
  1595. package/dist/webhooks/WebhookDeadLetterRepository.js.map +1 -0
  1596. package/dist/webhooks/WebhookHandler.d.ts +117 -0
  1597. package/dist/webhooks/WebhookHandler.d.ts.map +1 -0
  1598. package/dist/webhooks/WebhookHandler.js +349 -0
  1599. package/dist/webhooks/WebhookHandler.js.map +1 -0
  1600. package/dist/webhooks/WebhookPayload.d.ts +27 -0
  1601. package/dist/webhooks/WebhookPayload.d.ts.map +1 -0
  1602. package/dist/webhooks/WebhookPayload.js +123 -0
  1603. package/dist/webhooks/WebhookPayload.js.map +1 -0
  1604. package/dist/webhooks/WebhookQueue.d.ts +90 -0
  1605. package/dist/webhooks/WebhookQueue.d.ts.map +1 -0
  1606. package/dist/webhooks/WebhookQueue.js +340 -0
  1607. package/dist/webhooks/WebhookQueue.js.map +1 -0
  1608. package/dist/webhooks/WebhookQueue.types.d.ts +160 -0
  1609. package/dist/webhooks/WebhookQueue.types.d.ts.map +1 -0
  1610. package/dist/webhooks/WebhookQueue.types.js +10 -0
  1611. package/dist/webhooks/WebhookQueue.types.js.map +1 -0
  1612. package/dist/webhooks/WebhookQueue.utils.d.ts +44 -0
  1613. package/dist/webhooks/WebhookQueue.utils.d.ts.map +1 -0
  1614. package/dist/webhooks/WebhookQueue.utils.js +58 -0
  1615. package/dist/webhooks/WebhookQueue.utils.js.map +1 -0
  1616. package/dist/webhooks/index.d.ts +13 -0
  1617. package/dist/webhooks/index.d.ts.map +1 -0
  1618. package/dist/webhooks/index.js +17 -0
  1619. package/dist/webhooks/index.js.map +1 -0
  1620. package/dist/webhooks/webhook-schemas.d.ts +1308 -0
  1621. package/dist/webhooks/webhook-schemas.d.ts.map +1 -0
  1622. package/dist/webhooks/webhook-schemas.js +132 -0
  1623. package/dist/webhooks/webhook-schemas.js.map +1 -0
  1624. package/dist/webhooks/webhook-types.d.ts +222 -0
  1625. package/dist/webhooks/webhook-types.d.ts.map +1 -0
  1626. package/dist/webhooks/webhook-types.js +10 -0
  1627. package/dist/webhooks/webhook-types.js.map +1 -0
  1628. package/package.json +2 -2
  1629. package/dist/src/billing/GDPRComplianceService.test.d.ts +0 -2
  1630. package/dist/src/billing/GDPRComplianceService.test.d.ts.map +0 -1
  1631. package/dist/src/billing/GDPRComplianceService.test.js +0 -405
  1632. package/dist/src/billing/GDPRComplianceService.test.js.map +0 -1
@@ -0,0 +1,218 @@
1
+ /**
2
+ * SMI-1189: Reporter
3
+ *
4
+ * Report generation and summary output.
5
+ */
6
+ import { countBySeverity } from './categorizer.js';
7
+ import { calculateAverageRiskScore, calculateMaxRiskScore, getPassFailStats, } from './trust-scorer.js';
8
+ /**
9
+ * ANSI color codes for terminal output
10
+ */
11
+ const COLORS = {
12
+ reset: '\x1b[0m',
13
+ bold: '\x1b[1m',
14
+ dim: '\x1b[2m',
15
+ red: '\x1b[31m',
16
+ green: '\x1b[32m',
17
+ yellow: '\x1b[33m',
18
+ cyan: '\x1b[36m',
19
+ magenta: '\x1b[35m',
20
+ };
21
+ /**
22
+ * Check if colors should be used
23
+ */
24
+ function useColors() {
25
+ return process.stdout.isTTY && !process.env.CI && !process.env.NO_COLOR;
26
+ }
27
+ /**
28
+ * Apply color to text if colors are enabled
29
+ */
30
+ function colorize(text, color) {
31
+ return useColors() ? `${COLORS[color]}${text}${COLORS.reset}` : text;
32
+ }
33
+ /**
34
+ * Create a visual bar for statistics
35
+ */
36
+ function createStatBar(value, total, width = 20) {
37
+ const percentage = total > 0 ? value / total : 0;
38
+ const filled = Math.round(width * percentage);
39
+ const bar = '█'.repeat(filled) + '░'.repeat(width - filled);
40
+ return bar;
41
+ }
42
+ /**
43
+ * Log summary statistics to console with improved formatting
44
+ *
45
+ * @param results - Array of scan results
46
+ */
47
+ export function logSummary(results) {
48
+ const total = results.length;
49
+ const { passed, quarantined } = getPassFailStats(results);
50
+ const bySeverity = countBySeverity(results);
51
+ const avgRiskScore = calculateAverageRiskScore(results);
52
+ const maxRiskScore = calculateMaxRiskScore(results);
53
+ const border = '═'.repeat(60);
54
+ const thinBorder = '─'.repeat(60);
55
+ console.log();
56
+ console.log(colorize(border, 'cyan'));
57
+ console.log(colorize(' SCAN SUMMARY', 'bold'));
58
+ console.log(colorize(border, 'cyan'));
59
+ console.log();
60
+ // Main stats with visual bars
61
+ const passedPct = total > 0 ? ((passed / total) * 100).toFixed(1) : '0.0';
62
+ const quarantinedPct = total > 0 ? ((quarantined / total) * 100).toFixed(1) : '0.0';
63
+ console.log(` ${colorize('Total Skills Scanned:', 'bold')} ${total}`);
64
+ console.log();
65
+ console.log(` ${colorize('Safe (Passed):', 'green')} ${passed.toString().padStart(4)} ${createStatBar(passed, total)} ${passedPct}%`);
66
+ console.log(` ${colorize('Quarantined:', 'red')} ${quarantined.toString().padStart(4)} ${createStatBar(quarantined, total)} ${quarantinedPct}%`);
67
+ console.log();
68
+ console.log(colorize(thinBorder, 'dim'));
69
+ console.log();
70
+ // Severity breakdown
71
+ console.log(` ${colorize('By Severity:', 'bold')}`);
72
+ console.log();
73
+ console.log(` ${colorize('CRITICAL:', 'red')} ${bySeverity.CRITICAL.toString().padStart(4)} ${createStatBar(bySeverity.CRITICAL, total, 15)}`);
74
+ console.log(` ${colorize('HIGH:', 'magenta')} ${bySeverity.HIGH.toString().padStart(4)} ${createStatBar(bySeverity.HIGH, total, 15)}`);
75
+ console.log(` ${colorize('MEDIUM:', 'yellow')} ${bySeverity.MEDIUM.toString().padStart(4)} ${createStatBar(bySeverity.MEDIUM, total, 15)}`);
76
+ console.log(` ${colorize('LOW:', 'cyan')} ${bySeverity.LOW.toString().padStart(4)} ${createStatBar(bySeverity.LOW, total, 15)}`);
77
+ console.log();
78
+ console.log(colorize(thinBorder, 'dim'));
79
+ console.log();
80
+ // Risk score stats
81
+ console.log(` ${colorize('Risk Scores:', 'bold')}`);
82
+ console.log(` Average: ${avgRiskScore.toFixed(1)}`);
83
+ console.log(` Maximum: ${maxRiskScore}`);
84
+ console.log();
85
+ console.log(colorize(border, 'cyan'));
86
+ console.log();
87
+ }
88
+ /**
89
+ * Calculate top findings by type
90
+ *
91
+ * @param findings - Array of findings with context
92
+ * @param limit - Maximum number of top findings to return
93
+ * @returns Array of top findings with counts
94
+ */
95
+ export function calculateTopFindings(findings, limit = 10) {
96
+ const findingCounts = new Map();
97
+ for (const finding of findings) {
98
+ const existing = findingCounts.get(finding.type);
99
+ if (existing) {
100
+ existing.count++;
101
+ // Keep the highest severity seen for this type
102
+ if (finding.severity === 'critical' ||
103
+ (finding.severity === 'high' && existing.severity !== 'critical') ||
104
+ (finding.severity === 'medium' &&
105
+ existing.severity !== 'critical' &&
106
+ existing.severity !== 'high')) {
107
+ existing.severity = finding.severity;
108
+ }
109
+ }
110
+ else {
111
+ findingCounts.set(finding.type, { count: 1, severity: finding.severity });
112
+ }
113
+ }
114
+ return Array.from(findingCounts.entries())
115
+ .map(([type, data]) => ({ type, count: data.count, severity: data.severity }))
116
+ .sort((a, b) => b.count - a.count)
117
+ .slice(0, limit);
118
+ }
119
+ /**
120
+ * Generate the full security report
121
+ *
122
+ * @param results - Array of scan results
123
+ * @param findings - Array of findings with context
124
+ * @param inputPath - Path to the input file
125
+ * @returns SecurityReportOutput object
126
+ */
127
+ export function generateSecurityReport(results, findings, inputPath) {
128
+ const total = results.length;
129
+ const { passed, quarantined } = getPassFailStats(results);
130
+ const bySeverity = countBySeverity(results);
131
+ const avgRiskScore = calculateAverageRiskScore(results);
132
+ const maxRiskScore = calculateMaxRiskScore(results);
133
+ const topFindings = calculateTopFindings(findings);
134
+ return {
135
+ scanDate: new Date().toISOString(),
136
+ inputFile: inputPath,
137
+ summary: {
138
+ totalScanned: total,
139
+ passed,
140
+ quarantined,
141
+ bySeverity,
142
+ averageRiskScore: Math.round(avgRiskScore * 100) / 100,
143
+ maxRiskScore,
144
+ },
145
+ results,
146
+ topFindings,
147
+ };
148
+ }
149
+ /**
150
+ * Generate the quarantine output
151
+ *
152
+ * @param results - Array of quarantined scan results
153
+ * @returns QuarantineOutput object
154
+ */
155
+ export function generateQuarantineOutput(results) {
156
+ const quarantinedSkills = results.filter((r) => r.isQuarantined);
157
+ return {
158
+ generatedAt: new Date().toISOString(),
159
+ reason: 'Skills with HIGH or CRITICAL security findings, or risk score >= 40',
160
+ count: quarantinedSkills.length,
161
+ skills: quarantinedSkills.map((r) => ({
162
+ skillId: r.skillId,
163
+ skillName: r.skillName,
164
+ author: r.author,
165
+ riskScore: r.scanReport.riskScore,
166
+ severityCategory: r.severityCategory,
167
+ topFindings: r.scanReport.findings
168
+ .filter((f) => f.severity === 'critical' || f.severity === 'high')
169
+ .slice(0, 5)
170
+ .map((f) => `${f.type}: ${f.message}`),
171
+ })),
172
+ };
173
+ }
174
+ /**
175
+ * Generate the safe skills output
176
+ *
177
+ * @param results - Array of scan results
178
+ * @returns SafeSkillsOutput object
179
+ */
180
+ export function generateSafeSkillsOutput(results) {
181
+ const safeSkills = results.filter((r) => !r.isQuarantined);
182
+ return {
183
+ generatedAt: new Date().toISOString(),
184
+ count: safeSkills.length,
185
+ skills: safeSkills.map((r) => ({
186
+ skillId: r.skillId,
187
+ skillName: r.skillName,
188
+ author: r.author,
189
+ source: r.source,
190
+ riskScore: r.scanReport.riskScore,
191
+ })),
192
+ };
193
+ }
194
+ /**
195
+ * Log recommendations based on scan results
196
+ *
197
+ * @param results - Array of scan results
198
+ * @param criticalCount - Number of critical findings
199
+ */
200
+ export function logRecommendations(results, criticalCount) {
201
+ const { passed, quarantined } = getPassFailStats(results);
202
+ console.log('RECOMMENDATIONS:');
203
+ if (quarantined > 0) {
204
+ console.log(` - ${quarantined} skills have been quarantined`);
205
+ console.log(' - Review quarantine-skills.json for manual triage');
206
+ console.log(' - Critical/high findings require security review before import');
207
+ }
208
+ if (criticalCount > 0) {
209
+ console.log(` - ${criticalCount} CRITICAL findings detected`);
210
+ console.log(' - These skills should NOT be imported without thorough review');
211
+ }
212
+ if (passed > 0) {
213
+ console.log(` - ${passed} skills passed security checks`);
214
+ console.log(' - These are ready for import from safe-skills.json');
215
+ }
216
+ console.log();
217
+ }
218
+ //# sourceMappingURL=reporter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reporter.js","sourceRoot":"","sources":["../../../src/scripts/skill-scanner/reporter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,55 @@
1
+ /**
2
+ * SMI-1189: Scanner
3
+ *
4
+ * Main scanning logic for imported skills.
5
+ */
6
+ import { SecurityScanner } from '../../security/index.js';
7
+ import type { AllowlistMatcher, ImportedSkill, SkillScanResult, ScannerCliOptions } from './types.js';
8
+ import { type TrustScorerConfig } from './trust-scorer.js';
9
+ /**
10
+ * Scanner configuration
11
+ */
12
+ export interface ScannerConfig {
13
+ /** Default input file path */
14
+ defaultInput: string;
15
+ /** Output directory for reports */
16
+ outputDir: string;
17
+ /** Scanner options */
18
+ scannerOptions: {
19
+ riskThreshold: number;
20
+ };
21
+ /** Trust scorer config */
22
+ trustConfig: TrustScorerConfig;
23
+ /** Progress logging interval */
24
+ progressInterval: number;
25
+ /** SMI-4396: Path to the version-controlled allowlist file. */
26
+ allowlistPath: string;
27
+ }
28
+ /** Default scanner configuration */
29
+ export declare const DEFAULT_CONFIG: ScannerConfig;
30
+ /**
31
+ * Scan a single skill and return the result
32
+ *
33
+ * SMI-4396: accepts an optional AllowlistMatcher. Findings whose
34
+ * (skillId, type, message/location) match a non-expired allowlist entry are
35
+ * excluded from the quarantine decision. severityCategory still reflects
36
+ * the raw findings so the security report preserves audit visibility.
37
+ *
38
+ * @param skill - The skill to scan
39
+ * @param scanner - The security scanner instance
40
+ * @param config - Trust scorer configuration
41
+ * @param allowlist - Optional per-skill allowlist (SMI-4396)
42
+ * @returns The scan result
43
+ */
44
+ export declare function scanSkill(skill: ImportedSkill, scanner: SecurityScanner, config?: TrustScorerConfig, allowlist?: AllowlistMatcher): SkillScanResult;
45
+ /** Default CLI options */
46
+ export declare const DEFAULT_CLI_OPTIONS: ScannerCliOptions;
47
+ /**
48
+ * Scan all imported skills
49
+ *
50
+ * @param inputPath - Path to the imported skills JSON file
51
+ * @param config - Scanner configuration
52
+ * @param cliOptions - CLI options for output control
53
+ */
54
+ export declare function scanImportedSkills(inputPath: string, config?: ScannerConfig, cliOptions?: Partial<ScannerCliOptions>): Promise<void>;
55
+ //# sourceMappingURL=scanner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../../../src/scripts/skill-scanner/scanner.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AACzD,OAAO,KAAK,EACV,gBAAgB,EAChB,aAAa,EACb,eAAe,EAEf,iBAAiB,EAElB,MAAM,YAAY,CAAA;AAEnB,OAAO,EAKL,KAAK,iBAAiB,EAEvB,MAAM,mBAAmB,CAAA;AA8B1B;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,8BAA8B;IAC9B,YAAY,EAAE,MAAM,CAAA;IACpB,mCAAmC;IACnC,SAAS,EAAE,MAAM,CAAA;IACjB,sBAAsB;IACtB,cAAc,EAAE;QACd,aAAa,EAAE,MAAM,CAAA;KACtB,CAAA;IACD,0BAA0B;IAC1B,WAAW,EAAE,iBAAiB,CAAA;IAC9B,gCAAgC;IAChC,gBAAgB,EAAE,MAAM,CAAA;IACxB,+DAA+D;IAC/D,aAAa,EAAE,MAAM,CAAA;CACtB;AAED,oCAAoC;AACpC,eAAO,MAAM,cAAc,EAAE,aAS5B,CAAA;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,SAAS,CACvB,KAAK,EAAE,aAAa,EACpB,OAAO,EAAE,eAAe,EACxB,MAAM,GAAE,iBAAwC,EAChD,SAAS,GAAE,gBAAkC,GAC5C,eAAe,CAgBjB;AAED,0BAA0B;AAC1B,eAAO,MAAM,mBAAmB,EAAE,iBAKjC,CAAA;AA0DD;;;;;;GAMG;AACH,wBAAsB,kBAAkB,CACtC,SAAS,EAAE,MAAM,EACjB,MAAM,GAAE,aAA8B,EACtC,UAAU,GAAE,OAAO,CAAC,iBAAiB,CAAM,GAC1C,OAAO,CAAC,IAAI,CAAC,CAmLf"}
@@ -0,0 +1,269 @@
1
+ /**
2
+ * SMI-1189: Scanner
3
+ *
4
+ * Main scanning logic for imported skills.
5
+ */
6
+ import * as path from 'path';
7
+ import { SecurityScanner } from '../../security/index.js';
8
+ import { EMPTY_ALLOWLIST, loadAllowlist } from './allowlist.js';
9
+ import { shouldQuarantine, getPassFailStats, calculateAverageRiskScore, calculateMaxRiskScore, DEFAULT_TRUST_CONFIG, } from './trust-scorer.js';
10
+ import { determineSeverityCategory, countBySeverity } from './categorizer.js';
11
+ import { extractScannableContent, readImportedSkills, ensureDirectoryExists, fileExists, writeJsonFile, } from './file-scanner.js';
12
+ import { formatDuration, logHeader, logFindings, logProgress, logCompletion, logFileOutput, logScanStart, logProgressBar, clearProgressLine, logQuarantineTable, logCategorizedResults, } from './logger.js';
13
+ import { logSummary, generateSecurityReport, generateQuarantineOutput, generateSafeSkillsOutput, logRecommendations, } from './reporter.js';
14
+ /** Default scanner configuration */
15
+ export const DEFAULT_CONFIG = {
16
+ defaultInput: './data/imported-skills.json',
17
+ outputDir: './data',
18
+ scannerOptions: {
19
+ riskThreshold: 40,
20
+ },
21
+ trustConfig: DEFAULT_TRUST_CONFIG,
22
+ progressInterval: 100,
23
+ allowlistPath: './data/skills-security-allowlist.json',
24
+ };
25
+ /**
26
+ * Scan a single skill and return the result
27
+ *
28
+ * SMI-4396: accepts an optional AllowlistMatcher. Findings whose
29
+ * (skillId, type, message/location) match a non-expired allowlist entry are
30
+ * excluded from the quarantine decision. severityCategory still reflects
31
+ * the raw findings so the security report preserves audit visibility.
32
+ *
33
+ * @param skill - The skill to scan
34
+ * @param scanner - The security scanner instance
35
+ * @param config - Trust scorer configuration
36
+ * @param allowlist - Optional per-skill allowlist (SMI-4396)
37
+ * @returns The scan result
38
+ */
39
+ export function scanSkill(skill, scanner, config = DEFAULT_TRUST_CONFIG, allowlist = EMPTY_ALLOWLIST) {
40
+ const content = extractScannableContent(skill);
41
+ const report = scanner.scan(skill.id, content);
42
+ const isQuarantined = shouldQuarantine(report, config, allowlist);
43
+ const severityCategory = determineSeverityCategory(report.findings);
44
+ return {
45
+ skillId: skill.id,
46
+ skillName: skill.name,
47
+ author: skill.author || 'unknown',
48
+ source: skill.source || 'unknown',
49
+ scanReport: report,
50
+ severityCategory,
51
+ isQuarantined,
52
+ scanTimestamp: new Date().toISOString(),
53
+ };
54
+ }
55
+ /** Default CLI options */
56
+ export const DEFAULT_CLI_OPTIONS = {
57
+ json: false,
58
+ verbose: false,
59
+ quiet: false,
60
+ inputPath: DEFAULT_CONFIG.defaultInput,
61
+ };
62
+ /**
63
+ * Generate JSON output for machine-readable format
64
+ */
65
+ function generateJsonOutput(results, config, durationMs) {
66
+ const { passed, quarantined: quarantinedCount } = getPassFailStats(results);
67
+ const bySeverity = countBySeverity(results);
68
+ const avgRiskScore = calculateAverageRiskScore(results);
69
+ const maxRiskScore = calculateMaxRiskScore(results);
70
+ const quarantinedSkills = results
71
+ .filter((r) => r.isQuarantined)
72
+ .sort((a, b) => b.scanReport.riskScore - a.scanReport.riskScore)
73
+ .map((r) => ({
74
+ skillId: r.skillId,
75
+ riskScore: r.scanReport.riskScore,
76
+ severity: r.severityCategory,
77
+ topFinding: r.scanReport.findings.length > 0
78
+ ? `${r.scanReport.findings[0].type}: ${r.scanReport.findings[0].message}`
79
+ : 'N/A',
80
+ }));
81
+ const safeSkills = results
82
+ .filter((r) => !r.isQuarantined)
83
+ .sort((a, b) => a.scanReport.riskScore - b.scanReport.riskScore)
84
+ .map((r) => ({
85
+ skillId: r.skillId,
86
+ riskScore: r.scanReport.riskScore,
87
+ }));
88
+ return {
89
+ success: true,
90
+ summary: {
91
+ totalScanned: results.length,
92
+ passed,
93
+ quarantined: quarantinedCount,
94
+ bySeverity,
95
+ averageRiskScore: Math.round(avgRiskScore * 100) / 100,
96
+ maxRiskScore,
97
+ duration: Math.round(durationMs),
98
+ skillsPerSecond: Math.round((results.length / durationMs) * 1000 * 10) / 10,
99
+ },
100
+ quarantined: quarantinedSkills,
101
+ safe: safeSkills,
102
+ outputFiles: {
103
+ report: path.join(config.outputDir, 'security-report.json'),
104
+ quarantine: path.join(config.outputDir, 'quarantine-skills.json'),
105
+ safe: path.join(config.outputDir, 'safe-skills.json'),
106
+ },
107
+ };
108
+ }
109
+ /**
110
+ * Scan all imported skills
111
+ *
112
+ * @param inputPath - Path to the imported skills JSON file
113
+ * @param config - Scanner configuration
114
+ * @param cliOptions - CLI options for output control
115
+ */
116
+ export async function scanImportedSkills(inputPath, config = DEFAULT_CONFIG, cliOptions = {}) {
117
+ const options = { ...DEFAULT_CLI_OPTIONS, ...cliOptions, inputPath };
118
+ const startTime = performance.now();
119
+ // Validate input file exists (always check, regardless of output mode)
120
+ if (!fileExists(inputPath)) {
121
+ if (options.json) {
122
+ console.log(JSON.stringify({ success: false, error: `Input file not found: ${inputPath}` }));
123
+ }
124
+ else {
125
+ console.error(`Error: Input file not found: ${inputPath}`);
126
+ console.error('Usage: npx tsx packages/core/src/scripts/scan-imported-skills.ts [options] [path-to-imported-skills.json]');
127
+ console.error('\nOptions:');
128
+ console.error(' --json Output results in JSON format (machine-readable)');
129
+ console.error(' --verbose Show detailed output');
130
+ console.error(' --quiet Minimal output');
131
+ }
132
+ process.exit(1);
133
+ }
134
+ // Ensure output directory exists
135
+ ensureDirectoryExists(config.outputDir);
136
+ // Read and parse imported skills
137
+ let skills;
138
+ try {
139
+ skills = await readImportedSkills(inputPath);
140
+ }
141
+ catch (error) {
142
+ if (options.json) {
143
+ console.log(JSON.stringify({
144
+ success: false,
145
+ error: `Failed to read input: ${error.message}`,
146
+ }));
147
+ }
148
+ else {
149
+ console.error(`Error reading/parsing input file: ${error.message}`);
150
+ }
151
+ process.exit(1);
152
+ }
153
+ // For JSON output, skip all console logging until the end
154
+ if (!options.json && !options.quiet) {
155
+ logScanStart(skills.length, inputPath, config.outputDir);
156
+ }
157
+ // Initialize scanner
158
+ const scanner = new SecurityScanner(config.scannerOptions);
159
+ // SMI-4396: Load the security allowlist (returns EMPTY_ALLOWLIST if the file
160
+ // doesn't exist, so pre-SMI-4396 environments keep working). A malformed
161
+ // file throws — fail-safe toward quarantine, never silently proceed.
162
+ const allowlist = loadAllowlist(config.allowlistPath);
163
+ // Scan all skills
164
+ const results = [];
165
+ const allFindings = [];
166
+ let processedCount = 0;
167
+ // Use progress bar for interactive output
168
+ const useProgressBar = !options.json && !options.quiet && process.stdout.isTTY;
169
+ for (const skill of skills) {
170
+ processedCount++;
171
+ const result = scanSkill(skill, scanner, config.trustConfig, allowlist);
172
+ results.push(result);
173
+ // Collect findings with skill context
174
+ for (const finding of result.scanReport.findings) {
175
+ allFindings.push({ ...finding, skillId: skill.id });
176
+ }
177
+ // Log progress
178
+ if (useProgressBar) {
179
+ logProgressBar(processedCount, skills.length, true);
180
+ }
181
+ else if (!options.json && !options.quiet && processedCount % config.progressInterval === 0) {
182
+ logProgress(processedCount, skills.length);
183
+ }
184
+ }
185
+ // Clear progress bar line
186
+ if (useProgressBar) {
187
+ clearProgressLine();
188
+ }
189
+ if (!options.json && !options.quiet) {
190
+ logCompletion(processedCount, skills.length);
191
+ }
192
+ // Log critical and high findings (if not JSON mode)
193
+ const criticalFindings = allFindings.filter((f) => f.severity === 'critical');
194
+ const highFindings = allFindings.filter((f) => f.severity === 'high');
195
+ if (!options.json && !options.quiet) {
196
+ logFindings(criticalFindings, 20, 'CRITICAL FINDINGS');
197
+ logFindings(highFindings, 10, 'HIGH SEVERITY FINDINGS');
198
+ }
199
+ // Print categorized results
200
+ if (!options.json && !options.quiet) {
201
+ logCategorizedResults(results);
202
+ }
203
+ // Print quarantine table (if not JSON mode)
204
+ if (!options.json && !options.quiet) {
205
+ logHeader('QUARANTINED SKILLS');
206
+ logQuarantineTable(results);
207
+ }
208
+ // Print summary
209
+ if (!options.json && !options.quiet) {
210
+ logSummary(results);
211
+ }
212
+ // Generate output files
213
+ if (!options.json && !options.quiet) {
214
+ console.log('Generating output files...\n');
215
+ }
216
+ // 1. Full security report
217
+ const securityReport = generateSecurityReport(results, allFindings, inputPath);
218
+ const reportPath = path.join(config.outputDir, 'security-report.json');
219
+ await writeJsonFile(reportPath, securityReport);
220
+ if (!options.json && !options.quiet) {
221
+ logFileOutput('security-report.json', results.length);
222
+ }
223
+ // 2. Quarantine list
224
+ const quarantineOutput = generateQuarantineOutput(results);
225
+ const quarantinePath = path.join(config.outputDir, 'quarantine-skills.json');
226
+ await writeJsonFile(quarantinePath, quarantineOutput);
227
+ if (!options.json && !options.quiet) {
228
+ logFileOutput('quarantine-skills.json', quarantineOutput.count, 'blocked');
229
+ }
230
+ // 3. Safe skills list
231
+ const safeOutput = generateSafeSkillsOutput(results);
232
+ const safePath = path.join(config.outputDir, 'safe-skills.json');
233
+ await writeJsonFile(safePath, safeOutput);
234
+ if (!options.json && !options.quiet) {
235
+ logFileOutput('safe-skills.json', safeOutput.count, 'approved');
236
+ }
237
+ // Final timing
238
+ const endTime = performance.now();
239
+ const durationMs = endTime - startTime;
240
+ const duration = formatDuration(durationMs);
241
+ // JSON output mode
242
+ if (options.json) {
243
+ const jsonOutput = generateJsonOutput(results, config, durationMs);
244
+ console.log(JSON.stringify(jsonOutput, null, 2));
245
+ return;
246
+ }
247
+ // Human-readable completion output
248
+ if (!options.quiet) {
249
+ const border = '═'.repeat(60);
250
+ console.log();
251
+ console.log('\x1b[36m' + border + '\x1b[0m');
252
+ console.log('\x1b[1m SCAN COMPLETE\x1b[0m');
253
+ console.log('\x1b[36m' + border + '\x1b[0m');
254
+ console.log();
255
+ console.log(` Duration: ${duration}`);
256
+ console.log(` Skills per second: ${((results.length / durationMs) * 1000).toFixed(1)}`);
257
+ console.log();
258
+ console.log(' Output files:');
259
+ console.log(` - ${reportPath}`);
260
+ console.log(` - ${quarantinePath}`);
261
+ console.log(` - ${safePath}`);
262
+ console.log();
263
+ console.log('\x1b[36m' + border + '\x1b[0m');
264
+ console.log();
265
+ // Recommendations
266
+ logRecommendations(results, criticalFindings.length);
267
+ }
268
+ }
269
+ //# sourceMappingURL=scanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanner.js","sourceRoot":"","sources":["../../../src/scripts/skill-scanner/scanner.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,IAAI,MAAM,MAAM,CAAA;AAC5B,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AASzD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAC/D,OAAO,EACL,gBAAgB,EAChB,gBAAgB,EAChB,yBAAyB,EACzB,qBAAqB,EAErB,oBAAoB,GACrB,MAAM,mBAAmB,CAAA;AAC1B,OAAO,EAAE,yBAAyB,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAC7E,OAAO,EACL,uBAAuB,EACvB,kBAAkB,EAClB,qBAAqB,EACrB,UAAU,EACV,aAAa,GACd,MAAM,mBAAmB,CAAA;AAC1B,OAAO,EACL,cAAc,EACd,SAAS,EACT,WAAW,EACX,WAAW,EACX,aAAa,EACb,aAAa,EACb,YAAY,EACZ,cAAc,EACd,iBAAiB,EACjB,kBAAkB,EAClB,qBAAqB,GACtB,MAAM,aAAa,CAAA;AACpB,OAAO,EACL,UAAU,EACV,sBAAsB,EACtB,wBAAwB,EACxB,wBAAwB,EACxB,kBAAkB,GACnB,MAAM,eAAe,CAAA;AAsBtB,oCAAoC;AACpC,MAAM,CAAC,MAAM,cAAc,GAAkB;IAC3C,YAAY,EAAE,6BAA6B;IAC3C,SAAS,EAAE,QAAQ;IACnB,cAAc,EAAE;QACd,aAAa,EAAE,EAAE;KAClB;IACD,WAAW,EAAE,oBAAoB;IACjC,gBAAgB,EAAE,GAAG;IACrB,aAAa,EAAE,uCAAuC;CACvD,CAAA;AAED;;;;;;;;;;;;;GAaG;AACH,MAAM,UAAU,SAAS,CACvB,KAAoB,EACpB,OAAwB,EACxB,SAA4B,oBAAoB,EAChD,YAA8B,eAAe;IAE7C,MAAM,OAAO,GAAG,uBAAuB,CAAC,KAAK,CAAC,CAAA;IAC9C,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;IAC9C,MAAM,aAAa,GAAG,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,CAAA;IACjE,MAAM,gBAAgB,GAAG,yBAAyB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAEnE,OAAO;QACL,OAAO,EAAE,KAAK,CAAC,EAAE;QACjB,SAAS,EAAE,KAAK,CAAC,IAAI;QACrB,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,SAAS;QACjC,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,SAAS;QACjC,UAAU,EAAE,MAAM;QAClB,gBAAgB;QAChB,aAAa;QACb,aAAa,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACxC,CAAA;AACH,CAAC;AAED,0BAA0B;AAC1B,MAAM,CAAC,MAAM,mBAAmB,GAAsB;IACpD,IAAI,EAAE,KAAK;IACX,OAAO,EAAE,KAAK;IACd,KAAK,EAAE,KAAK;IACZ,SAAS,EAAE,cAAc,CAAC,YAAY;CACvC,CAAA;AAED;;GAEG;AACH,SAAS,kBAAkB,CACzB,OAA0B,EAC1B,MAAqB,EACrB,UAAkB;IAElB,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAA;IAC3E,MAAM,UAAU,GAAG,eAAe,CAAC,OAAO,CAAC,CAAA;IAC3C,MAAM,YAAY,GAAG,yBAAyB,CAAC,OAAO,CAAC,CAAA;IACvD,MAAM,YAAY,GAAG,qBAAqB,CAAC,OAAO,CAAC,CAAA;IAEnD,MAAM,iBAAiB,GAAG,OAAO;SAC9B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC;SAC9B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,GAAG,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC;SAC/D,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACX,OAAO,EAAE,CAAC,CAAC,OAAO;QAClB,SAAS,EAAE,CAAC,CAAC,UAAU,CAAC,SAAS;QACjC,QAAQ,EAAE,CAAC,CAAC,gBAAgB;QAC5B,UAAU,EACR,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;YAC9B,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE;YACzE,CAAC,CAAC,KAAK;KACZ,CAAC,CAAC,CAAA;IAEL,MAAM,UAAU,GAAG,OAAO;SACvB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;SAC/B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,GAAG,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC;SAC/D,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACX,OAAO,EAAE,CAAC,CAAC,OAAO;QAClB,SAAS,EAAE,CAAC,CAAC,UAAU,CAAC,SAAS;KAClC,CAAC,CAAC,CAAA;IAEL,OAAO;QACL,OAAO,EAAE,IAAI;QACb,OAAO,EAAE;YACP,YAAY,EAAE,OAAO,CAAC,MAAM;YAC5B,MAAM;YACN,WAAW,EAAE,gBAAgB;YAC7B,UAAU;YACV,gBAAgB,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,GAAG,CAAC,GAAG,GAAG;YACtD,YAAY;YACZ,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC;YAChC,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC,GAAG,IAAI,GAAG,EAAE,CAAC,GAAG,EAAE;SAC5E;QACD,WAAW,EAAE,iBAAiB;QAC9B,IAAI,EAAE,UAAU;QAChB,WAAW,EAAE;YACX,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,sBAAsB,CAAC;YAC3D,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,wBAAwB,CAAC;YACjE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,kBAAkB,CAAC;SACtD;KACF,CAAA;AACH,CAAC;AAED;;;;;;GAMG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,SAAiB,EACjB,SAAwB,cAAc,EACtC,aAAyC,EAAE;IAE3C,MAAM,OAAO,GAAG,EAAE,GAAG,mBAAmB,EAAE,GAAG,UAAU,EAAE,SAAS,EAAE,CAAA;IACpE,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE,CAAA;IAEnC,uEAAuE;IACvE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QAC3B,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,yBAAyB,SAAS,EAAE,EAAE,CAAC,CAAC,CAAA;QAC9F,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,gCAAgC,SAAS,EAAE,CAAC,CAAA;YAC1D,OAAO,CAAC,KAAK,CACX,2GAA2G,CAC5G,CAAA;YACD,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;YAC3B,OAAO,CAAC,KAAK,CAAC,gEAAgE,CAAC,CAAA;YAC/E,OAAO,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAA;YACnD,OAAO,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAA;QAC/C,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;IAED,iCAAiC;IACjC,qBAAqB,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;IAEvC,iCAAiC;IACjC,IAAI,MAAuB,CAAA;IAC3B,IAAI,CAAC;QACH,MAAM,GAAG,MAAM,kBAAkB,CAAC,SAAS,CAAC,CAAA;IAC9C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CACT,IAAI,CAAC,SAAS,CAAC;gBACb,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,yBAA0B,KAAe,CAAC,OAAO,EAAE;aAC3D,CAAC,CACH,CAAA;QACH,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,qCAAsC,KAAe,CAAC,OAAO,EAAE,CAAC,CAAA;QAChF,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;IAED,0DAA0D;IAC1D,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,YAAY,CAAC,MAAM,CAAC,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,CAAC,CAAA;IAC1D,CAAC;IAED,qBAAqB;IACrB,MAAM,OAAO,GAAG,IAAI,eAAe,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;IAE1D,6EAA6E;IAC7E,yEAAyE;IACzE,qEAAqE;IACrE,MAAM,SAAS,GAAG,aAAa,CAAC,MAAM,CAAC,aAAa,CAAC,CAAA;IAErD,kBAAkB;IAClB,MAAM,OAAO,GAAsB,EAAE,CAAA;IACrC,MAAM,WAAW,GAAyB,EAAE,CAAA;IAC5C,IAAI,cAAc,GAAG,CAAC,CAAA;IAEtB,0CAA0C;IAC1C,MAAM,cAAc,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,CAAA;IAE9E,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,cAAc,EAAE,CAAA;QAEhB,MAAM,MAAM,GAAG,SAAS,CAAC,KAAK,EAAE,OAAO,EAAE,MAAM,CAAC,WAAW,EAAE,SAAS,CAAC,CAAA;QACvE,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAEpB,sCAAsC;QACtC,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;YACjD,WAAW,CAAC,IAAI,CAAC,EAAE,GAAG,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAA;QACrD,CAAC;QAED,eAAe;QACf,IAAI,cAAc,EAAE,CAAC;YACnB,cAAc,CAAC,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;QACrD,CAAC;aAAM,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,cAAc,GAAG,MAAM,CAAC,gBAAgB,KAAK,CAAC,EAAE,CAAC;YAC7F,WAAW,CAAC,cAAc,EAAE,MAAM,CAAC,MAAM,CAAC,CAAA;QAC5C,CAAC;IACH,CAAC;IAED,0BAA0B;IAC1B,IAAI,cAAc,EAAE,CAAC;QACnB,iBAAiB,EAAE,CAAA;IACrB,CAAC;IAED,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,aAAa,CAAC,cAAc,EAAE,MAAM,CAAC,MAAM,CAAC,CAAA;IAC9C,CAAC;IAED,oDAAoD;IACpD,MAAM,gBAAgB,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAA;IAC7E,MAAM,YAAY,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAA;IAErE,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,WAAW,CAAC,gBAAgB,EAAE,EAAE,EAAE,mBAAmB,CAAC,CAAA;QACtD,WAAW,CAAC,YAAY,EAAE,EAAE,EAAE,wBAAwB,CAAC,CAAA;IACzD,CAAC;IAED,4BAA4B;IAC5B,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,qBAAqB,CAAC,OAAO,CAAC,CAAA;IAChC,CAAC;IAED,4CAA4C;IAC5C,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,SAAS,CAAC,oBAAoB,CAAC,CAAA;QAC/B,kBAAkB,CAAC,OAAO,CAAC,CAAA;IAC7B,CAAC;IAED,gBAAgB;IAChB,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,UAAU,CAAC,OAAO,CAAC,CAAA;IACrB,CAAC;IAED,wBAAwB;IACxB,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,OAAO,CAAC,GAAG,CAAC,8BAA8B,CAAC,CAAA;IAC7C,CAAC;IAED,0BAA0B;IAC1B,MAAM,cAAc,GAAG,sBAAsB,CAAC,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,CAAA;IAC9E,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,sBAAsB,CAAC,CAAA;IACtE,MAAM,aAAa,CAAC,UAAU,EAAE,cAAc,CAAC,CAAA;IAC/C,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,aAAa,CAAC,sBAAsB,EAAE,OAAO,CAAC,MAAM,CAAC,CAAA;IACvD,CAAC;IAED,qBAAqB;IACrB,MAAM,gBAAgB,GAAG,wBAAwB,CAAC,OAAO,CAAC,CAAA;IAC1D,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,wBAAwB,CAAC,CAAA;IAC5E,MAAM,aAAa,CAAC,cAAc,EAAE,gBAAgB,CAAC,CAAA;IACrD,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,aAAa,CAAC,wBAAwB,EAAE,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;IAC5E,CAAC;IAED,sBAAsB;IACtB,MAAM,UAAU,GAAG,wBAAwB,CAAC,OAAO,CAAC,CAAA;IACpD,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,kBAAkB,CAAC,CAAA;IAChE,MAAM,aAAa,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAA;IACzC,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACpC,aAAa,CAAC,kBAAkB,EAAE,UAAU,CAAC,KAAK,EAAE,UAAU,CAAC,CAAA;IACjE,CAAC;IAED,eAAe;IACf,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE,CAAA;IACjC,MAAM,UAAU,GAAG,OAAO,GAAG,SAAS,CAAA;IACtC,MAAM,QAAQ,GAAG,cAAc,CAAC,UAAU,CAAC,CAAA;IAE3C,mBAAmB;IACnB,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,MAAM,UAAU,GAAG,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,CAAA;QAClE,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;QAChD,OAAM;IACR,CAAC;IAED,mCAAmC;IACnC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACnB,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;QAC7B,OAAO,CAAC,GAAG,EAAE,CAAA;QACb,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,MAAM,GAAG,SAAS,CAAC,CAAA;QAC5C,OAAO,CAAC,GAAG,CAAC,iDAAiD,CAAC,CAAA;QAC9D,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,MAAM,GAAG,SAAS,CAAC,CAAA;QAC5C,OAAO,CAAC,GAAG,EAAE,CAAA;QACb,OAAO,CAAC,GAAG,CAAC,4BAA4B,QAAQ,EAAE,CAAC,CAAA;QACnD,OAAO,CAAC,GAAG,CAAC,4BAA4B,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;QAC5F,OAAO,CAAC,GAAG,EAAE,CAAA;QACb,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAA;QAC9B,OAAO,CAAC,GAAG,CAAC,SAAS,UAAU,EAAE,CAAC,CAAA;QAClC,OAAO,CAAC,GAAG,CAAC,SAAS,cAAc,EAAE,CAAC,CAAA;QACtC,OAAO,CAAC,GAAG,CAAC,SAAS,QAAQ,EAAE,CAAC,CAAA;QAChC,OAAO,CAAC,GAAG,EAAE,CAAA;QACb,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,MAAM,GAAG,SAAS,CAAC,CAAA;QAC5C,OAAO,CAAC,GAAG,EAAE,CAAA;QAEb,kBAAkB;QAClB,kBAAkB,CAAC,OAAO,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAA;IACtD,CAAC;AACH,CAAC"}
@@ -0,0 +1,73 @@
1
+ /**
2
+ * SMI-1189: Trust Scorer
3
+ * SMI-4396: Allowlist-aware quarantine predicate.
4
+ *
5
+ * Trust score calculation and quarantine decision logic.
6
+ */
7
+ import type { ScanReport } from '../../security/index.js';
8
+ import type { AllowlistMatcher } from './types.js';
9
+ /**
10
+ * Configuration for trust scoring
11
+ */
12
+ export interface TrustScorerConfig {
13
+ /** Risk threshold for quarantine (skills at or above this are quarantined) */
14
+ quarantineThreshold: number;
15
+ }
16
+ /** Default trust scorer configuration */
17
+ export declare const DEFAULT_TRUST_CONFIG: TrustScorerConfig;
18
+ /**
19
+ * Determines if a skill should be quarantined based on findings.
20
+ *
21
+ * SMI-4396: when an allowlist matcher is provided, findings the matcher
22
+ * approves are removed BEFORE the quarantine check runs, and the risk score
23
+ * is recomputed from the filtered set rather than trusting report.riskScore
24
+ * (which was computed pre-allowlist inside SecurityScanner.scan).
25
+ *
26
+ * !report.passed is intentionally NOT part of the predicate: `passed` is
27
+ * also computed pre-allowlist, so keeping it here would re-quarantine every
28
+ * allowlisted skill whose raw scan had critical/high findings — defeating
29
+ * the allowlist's purpose. The new two-clause predicate still covers the old
30
+ * semantics: any scan that was `passed: false` must have had at least one
31
+ * critical/high finding OR score >= threshold, both of which are still caught.
32
+ *
33
+ * A skill is quarantined if ANY of:
34
+ * 1. Post-allowlist findings contain a critical or high severity entry
35
+ * 2. Post-allowlist risk score >= quarantineThreshold
36
+ *
37
+ * @param report - The scan report for the skill
38
+ * @param config - Trust scorer configuration
39
+ * @param allowlist - Optional per-skill allowlist (SMI-4396)
40
+ * @returns true if the skill should be quarantined
41
+ */
42
+ export declare function shouldQuarantine(report: ScanReport, config?: TrustScorerConfig, allowlist?: AllowlistMatcher): boolean;
43
+ /**
44
+ * Calculate average risk score from results
45
+ *
46
+ * @param results - Array of scan results with risk scores
47
+ * @returns Average risk score (0 if no results)
48
+ */
49
+ export declare function calculateAverageRiskScore(results: Array<{
50
+ scanReport: ScanReport;
51
+ }>): number;
52
+ /**
53
+ * Calculate maximum risk score from results
54
+ *
55
+ * @param results - Array of scan results with risk scores
56
+ * @returns Maximum risk score (0 if no results)
57
+ */
58
+ export declare function calculateMaxRiskScore(results: Array<{
59
+ scanReport: ScanReport;
60
+ }>): number;
61
+ /**
62
+ * Get pass/fail statistics from results
63
+ *
64
+ * @param results - Array of scan results
65
+ * @returns Object with passed and quarantined counts
66
+ */
67
+ export declare function getPassFailStats(results: Array<{
68
+ isQuarantined: boolean;
69
+ }>): {
70
+ passed: number;
71
+ quarantined: number;
72
+ };
73
+ //# sourceMappingURL=trust-scorer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trust-scorer.d.ts","sourceRoot":"","sources":["../../../src/scripts/skill-scanner/trust-scorer.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AAEzD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AAElD;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,8EAA8E;IAC9E,mBAAmB,EAAE,MAAM,CAAA;CAC5B;AAED,yCAAyC;AACzC,eAAO,MAAM,oBAAoB,EAAE,iBAElC,CAAA;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,UAAU,EAClB,MAAM,GAAE,iBAAwC,EAChD,SAAS,CAAC,EAAE,gBAAgB,GAC3B,OAAO,CAWT;AAED;;;;;GAKG;AACH,wBAAgB,yBAAyB,CAAC,OAAO,EAAE,KAAK,CAAC;IAAE,UAAU,EAAE,UAAU,CAAA;CAAE,CAAC,GAAG,MAAM,CAM5F;AAED;;;;;GAKG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,KAAK,CAAC;IAAE,UAAU,EAAE,UAAU,CAAA;CAAE,CAAC,GAAG,MAAM,CAGxF;AAED;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC;IAAE,aAAa,EAAE,OAAO,CAAA;CAAE,CAAC,GAAG;IAC5E,MAAM,EAAE,MAAM,CAAA;IACd,WAAW,EAAE,MAAM,CAAA;CACpB,CAKA"}