@skillsmith/core 0.1.2 → 0.4.0

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 (684) hide show
  1. package/README.md +235 -4
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/src/analysis/CodebaseAnalyzer.d.ts +4 -134
  4. package/dist/src/analysis/CodebaseAnalyzer.d.ts.map +1 -1
  5. package/dist/src/analysis/CodebaseAnalyzer.js +7 -315
  6. package/dist/src/analysis/CodebaseAnalyzer.js.map +1 -1
  7. package/dist/src/analysis/__tests__/incremental.test.d.ts +13 -0
  8. package/dist/src/analysis/__tests__/incremental.test.d.ts.map +1 -0
  9. package/dist/src/analysis/__tests__/incremental.test.js +515 -0
  10. package/dist/src/analysis/__tests__/incremental.test.js.map +1 -0
  11. package/dist/src/analysis/__tests__/integration.test.d.ts +14 -0
  12. package/dist/src/analysis/__tests__/integration.test.d.ts.map +1 -0
  13. package/dist/src/analysis/__tests__/integration.test.js +1059 -0
  14. package/dist/src/analysis/__tests__/integration.test.js.map +1 -0
  15. package/dist/src/analysis/__tests__/metrics.test.d.ts +9 -0
  16. package/dist/src/analysis/__tests__/metrics.test.d.ts.map +1 -0
  17. package/dist/src/analysis/__tests__/metrics.test.js +369 -0
  18. package/dist/src/analysis/__tests__/metrics.test.js.map +1 -0
  19. package/dist/src/analysis/__tests__/performance.test.d.ts +15 -0
  20. package/dist/src/analysis/__tests__/performance.test.d.ts.map +1 -0
  21. package/dist/src/analysis/__tests__/performance.test.js +402 -0
  22. package/dist/src/analysis/__tests__/performance.test.js.map +1 -0
  23. package/dist/src/analysis/adapters/__tests__/go.test.d.ts +12 -0
  24. package/dist/src/analysis/adapters/__tests__/go.test.d.ts.map +1 -0
  25. package/dist/src/analysis/adapters/__tests__/go.test.js +561 -0
  26. package/dist/src/analysis/adapters/__tests__/go.test.js.map +1 -0
  27. package/dist/src/analysis/adapters/__tests__/python.test.d.ts +11 -0
  28. package/dist/src/analysis/adapters/__tests__/python.test.d.ts.map +1 -0
  29. package/dist/src/analysis/adapters/__tests__/python.test.js +669 -0
  30. package/dist/src/analysis/adapters/__tests__/python.test.js.map +1 -0
  31. package/dist/src/analysis/adapters/__tests__/rust.test.d.ts +12 -0
  32. package/dist/src/analysis/adapters/__tests__/rust.test.d.ts.map +1 -0
  33. package/dist/src/analysis/adapters/__tests__/rust.test.js +676 -0
  34. package/dist/src/analysis/adapters/__tests__/rust.test.js.map +1 -0
  35. package/dist/src/analysis/adapters/__tests__/typescript.test.d.ts +14 -0
  36. package/dist/src/analysis/adapters/__tests__/typescript.test.d.ts.map +1 -0
  37. package/dist/src/analysis/adapters/__tests__/typescript.test.js +381 -0
  38. package/dist/src/analysis/adapters/__tests__/typescript.test.js.map +1 -0
  39. package/dist/src/analysis/adapters/base.d.ts +83 -0
  40. package/dist/src/analysis/adapters/base.d.ts.map +1 -0
  41. package/dist/src/analysis/adapters/base.js +40 -0
  42. package/dist/src/analysis/adapters/base.js.map +1 -0
  43. package/dist/src/analysis/adapters/factory.d.ts +150 -0
  44. package/dist/src/analysis/adapters/factory.d.ts.map +1 -0
  45. package/dist/src/analysis/adapters/factory.js +244 -0
  46. package/dist/src/analysis/adapters/factory.js.map +1 -0
  47. package/dist/src/analysis/adapters/go.d.ts +131 -0
  48. package/dist/src/analysis/adapters/go.d.ts.map +1 -0
  49. package/dist/src/analysis/adapters/go.js +414 -0
  50. package/dist/src/analysis/adapters/go.js.map +1 -0
  51. package/dist/src/analysis/adapters/index.d.ts +20 -0
  52. package/dist/src/analysis/adapters/index.d.ts.map +1 -0
  53. package/dist/src/analysis/adapters/index.js +23 -0
  54. package/dist/src/analysis/adapters/index.js.map +1 -0
  55. package/dist/src/analysis/adapters/java.d.ts +154 -0
  56. package/dist/src/analysis/adapters/java.d.ts.map +1 -0
  57. package/dist/src/analysis/adapters/java.js +407 -0
  58. package/dist/src/analysis/adapters/java.js.map +1 -0
  59. package/dist/src/analysis/adapters/python.d.ts +165 -0
  60. package/dist/src/analysis/adapters/python.d.ts.map +1 -0
  61. package/dist/src/analysis/adapters/python.js +475 -0
  62. package/dist/src/analysis/adapters/python.js.map +1 -0
  63. package/dist/src/analysis/adapters/rust.d.ts +116 -0
  64. package/dist/src/analysis/adapters/rust.d.ts.map +1 -0
  65. package/dist/src/analysis/adapters/rust.js +476 -0
  66. package/dist/src/analysis/adapters/rust.js.map +1 -0
  67. package/dist/src/analysis/adapters/typescript.d.ts +68 -0
  68. package/dist/src/analysis/adapters/typescript.d.ts.map +1 -0
  69. package/dist/src/analysis/adapters/typescript.js +79 -0
  70. package/dist/src/analysis/adapters/typescript.js.map +1 -0
  71. package/dist/src/analysis/aggregator.d.ts +193 -0
  72. package/dist/src/analysis/aggregator.d.ts.map +1 -0
  73. package/dist/src/analysis/aggregator.js +283 -0
  74. package/dist/src/analysis/aggregator.js.map +1 -0
  75. package/dist/src/analysis/cache.d.ts +180 -0
  76. package/dist/src/analysis/cache.d.ts.map +1 -0
  77. package/dist/src/analysis/cache.js +279 -0
  78. package/dist/src/analysis/cache.js.map +1 -0
  79. package/dist/src/analysis/file-streamer.d.ts +136 -0
  80. package/dist/src/analysis/file-streamer.d.ts.map +1 -0
  81. package/dist/src/analysis/file-streamer.js +291 -0
  82. package/dist/src/analysis/file-streamer.js.map +1 -0
  83. package/dist/src/analysis/framework-detector.d.ts +47 -0
  84. package/dist/src/analysis/framework-detector.d.ts.map +1 -0
  85. package/dist/src/analysis/framework-detector.js +151 -0
  86. package/dist/src/analysis/framework-detector.js.map +1 -0
  87. package/dist/src/analysis/incremental-parser.d.ts +186 -0
  88. package/dist/src/analysis/incremental-parser.d.ts.map +1 -0
  89. package/dist/src/analysis/incremental-parser.js +291 -0
  90. package/dist/src/analysis/incremental-parser.js.map +1 -0
  91. package/dist/src/analysis/incremental.d.ts +186 -0
  92. package/dist/src/analysis/incremental.d.ts.map +1 -0
  93. package/dist/src/analysis/incremental.js +247 -0
  94. package/dist/src/analysis/incremental.js.map +1 -0
  95. package/dist/src/analysis/index.d.ts +29 -2
  96. package/dist/src/analysis/index.d.ts.map +1 -1
  97. package/dist/src/analysis/index.js +53 -2
  98. package/dist/src/analysis/index.js.map +1 -1
  99. package/dist/src/analysis/language-detector.d.ts +92 -0
  100. package/dist/src/analysis/language-detector.d.ts.map +1 -0
  101. package/dist/src/analysis/language-detector.js +602 -0
  102. package/dist/src/analysis/language-detector.js.map +1 -0
  103. package/dist/src/analysis/memory-monitor.d.ts +199 -0
  104. package/dist/src/analysis/memory-monitor.d.ts.map +1 -0
  105. package/dist/src/analysis/memory-monitor.js +271 -0
  106. package/dist/src/analysis/memory-monitor.js.map +1 -0
  107. package/dist/src/analysis/metrics.d.ts +300 -0
  108. package/dist/src/analysis/metrics.d.ts.map +1 -0
  109. package/dist/src/analysis/metrics.js +537 -0
  110. package/dist/src/analysis/metrics.js.map +1 -0
  111. package/dist/src/analysis/parsers.d.ts +43 -0
  112. package/dist/src/analysis/parsers.d.ts.map +1 -0
  113. package/dist/src/analysis/parsers.js +219 -0
  114. package/dist/src/analysis/parsers.js.map +1 -0
  115. package/dist/src/analysis/router.d.ts +264 -0
  116. package/dist/src/analysis/router.d.ts.map +1 -0
  117. package/dist/src/analysis/router.js +398 -0
  118. package/dist/src/analysis/router.js.map +1 -0
  119. package/dist/src/analysis/tree-cache.d.ts +208 -0
  120. package/dist/src/analysis/tree-cache.d.ts.map +1 -0
  121. package/dist/src/analysis/tree-cache.js +288 -0
  122. package/dist/src/analysis/tree-cache.js.map +1 -0
  123. package/dist/src/analysis/tree-sitter/manager.d.ts +141 -0
  124. package/dist/src/analysis/tree-sitter/manager.d.ts.map +1 -0
  125. package/dist/src/analysis/tree-sitter/manager.js +239 -0
  126. package/dist/src/analysis/tree-sitter/manager.js.map +1 -0
  127. package/dist/src/analysis/types.d.ts +203 -0
  128. package/dist/src/analysis/types.d.ts.map +1 -0
  129. package/dist/src/analysis/types.js +58 -0
  130. package/dist/src/analysis/types.js.map +1 -0
  131. package/dist/src/analysis/worker-pool.d.ts +141 -0
  132. package/dist/src/analysis/worker-pool.d.ts.map +1 -0
  133. package/dist/src/analysis/worker-pool.js +418 -0
  134. package/dist/src/analysis/worker-pool.js.map +1 -0
  135. package/dist/src/analytics/AnalyticsRepository.d.ts +4 -0
  136. package/dist/src/analytics/AnalyticsRepository.d.ts.map +1 -1
  137. package/dist/src/analytics/AnalyticsRepository.js +30 -48
  138. package/dist/src/analytics/AnalyticsRepository.js.map +1 -1
  139. package/dist/src/analytics/schema.d.ts +1 -1
  140. package/dist/src/analytics/schema.d.ts.map +1 -1
  141. package/dist/src/analytics/schema.js +140 -0
  142. package/dist/src/analytics/schema.js.map +1 -1
  143. package/dist/src/api/cache.d.ts +131 -0
  144. package/dist/src/api/cache.d.ts.map +1 -0
  145. package/dist/src/api/cache.js +264 -0
  146. package/dist/src/api/cache.js.map +1 -0
  147. package/dist/src/api/client.d.ts +286 -0
  148. package/dist/src/api/client.d.ts.map +1 -0
  149. package/dist/src/api/client.js +422 -0
  150. package/dist/src/api/client.js.map +1 -0
  151. package/dist/src/api/index.d.ts +12 -0
  152. package/dist/src/api/index.d.ts.map +1 -0
  153. package/dist/src/api/index.js +17 -0
  154. package/dist/src/api/index.js.map +1 -0
  155. package/dist/src/api/types.d.ts +251 -0
  156. package/dist/src/api/types.d.ts.map +1 -0
  157. package/dist/src/api/types.js +9 -0
  158. package/dist/src/api/types.js.map +1 -0
  159. package/dist/src/benchmarks/BenchmarkRunner.d.ts +6 -175
  160. package/dist/src/benchmarks/BenchmarkRunner.d.ts.map +1 -1
  161. package/dist/src/benchmarks/BenchmarkRunner.js +6 -123
  162. package/dist/src/benchmarks/BenchmarkRunner.js.map +1 -1
  163. package/dist/src/benchmarks/MemoryProfiler.d.ts +4 -262
  164. package/dist/src/benchmarks/MemoryProfiler.d.ts.map +1 -1
  165. package/dist/src/benchmarks/MemoryProfiler.js +4 -400
  166. package/dist/src/benchmarks/MemoryProfiler.js.map +1 -1
  167. package/dist/src/benchmarks/comparator.d.ts +38 -0
  168. package/dist/src/benchmarks/comparator.d.ts.map +1 -0
  169. package/dist/src/benchmarks/comparator.js +81 -0
  170. package/dist/src/benchmarks/comparator.js.map +1 -0
  171. package/dist/src/benchmarks/formatters.d.ts +30 -0
  172. package/dist/src/benchmarks/formatters.d.ts.map +1 -0
  173. package/dist/src/benchmarks/formatters.js +88 -0
  174. package/dist/src/benchmarks/formatters.js.map +1 -0
  175. package/dist/src/benchmarks/index.d.ts +5 -1
  176. package/dist/src/benchmarks/index.d.ts.map +1 -1
  177. package/dist/src/benchmarks/index.js +9 -2
  178. package/dist/src/benchmarks/index.js.map +1 -1
  179. package/dist/src/benchmarks/memory/MemoryProfiler.d.ts +165 -0
  180. package/dist/src/benchmarks/memory/MemoryProfiler.d.ts.map +1 -0
  181. package/dist/src/benchmarks/memory/MemoryProfiler.js +312 -0
  182. package/dist/src/benchmarks/memory/MemoryProfiler.js.map +1 -0
  183. package/dist/src/benchmarks/memory/baseline-manager.d.ts +64 -0
  184. package/dist/src/benchmarks/memory/baseline-manager.d.ts.map +1 -0
  185. package/dist/src/benchmarks/memory/baseline-manager.js +95 -0
  186. package/dist/src/benchmarks/memory/baseline-manager.js.map +1 -0
  187. package/dist/src/benchmarks/memory/index.d.ts +12 -0
  188. package/dist/src/benchmarks/memory/index.d.ts.map +1 -0
  189. package/dist/src/benchmarks/memory/index.js +12 -0
  190. package/dist/src/benchmarks/memory/index.js.map +1 -0
  191. package/dist/src/benchmarks/memory/leak-detector.d.ts +23 -0
  192. package/dist/src/benchmarks/memory/leak-detector.d.ts.map +1 -0
  193. package/dist/src/benchmarks/memory/leak-detector.js +46 -0
  194. package/dist/src/benchmarks/memory/leak-detector.js.map +1 -0
  195. package/dist/src/benchmarks/memory/regression-detector.d.ts +17 -0
  196. package/dist/src/benchmarks/memory/regression-detector.d.ts.map +1 -0
  197. package/dist/src/benchmarks/memory/regression-detector.js +56 -0
  198. package/dist/src/benchmarks/memory/regression-detector.js.map +1 -0
  199. package/dist/src/benchmarks/memory/types.d.ts +111 -0
  200. package/dist/src/benchmarks/memory/types.d.ts.map +1 -0
  201. package/dist/src/benchmarks/memory/types.js +7 -0
  202. package/dist/src/benchmarks/memory/types.js.map +1 -0
  203. package/dist/src/benchmarks/memory/utils.d.ts +17 -0
  204. package/dist/src/benchmarks/memory/utils.d.ts.map +1 -0
  205. package/dist/src/benchmarks/memory/utils.js +29 -0
  206. package/dist/src/benchmarks/memory/utils.js.map +1 -0
  207. package/dist/src/benchmarks/types.d.ts +175 -0
  208. package/dist/src/benchmarks/types.d.ts.map +1 -0
  209. package/dist/src/benchmarks/types.js +20 -0
  210. package/dist/src/benchmarks/types.js.map +1 -0
  211. package/dist/src/billing/BillingService.d.ts +139 -0
  212. package/dist/src/billing/BillingService.d.ts.map +1 -0
  213. package/dist/src/billing/BillingService.js +393 -0
  214. package/dist/src/billing/BillingService.js.map +1 -0
  215. package/dist/src/billing/GDPRComplianceService.d.ts +176 -0
  216. package/dist/src/billing/GDPRComplianceService.d.ts.map +1 -0
  217. package/dist/src/billing/GDPRComplianceService.js +361 -0
  218. package/dist/src/billing/GDPRComplianceService.js.map +1 -0
  219. package/dist/src/billing/StripeClient.d.ts +177 -0
  220. package/dist/src/billing/StripeClient.d.ts.map +1 -0
  221. package/dist/src/billing/StripeClient.js +462 -0
  222. package/dist/src/billing/StripeClient.js.map +1 -0
  223. package/dist/src/billing/StripeReconciliationJob.d.ts +95 -0
  224. package/dist/src/billing/StripeReconciliationJob.d.ts.map +1 -0
  225. package/dist/src/billing/StripeReconciliationJob.js +405 -0
  226. package/dist/src/billing/StripeReconciliationJob.js.map +1 -0
  227. package/dist/src/billing/StripeWebhookHandler.d.ts +92 -0
  228. package/dist/src/billing/StripeWebhookHandler.d.ts.map +1 -0
  229. package/dist/src/billing/StripeWebhookHandler.js +409 -0
  230. package/dist/src/billing/StripeWebhookHandler.js.map +1 -0
  231. package/dist/src/billing/index.d.ts +18 -0
  232. package/dist/src/billing/index.d.ts.map +1 -0
  233. package/dist/src/billing/index.js +19 -0
  234. package/dist/src/billing/index.js.map +1 -0
  235. package/dist/src/billing/types.d.ts +266 -0
  236. package/dist/src/billing/types.d.ts.map +1 -0
  237. package/dist/src/billing/types.js +23 -0
  238. package/dist/src/billing/types.js.map +1 -0
  239. package/dist/src/db/schema.d.ts +1 -1
  240. package/dist/src/db/schema.d.ts.map +1 -1
  241. package/dist/src/db/schema.js +41 -1
  242. package/dist/src/db/schema.js.map +1 -1
  243. package/dist/src/embeddings/hnsw-store.d.ts +568 -0
  244. package/dist/src/embeddings/hnsw-store.d.ts.map +1 -0
  245. package/dist/src/embeddings/hnsw-store.js +805 -0
  246. package/dist/src/embeddings/hnsw-store.js.map +1 -0
  247. package/dist/src/embeddings/index.d.ts +2 -0
  248. package/dist/src/embeddings/index.d.ts.map +1 -1
  249. package/dist/src/embeddings/index.js +2 -0
  250. package/dist/src/embeddings/index.js.map +1 -1
  251. package/dist/src/errors.d.ts +1 -0
  252. package/dist/src/errors.d.ts.map +1 -1
  253. package/dist/src/errors.js +1 -0
  254. package/dist/src/errors.js.map +1 -1
  255. package/dist/src/index.d.ts +7 -3
  256. package/dist/src/index.d.ts.map +1 -1
  257. package/dist/src/index.js +12 -4
  258. package/dist/src/index.js.map +1 -1
  259. package/dist/src/learning/PatternStore.d.ts +457 -0
  260. package/dist/src/learning/PatternStore.d.ts.map +1 -0
  261. package/dist/src/learning/PatternStore.js +893 -0
  262. package/dist/src/learning/PatternStore.js.map +1 -0
  263. package/dist/src/learning/ReasoningBankIntegration.d.ts +403 -0
  264. package/dist/src/learning/ReasoningBankIntegration.d.ts.map +1 -0
  265. package/dist/src/learning/ReasoningBankIntegration.js +627 -0
  266. package/dist/src/learning/ReasoningBankIntegration.js.map +1 -0
  267. package/dist/src/learning/index.d.ts +15 -0
  268. package/dist/src/learning/index.d.ts.map +1 -0
  269. package/dist/src/learning/index.js +15 -0
  270. package/dist/src/learning/index.js.map +1 -0
  271. package/dist/src/repositories/IndexerRepository.d.ts.map +1 -1
  272. package/dist/src/repositories/IndexerRepository.js +1 -0
  273. package/dist/src/repositories/IndexerRepository.js.map +1 -1
  274. package/dist/src/repositories/QuarantineRepository.d.ts +4 -251
  275. package/dist/src/repositories/QuarantineRepository.d.ts.map +1 -1
  276. package/dist/src/repositories/QuarantineRepository.js +4 -441
  277. package/dist/src/repositories/QuarantineRepository.js.map +1 -1
  278. package/dist/src/repositories/SkillRepository.d.ts.map +1 -1
  279. package/dist/src/repositories/SkillRepository.js +1 -0
  280. package/dist/src/repositories/SkillRepository.js.map +1 -1
  281. package/dist/src/repositories/SyncConfigRepository.d.ts +91 -0
  282. package/dist/src/repositories/SyncConfigRepository.d.ts.map +1 -0
  283. package/dist/src/repositories/SyncConfigRepository.js +202 -0
  284. package/dist/src/repositories/SyncConfigRepository.js.map +1 -0
  285. package/dist/src/repositories/SyncHistoryRepository.d.ts +104 -0
  286. package/dist/src/repositories/SyncHistoryRepository.d.ts.map +1 -0
  287. package/dist/src/repositories/SyncHistoryRepository.js +235 -0
  288. package/dist/src/repositories/SyncHistoryRepository.js.map +1 -0
  289. package/dist/src/repositories/quarantine/QuarantineRepository.d.ts +168 -0
  290. package/dist/src/repositories/quarantine/QuarantineRepository.d.ts.map +1 -0
  291. package/dist/src/repositories/quarantine/QuarantineRepository.js +341 -0
  292. package/dist/src/repositories/quarantine/QuarantineRepository.js.map +1 -0
  293. package/dist/src/repositories/quarantine/index.d.ts +10 -0
  294. package/dist/src/repositories/quarantine/index.d.ts.map +1 -0
  295. package/dist/src/repositories/quarantine/index.js +10 -0
  296. package/dist/src/repositories/quarantine/index.js.map +1 -0
  297. package/dist/src/repositories/quarantine/queries.d.ts +58 -0
  298. package/dist/src/repositories/quarantine/queries.d.ts.map +1 -0
  299. package/dist/src/repositories/quarantine/queries.js +88 -0
  300. package/dist/src/repositories/quarantine/queries.js.map +1 -0
  301. package/dist/src/repositories/quarantine/query-builder.d.ts +44 -0
  302. package/dist/src/repositories/quarantine/query-builder.d.ts.map +1 -0
  303. package/dist/src/repositories/quarantine/query-builder.js +87 -0
  304. package/dist/src/repositories/quarantine/query-builder.js.map +1 -0
  305. package/dist/src/repositories/quarantine/types.d.ts +155 -0
  306. package/dist/src/repositories/quarantine/types.d.ts.map +1 -0
  307. package/dist/src/repositories/quarantine/types.js +13 -0
  308. package/dist/src/repositories/quarantine/types.js.map +1 -0
  309. package/dist/src/routing/SONARouter.d.ts +154 -0
  310. package/dist/src/routing/SONARouter.d.ts.map +1 -0
  311. package/dist/src/routing/SONARouter.js +679 -0
  312. package/dist/src/routing/SONARouter.js.map +1 -0
  313. package/dist/src/routing/index.d.ts +9 -0
  314. package/dist/src/routing/index.d.ts.map +1 -0
  315. package/dist/src/routing/index.js +10 -0
  316. package/dist/src/routing/index.js.map +1 -0
  317. package/dist/src/routing/types.d.ts +331 -0
  318. package/dist/src/routing/types.d.ts.map +1 -0
  319. package/dist/src/routing/types.js +203 -0
  320. package/dist/src/routing/types.js.map +1 -0
  321. package/dist/src/scripts/__tests__/scan-imported-skills.test.d.ts +1 -0
  322. package/dist/src/scripts/__tests__/scan-imported-skills.test.d.ts.map +1 -1
  323. package/dist/src/scripts/__tests__/scan-imported-skills.test.js +12 -43
  324. package/dist/src/scripts/__tests__/scan-imported-skills.test.js.map +1 -1
  325. package/dist/src/scripts/github-import/checkpoint.d.ts +21 -0
  326. package/dist/src/scripts/github-import/checkpoint.d.ts.map +1 -0
  327. package/dist/src/scripts/github-import/checkpoint.js +52 -0
  328. package/dist/src/scripts/github-import/checkpoint.js.map +1 -0
  329. package/dist/src/scripts/github-import/deduplication.d.ts +15 -0
  330. package/dist/src/scripts/github-import/deduplication.d.ts.map +1 -0
  331. package/dist/src/scripts/github-import/deduplication.js +33 -0
  332. package/dist/src/scripts/github-import/deduplication.js.map +1 -0
  333. package/dist/src/scripts/github-import/github-client.d.ts +57 -0
  334. package/dist/src/scripts/github-import/github-client.d.ts.map +1 -0
  335. package/dist/src/scripts/github-import/github-client.js +473 -0
  336. package/dist/src/scripts/github-import/github-client.js.map +1 -0
  337. package/dist/src/scripts/github-import/index.d.ts +29 -0
  338. package/dist/src/scripts/github-import/index.d.ts.map +1 -0
  339. package/dist/src/scripts/github-import/index.js +191 -0
  340. package/dist/src/scripts/github-import/index.js.map +1 -0
  341. package/dist/src/scripts/github-import/output.d.ts +12 -0
  342. package/dist/src/scripts/github-import/output.d.ts.map +1 -0
  343. package/dist/src/scripts/github-import/output.js +34 -0
  344. package/dist/src/scripts/github-import/output.js.map +1 -0
  345. package/dist/src/scripts/github-import/types.d.ts +114 -0
  346. package/dist/src/scripts/github-import/types.d.ts.map +1 -0
  347. package/dist/src/scripts/github-import/types.js +47 -0
  348. package/dist/src/scripts/github-import/types.js.map +1 -0
  349. package/dist/src/scripts/github-import/utils.d.ts +13 -0
  350. package/dist/src/scripts/github-import/utils.d.ts.map +1 -0
  351. package/dist/src/scripts/github-import/utils.js +28 -0
  352. package/dist/src/scripts/github-import/utils.js.map +1 -0
  353. package/dist/src/scripts/import-github-skills.d.ts +3 -12
  354. package/dist/src/scripts/import-github-skills.d.ts.map +1 -1
  355. package/dist/src/scripts/import-github-skills.js +27 -402
  356. package/dist/src/scripts/import-github-skills.js.map +1 -1
  357. package/dist/src/scripts/merge-skills.d.ts +56 -0
  358. package/dist/src/scripts/merge-skills.d.ts.map +1 -0
  359. package/dist/src/scripts/merge-skills.js +411 -0
  360. package/dist/src/scripts/merge-skills.js.map +1 -0
  361. package/dist/src/scripts/scan-imported-skills.d.ts +7 -7
  362. package/dist/src/scripts/scan-imported-skills.d.ts.map +1 -1
  363. package/dist/src/scripts/scan-imported-skills.js +8 -397
  364. package/dist/src/scripts/scan-imported-skills.js.map +1 -1
  365. package/dist/src/scripts/skill-scanner/categorizer.d.ts +43 -0
  366. package/dist/src/scripts/skill-scanner/categorizer.d.ts.map +1 -0
  367. package/dist/src/scripts/skill-scanner/categorizer.js +61 -0
  368. package/dist/src/scripts/skill-scanner/categorizer.js.map +1 -0
  369. package/dist/src/scripts/skill-scanner/file-scanner.d.ts +43 -0
  370. package/dist/src/scripts/skill-scanner/file-scanner.d.ts.map +1 -0
  371. package/dist/src/scripts/skill-scanner/file-scanner.js +90 -0
  372. package/dist/src/scripts/skill-scanner/file-scanner.js.map +1 -0
  373. package/dist/src/scripts/skill-scanner/index.d.ts +29 -0
  374. package/dist/src/scripts/skill-scanner/index.d.ts.map +1 -0
  375. package/dist/src/scripts/skill-scanner/index.js +134 -0
  376. package/dist/src/scripts/skill-scanner/index.js.map +1 -0
  377. package/dist/src/scripts/skill-scanner/logger.d.ts +110 -0
  378. package/dist/src/scripts/skill-scanner/logger.d.ts.map +1 -0
  379. package/dist/src/scripts/skill-scanner/logger.js +358 -0
  380. package/dist/src/scripts/skill-scanner/logger.js.map +1 -0
  381. package/dist/src/scripts/skill-scanner/reporter.d.ts +56 -0
  382. package/dist/src/scripts/skill-scanner/reporter.d.ts.map +1 -0
  383. package/dist/src/scripts/skill-scanner/reporter.js +218 -0
  384. package/dist/src/scripts/skill-scanner/reporter.js.map +1 -0
  385. package/dist/src/scripts/skill-scanner/scanner.d.ts +47 -0
  386. package/dist/src/scripts/skill-scanner/scanner.d.ts.map +1 -0
  387. package/dist/src/scripts/skill-scanner/scanner.js +257 -0
  388. package/dist/src/scripts/skill-scanner/scanner.js.map +1 -0
  389. package/dist/src/scripts/skill-scanner/trust-scorer.d.ts +59 -0
  390. package/dist/src/scripts/skill-scanner/trust-scorer.d.ts.map +1 -0
  391. package/dist/src/scripts/skill-scanner/trust-scorer.js +62 -0
  392. package/dist/src/scripts/skill-scanner/trust-scorer.js.map +1 -0
  393. package/dist/src/scripts/skill-scanner/types.d.ts +142 -0
  394. package/dist/src/scripts/skill-scanner/types.d.ts.map +1 -0
  395. package/dist/src/scripts/skill-scanner/types.js +7 -0
  396. package/dist/src/scripts/skill-scanner/types.js.map +1 -0
  397. package/dist/src/scripts/validate-skills.d.ts +3 -172
  398. package/dist/src/scripts/validate-skills.d.ts.map +1 -1
  399. package/dist/src/scripts/validate-skills.js +6 -519
  400. package/dist/src/scripts/validate-skills.js.map +1 -1
  401. package/dist/src/scripts/validation/deduplication.d.ts +23 -0
  402. package/dist/src/scripts/validation/deduplication.d.ts.map +1 -0
  403. package/dist/src/scripts/validation/deduplication.js +127 -0
  404. package/dist/src/scripts/validation/deduplication.js.map +1 -0
  405. package/dist/src/scripts/validation/field-validators.d.ts +9 -0
  406. package/dist/src/scripts/validation/field-validators.d.ts.map +1 -0
  407. package/dist/src/scripts/validation/field-validators.js +135 -0
  408. package/dist/src/scripts/validation/field-validators.js.map +1 -0
  409. package/dist/src/scripts/validation/index.d.ts +29 -0
  410. package/dist/src/scripts/validation/index.d.ts.map +1 -0
  411. package/dist/src/scripts/validation/index.js +83 -0
  412. package/dist/src/scripts/validation/index.js.map +1 -0
  413. package/dist/src/scripts/validation/normalizers.d.ts +29 -0
  414. package/dist/src/scripts/validation/normalizers.d.ts.map +1 -0
  415. package/dist/src/scripts/validation/normalizers.js +79 -0
  416. package/dist/src/scripts/validation/normalizers.js.map +1 -0
  417. package/dist/src/scripts/validation/pipeline.d.ts +13 -0
  418. package/dist/src/scripts/validation/pipeline.d.ts.map +1 -0
  419. package/dist/src/scripts/validation/pipeline.js +126 -0
  420. package/dist/src/scripts/validation/pipeline.js.map +1 -0
  421. package/dist/src/scripts/validation/types.d.ts +128 -0
  422. package/dist/src/scripts/validation/types.d.ts.map +1 -0
  423. package/dist/src/scripts/validation/types.js +43 -0
  424. package/dist/src/scripts/validation/types.js.map +1 -0
  425. package/dist/src/security/SkillSandbox.d.ts +156 -0
  426. package/dist/src/security/SkillSandbox.d.ts.map +1 -0
  427. package/dist/src/security/SkillSandbox.js +303 -0
  428. package/dist/src/security/SkillSandbox.js.map +1 -0
  429. package/dist/src/security/index.d.ts +8 -5
  430. package/dist/src/security/index.d.ts.map +1 -1
  431. package/dist/src/security/index.js +13 -3
  432. package/dist/src/security/index.js.map +1 -1
  433. package/dist/src/security/rate-limiter/RateLimiter.d.ts +86 -0
  434. package/dist/src/security/rate-limiter/RateLimiter.d.ts.map +1 -0
  435. package/dist/src/security/rate-limiter/RateLimiter.js +260 -0
  436. package/dist/src/security/rate-limiter/RateLimiter.js.map +1 -0
  437. package/dist/src/security/rate-limiter/constants.d.ts +15 -0
  438. package/dist/src/security/rate-limiter/constants.d.ts.map +1 -0
  439. package/dist/src/security/rate-limiter/constants.js +15 -0
  440. package/dist/src/security/rate-limiter/constants.js.map +1 -0
  441. package/dist/src/security/rate-limiter/errors.d.ts +22 -0
  442. package/dist/src/security/rate-limiter/errors.d.ts.map +1 -0
  443. package/dist/src/security/rate-limiter/errors.js +32 -0
  444. package/dist/src/security/rate-limiter/errors.js.map +1 -0
  445. package/dist/src/security/rate-limiter/index.d.ts +12 -0
  446. package/dist/src/security/rate-limiter/index.d.ts.map +1 -0
  447. package/dist/src/security/rate-limiter/index.js +16 -0
  448. package/dist/src/security/rate-limiter/index.js.map +1 -0
  449. package/dist/src/security/rate-limiter/metrics-manager.d.ts +55 -0
  450. package/dist/src/security/rate-limiter/metrics-manager.d.ts.map +1 -0
  451. package/dist/src/security/rate-limiter/metrics-manager.js +144 -0
  452. package/dist/src/security/rate-limiter/metrics-manager.js.map +1 -0
  453. package/dist/src/security/rate-limiter/presets.d.ts +64 -0
  454. package/dist/src/security/rate-limiter/presets.d.ts.map +1 -0
  455. package/dist/src/security/rate-limiter/presets.js +65 -0
  456. package/dist/src/security/rate-limiter/presets.js.map +1 -0
  457. package/dist/src/security/rate-limiter/queue-manager.d.ts +59 -0
  458. package/dist/src/security/rate-limiter/queue-manager.d.ts.map +1 -0
  459. package/dist/src/security/rate-limiter/queue-manager.js +189 -0
  460. package/dist/src/security/rate-limiter/queue-manager.js.map +1 -0
  461. package/dist/src/security/rate-limiter/storage.d.ts +34 -0
  462. package/dist/src/security/rate-limiter/storage.d.ts.map +1 -0
  463. package/dist/src/security/rate-limiter/storage.js +80 -0
  464. package/dist/src/security/rate-limiter/storage.js.map +1 -0
  465. package/dist/src/security/rate-limiter/token-bucket.d.ts +44 -0
  466. package/dist/src/security/rate-limiter/token-bucket.d.ts.map +1 -0
  467. package/dist/src/security/rate-limiter/token-bucket.js +99 -0
  468. package/dist/src/security/rate-limiter/token-bucket.js.map +1 -0
  469. package/dist/src/security/rate-limiter/types.d.ts +104 -0
  470. package/dist/src/security/rate-limiter/types.d.ts.map +1 -0
  471. package/dist/src/security/rate-limiter/types.js +7 -0
  472. package/dist/src/security/rate-limiter/types.js.map +1 -0
  473. package/dist/src/security/sanitization.d.ts +85 -0
  474. package/dist/src/security/sanitization.d.ts.map +1 -1
  475. package/dist/src/security/sanitization.js +133 -0
  476. package/dist/src/security/sanitization.js.map +1 -1
  477. package/dist/src/security/{scanner.d.ts → scanner/SecurityScanner.d.ts} +28 -62
  478. package/dist/src/security/scanner/SecurityScanner.d.ts.map +1 -0
  479. package/dist/src/security/{scanner.js → scanner/SecurityScanner.js} +230 -222
  480. package/dist/src/security/scanner/SecurityScanner.js.map +1 -0
  481. package/dist/src/security/scanner/index.d.ts +11 -0
  482. package/dist/src/security/scanner/index.d.ts.map +1 -0
  483. package/dist/src/security/scanner/index.js +14 -0
  484. package/dist/src/security/scanner/index.js.map +1 -0
  485. package/dist/src/security/scanner/patterns.d.ts +27 -0
  486. package/dist/src/security/scanner/patterns.d.ts.map +1 -0
  487. package/dist/src/security/scanner/patterns.js +198 -0
  488. package/dist/src/security/scanner/patterns.js.map +1 -0
  489. package/dist/src/security/scanner/regex-utils.d.ts +33 -0
  490. package/dist/src/security/scanner/regex-utils.d.ts.map +1 -0
  491. package/dist/src/security/scanner/regex-utils.js +41 -0
  492. package/dist/src/security/scanner/regex-utils.js.map +1 -0
  493. package/dist/src/security/scanner/types.d.ts +75 -0
  494. package/dist/src/security/scanner/types.d.ts.map +1 -0
  495. package/dist/src/security/scanner/types.js +7 -0
  496. package/dist/src/security/scanner/types.js.map +1 -0
  497. package/dist/src/security/scanner/weights.d.ts +15 -0
  498. package/dist/src/security/scanner/weights.d.ts.map +1 -0
  499. package/dist/src/security/scanner/weights.js +29 -0
  500. package/dist/src/security/scanner/weights.js.map +1 -0
  501. package/dist/src/services/SearchService.d.ts.map +1 -1
  502. package/dist/src/services/SearchService.js +1 -0
  503. package/dist/src/services/SearchService.js.map +1 -1
  504. package/dist/src/session/SessionHealthMonitor.d.ts +5 -168
  505. package/dist/src/session/SessionHealthMonitor.d.ts.map +1 -1
  506. package/dist/src/session/SessionHealthMonitor.js +22 -91
  507. package/dist/src/session/SessionHealthMonitor.js.map +1 -1
  508. package/dist/src/session/SessionManager.d.ts +7 -0
  509. package/dist/src/session/SessionManager.d.ts.map +1 -1
  510. package/dist/src/session/SessionManager.js +117 -10
  511. package/dist/src/session/SessionManager.js.map +1 -1
  512. package/dist/src/session/health-checks.d.ts +37 -0
  513. package/dist/src/session/health-checks.d.ts.map +1 -0
  514. package/dist/src/session/health-checks.js +64 -0
  515. package/dist/src/session/health-checks.js.map +1 -0
  516. package/dist/src/session/health-types.d.ts +78 -0
  517. package/dist/src/session/health-types.d.ts.map +1 -0
  518. package/dist/src/session/health-types.js +16 -0
  519. package/dist/src/session/health-types.js.map +1 -0
  520. package/dist/src/session/index.d.ts +5 -1
  521. package/dist/src/session/index.d.ts.map +1 -1
  522. package/dist/src/session/index.js +9 -0
  523. package/dist/src/session/index.js.map +1 -1
  524. package/dist/src/session/metrics-collector.d.ts +23 -0
  525. package/dist/src/session/metrics-collector.d.ts.map +1 -0
  526. package/dist/src/session/metrics-collector.js +44 -0
  527. package/dist/src/session/metrics-collector.js.map +1 -0
  528. package/dist/src/session/typed-event-emitter.d.ts +70 -0
  529. package/dist/src/session/typed-event-emitter.d.ts.map +1 -0
  530. package/dist/src/session/typed-event-emitter.js +79 -0
  531. package/dist/src/session/typed-event-emitter.js.map +1 -0
  532. package/dist/src/sources/BaseSourceAdapter.d.ts +1 -1
  533. package/dist/src/sources/BaseSourceAdapter.d.ts.map +1 -1
  534. package/dist/src/sources/BaseSourceAdapter.js +2 -2
  535. package/dist/src/sources/BaseSourceAdapter.js.map +1 -1
  536. package/dist/src/sync/BackgroundSyncService.d.ts +90 -0
  537. package/dist/src/sync/BackgroundSyncService.d.ts.map +1 -0
  538. package/dist/src/sync/BackgroundSyncService.js +214 -0
  539. package/dist/src/sync/BackgroundSyncService.js.map +1 -0
  540. package/dist/src/sync/SyncEngine.d.ts +76 -0
  541. package/dist/src/sync/SyncEngine.d.ts.map +1 -0
  542. package/dist/src/sync/SyncEngine.js +292 -0
  543. package/dist/src/sync/SyncEngine.js.map +1 -0
  544. package/dist/src/sync/index.d.ts +11 -0
  545. package/dist/src/sync/index.d.ts.map +1 -0
  546. package/dist/src/sync/index.js +14 -0
  547. package/dist/src/sync/index.js.map +1 -0
  548. package/dist/src/telemetry/index.d.ts +1 -0
  549. package/dist/src/telemetry/index.d.ts.map +1 -1
  550. package/dist/src/telemetry/index.js +2 -0
  551. package/dist/src/telemetry/index.js.map +1 -1
  552. package/dist/src/telemetry/posthog.d.ts +147 -0
  553. package/dist/src/telemetry/posthog.d.ts.map +1 -0
  554. package/dist/src/telemetry/posthog.js +213 -0
  555. package/dist/src/telemetry/posthog.js.map +1 -0
  556. package/dist/src/testing/MultiLLMProvider.d.ts +374 -0
  557. package/dist/src/testing/MultiLLMProvider.d.ts.map +1 -0
  558. package/dist/src/testing/MultiLLMProvider.js +720 -0
  559. package/dist/src/testing/MultiLLMProvider.js.map +1 -0
  560. package/dist/src/testing/index.d.ts +8 -0
  561. package/dist/src/testing/index.d.ts.map +1 -0
  562. package/dist/src/testing/index.js +9 -0
  563. package/dist/src/testing/index.js.map +1 -0
  564. package/dist/src/types/skill.d.ts +3 -0
  565. package/dist/src/types/skill.d.ts.map +1 -1
  566. package/dist/src/types.d.ts +5 -1
  567. package/dist/src/types.d.ts.map +1 -1
  568. package/dist/src/types.js +2 -2
  569. package/dist/src/types.js.map +1 -1
  570. package/dist/tests/RateLimiter.test.js +4 -4
  571. package/dist/tests/RateLimiter.test.js.map +1 -1
  572. package/dist/tests/SecurityScanner.test.js +337 -1
  573. package/dist/tests/SecurityScanner.test.js.map +1 -1
  574. package/dist/tests/adapters-factory.test.d.ts +13 -0
  575. package/dist/tests/adapters-factory.test.d.ts.map +1 -0
  576. package/dist/tests/adapters-factory.test.js +308 -0
  577. package/dist/tests/adapters-factory.test.js.map +1 -0
  578. package/dist/tests/adapters-java.test.d.ts +13 -0
  579. package/dist/tests/adapters-java.test.d.ts.map +1 -0
  580. package/dist/tests/adapters-java.test.js +925 -0
  581. package/dist/tests/adapters-java.test.js.map +1 -0
  582. package/dist/tests/api/client.validation.test.d.ts +7 -0
  583. package/dist/tests/api/client.validation.test.d.ts.map +1 -0
  584. package/dist/tests/api/client.validation.test.js +183 -0
  585. package/dist/tests/api/client.validation.test.js.map +1 -0
  586. package/dist/tests/billing/BillingService.test.d.ts +7 -0
  587. package/dist/tests/billing/BillingService.test.d.ts.map +1 -0
  588. package/dist/tests/billing/BillingService.test.js +168 -0
  589. package/dist/tests/billing/BillingService.test.js.map +1 -0
  590. package/dist/tests/billing/GDPRCompliance.test.d.ts +7 -0
  591. package/dist/tests/billing/GDPRCompliance.test.d.ts.map +1 -0
  592. package/dist/tests/billing/GDPRCompliance.test.js +195 -0
  593. package/dist/tests/billing/GDPRCompliance.test.js.map +1 -0
  594. package/dist/tests/billing/StripeReconciliation.test.d.ts +7 -0
  595. package/dist/tests/billing/StripeReconciliation.test.d.ts.map +1 -0
  596. package/dist/tests/billing/StripeReconciliation.test.js +266 -0
  597. package/dist/tests/billing/StripeReconciliation.test.js.map +1 -0
  598. package/dist/tests/billing/stripe-validators.test.d.ts +7 -0
  599. package/dist/tests/billing/stripe-validators.test.d.ts.map +1 -0
  600. package/dist/tests/billing/stripe-validators.test.js +107 -0
  601. package/dist/tests/billing/stripe-validators.test.js.map +1 -0
  602. package/dist/tests/e2e/security/security.e2e.test.js +3 -3
  603. package/dist/tests/e2e/security/security.e2e.test.js.map +1 -1
  604. package/dist/tests/embeddings/hnsw-store.test.d.ts +7 -0
  605. package/dist/tests/embeddings/hnsw-store.test.d.ts.map +1 -0
  606. package/dist/tests/embeddings/hnsw-store.test.js +295 -0
  607. package/dist/tests/embeddings/hnsw-store.test.js.map +1 -0
  608. package/dist/tests/integration/neural/e2e-learning.test.d.ts +17 -0
  609. package/dist/tests/integration/neural/e2e-learning.test.d.ts.map +1 -0
  610. package/dist/tests/integration/neural/e2e-learning.test.js +238 -0
  611. package/dist/tests/integration/neural/e2e-learning.test.js.map +1 -0
  612. package/dist/tests/integration/neural/helpers.d.ts +132 -0
  613. package/dist/tests/integration/neural/helpers.d.ts.map +1 -0
  614. package/dist/tests/integration/neural/helpers.js +287 -0
  615. package/dist/tests/integration/neural/helpers.js.map +1 -0
  616. package/dist/tests/integration/neural/personalization.test.d.ts +21 -0
  617. package/dist/tests/integration/neural/personalization.test.d.ts.map +1 -0
  618. package/dist/tests/integration/neural/personalization.test.js +304 -0
  619. package/dist/tests/integration/neural/personalization.test.js.map +1 -0
  620. package/dist/tests/integration/neural/preference-learner.test.d.ts +23 -0
  621. package/dist/tests/integration/neural/preference-learner.test.d.ts.map +1 -0
  622. package/dist/tests/integration/neural/preference-learner.test.js +289 -0
  623. package/dist/tests/integration/neural/preference-learner.test.js.map +1 -0
  624. package/dist/tests/integration/neural/privacy.test.d.ts +19 -0
  625. package/dist/tests/integration/neural/privacy.test.d.ts.map +1 -0
  626. package/dist/tests/integration/neural/privacy.test.js +249 -0
  627. package/dist/tests/integration/neural/privacy.test.js.map +1 -0
  628. package/dist/tests/integration/neural/setup.d.ts +175 -0
  629. package/dist/tests/integration/neural/setup.d.ts.map +1 -0
  630. package/dist/tests/integration/neural/setup.js +487 -0
  631. package/dist/tests/integration/neural/setup.js.map +1 -0
  632. package/dist/tests/integration/neural/signal-collection.test.d.ts +21 -0
  633. package/dist/tests/integration/neural/signal-collection.test.d.ts.map +1 -0
  634. package/dist/tests/integration/neural/signal-collection.test.js +232 -0
  635. package/dist/tests/integration/neural/signal-collection.test.js.map +1 -0
  636. package/dist/tests/language-detector.test.d.ts +13 -0
  637. package/dist/tests/language-detector.test.d.ts.map +1 -0
  638. package/dist/tests/language-detector.test.js +674 -0
  639. package/dist/tests/language-detector.test.js.map +1 -0
  640. package/dist/tests/learning/PatternStore.test.d.ts +8 -0
  641. package/dist/tests/learning/PatternStore.test.d.ts.map +1 -0
  642. package/dist/tests/learning/PatternStore.test.js +589 -0
  643. package/dist/tests/learning/PatternStore.test.js.map +1 -0
  644. package/dist/tests/learning/ReasoningBankIntegration.test.d.ts +8 -0
  645. package/dist/tests/learning/ReasoningBankIntegration.test.d.ts.map +1 -0
  646. package/dist/tests/learning/ReasoningBankIntegration.test.js +269 -0
  647. package/dist/tests/learning/ReasoningBankIntegration.test.js.map +1 -0
  648. package/dist/tests/routing/SONARouter.test.d.ts +8 -0
  649. package/dist/tests/routing/SONARouter.test.d.ts.map +1 -0
  650. package/dist/tests/routing/SONARouter.test.js +400 -0
  651. package/dist/tests/routing/SONARouter.test.js.map +1 -0
  652. package/dist/tests/security/ContinuousSecurity.test.js +10 -12
  653. package/dist/tests/security/ContinuousSecurity.test.js.map +1 -1
  654. package/dist/tests/security/SkillSandbox.test.d.ts +8 -0
  655. package/dist/tests/security/SkillSandbox.test.d.ts.map +1 -0
  656. package/dist/tests/security/SkillSandbox.test.js +321 -0
  657. package/dist/tests/security/SkillSandbox.test.js.map +1 -0
  658. package/dist/tests/sync/SyncConfigRepository.test.d.ts +7 -0
  659. package/dist/tests/sync/SyncConfigRepository.test.d.ts.map +1 -0
  660. package/dist/tests/sync/SyncConfigRepository.test.js +154 -0
  661. package/dist/tests/sync/SyncConfigRepository.test.js.map +1 -0
  662. package/dist/tests/sync/SyncEngine.test.d.ts +7 -0
  663. package/dist/tests/sync/SyncEngine.test.d.ts.map +1 -0
  664. package/dist/tests/sync/SyncEngine.test.js +300 -0
  665. package/dist/tests/sync/SyncEngine.test.js.map +1 -0
  666. package/dist/tests/sync/SyncHistoryRepository.test.d.ts +7 -0
  667. package/dist/tests/sync/SyncHistoryRepository.test.d.ts.map +1 -0
  668. package/dist/tests/sync/SyncHistoryRepository.test.js +220 -0
  669. package/dist/tests/sync/SyncHistoryRepository.test.js.map +1 -0
  670. package/dist/tests/telemetry/posthog.test.d.ts +13 -0
  671. package/dist/tests/telemetry/posthog.test.d.ts.map +1 -0
  672. package/dist/tests/telemetry/posthog.test.js +600 -0
  673. package/dist/tests/telemetry/posthog.test.js.map +1 -0
  674. package/dist/tests/testing/MultiLLMProvider.test.d.ts +14 -0
  675. package/dist/tests/testing/MultiLLMProvider.test.d.ts.map +1 -0
  676. package/dist/tests/testing/MultiLLMProvider.test.js +438 -0
  677. package/dist/tests/testing/MultiLLMProvider.test.js.map +1 -0
  678. package/package.json +20 -5
  679. package/dist/src/security/RateLimiter.d.ts +0 -337
  680. package/dist/src/security/RateLimiter.d.ts.map +0 -1
  681. package/dist/src/security/RateLimiter.js +0 -782
  682. package/dist/src/security/RateLimiter.js.map +0 -1
  683. package/dist/src/security/scanner.d.ts.map +0 -1
  684. package/dist/src/security/scanner.js.map +0 -1
@@ -0,0 +1,47 @@
1
+ /**
2
+ * SMI-1189: Scanner
3
+ *
4
+ * Main scanning logic for imported skills.
5
+ */
6
+ import { SecurityScanner } from '../../security/index.js';
7
+ import type { 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
+ }
26
+ /** Default scanner configuration */
27
+ export declare const DEFAULT_CONFIG: ScannerConfig;
28
+ /**
29
+ * Scan a single skill and return the result
30
+ *
31
+ * @param skill - The skill to scan
32
+ * @param scanner - The security scanner instance
33
+ * @param config - Trust scorer configuration
34
+ * @returns The scan result
35
+ */
36
+ export declare function scanSkill(skill: ImportedSkill, scanner: SecurityScanner, config?: TrustScorerConfig): SkillScanResult;
37
+ /** Default CLI options */
38
+ export declare const DEFAULT_CLI_OPTIONS: ScannerCliOptions;
39
+ /**
40
+ * Scan all imported skills
41
+ *
42
+ * @param inputPath - Path to the imported skills JSON file
43
+ * @param config - Scanner configuration
44
+ * @param cliOptions - CLI options for output control
45
+ */
46
+ export declare function scanImportedSkills(inputPath: string, config?: ScannerConfig, cliOptions?: Partial<ScannerCliOptions>): Promise<void>;
47
+ //# 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,aAAa,EACb,eAAe,EAEf,iBAAiB,EAElB,MAAM,YAAY,CAAA;AACnB,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;CACzB;AAED,oCAAoC;AACpC,eAAO,MAAM,cAAc,EAAE,aAQ5B,CAAA;AAED;;;;;;;GAOG;AACH,wBAAgB,SAAS,CACvB,KAAK,EAAE,aAAa,EACpB,OAAO,EAAE,eAAe,EACxB,MAAM,GAAE,iBAAwC,GAC/C,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,CA8Kf"}
@@ -0,0 +1,257 @@
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 { shouldQuarantine, getPassFailStats, calculateAverageRiskScore, calculateMaxRiskScore, DEFAULT_TRUST_CONFIG, } from './trust-scorer.js';
9
+ import { determineSeverityCategory, countBySeverity } from './categorizer.js';
10
+ import { extractScannableContent, readImportedSkills, ensureDirectoryExists, fileExists, writeJsonFile, } from './file-scanner.js';
11
+ import { formatDuration, logHeader, logFindings, logProgress, logCompletion, logFileOutput, logScanStart, logProgressBar, clearProgressLine, logQuarantineTable, logCategorizedResults, } from './logger.js';
12
+ import { logSummary, generateSecurityReport, generateQuarantineOutput, generateSafeSkillsOutput, logRecommendations, } from './reporter.js';
13
+ /** Default scanner configuration */
14
+ export const DEFAULT_CONFIG = {
15
+ defaultInput: './data/imported-skills.json',
16
+ outputDir: './data',
17
+ scannerOptions: {
18
+ riskThreshold: 40,
19
+ },
20
+ trustConfig: DEFAULT_TRUST_CONFIG,
21
+ progressInterval: 100,
22
+ };
23
+ /**
24
+ * Scan a single skill and return the result
25
+ *
26
+ * @param skill - The skill to scan
27
+ * @param scanner - The security scanner instance
28
+ * @param config - Trust scorer configuration
29
+ * @returns The scan result
30
+ */
31
+ export function scanSkill(skill, scanner, config = DEFAULT_TRUST_CONFIG) {
32
+ const content = extractScannableContent(skill);
33
+ const report = scanner.scan(skill.id, content);
34
+ const isQuarantined = shouldQuarantine(report, config);
35
+ const severityCategory = determineSeverityCategory(report.findings);
36
+ return {
37
+ skillId: skill.id,
38
+ skillName: skill.name,
39
+ author: skill.author || 'unknown',
40
+ source: skill.source || 'unknown',
41
+ scanReport: report,
42
+ severityCategory,
43
+ isQuarantined,
44
+ scanTimestamp: new Date().toISOString(),
45
+ };
46
+ }
47
+ /** Default CLI options */
48
+ export const DEFAULT_CLI_OPTIONS = {
49
+ json: false,
50
+ verbose: false,
51
+ quiet: false,
52
+ inputPath: DEFAULT_CONFIG.defaultInput,
53
+ };
54
+ /**
55
+ * Generate JSON output for machine-readable format
56
+ */
57
+ function generateJsonOutput(results, config, durationMs) {
58
+ const { passed, quarantined: quarantinedCount } = getPassFailStats(results);
59
+ const bySeverity = countBySeverity(results);
60
+ const avgRiskScore = calculateAverageRiskScore(results);
61
+ const maxRiskScore = calculateMaxRiskScore(results);
62
+ const quarantinedSkills = results
63
+ .filter((r) => r.isQuarantined)
64
+ .sort((a, b) => b.scanReport.riskScore - a.scanReport.riskScore)
65
+ .map((r) => ({
66
+ skillId: r.skillId,
67
+ riskScore: r.scanReport.riskScore,
68
+ severity: r.severityCategory,
69
+ topFinding: r.scanReport.findings.length > 0
70
+ ? `${r.scanReport.findings[0].type}: ${r.scanReport.findings[0].message}`
71
+ : 'N/A',
72
+ }));
73
+ const safeSkills = results
74
+ .filter((r) => !r.isQuarantined)
75
+ .sort((a, b) => a.scanReport.riskScore - b.scanReport.riskScore)
76
+ .map((r) => ({
77
+ skillId: r.skillId,
78
+ riskScore: r.scanReport.riskScore,
79
+ }));
80
+ return {
81
+ success: true,
82
+ summary: {
83
+ totalScanned: results.length,
84
+ passed,
85
+ quarantined: quarantinedCount,
86
+ bySeverity,
87
+ averageRiskScore: Math.round(avgRiskScore * 100) / 100,
88
+ maxRiskScore,
89
+ duration: Math.round(durationMs),
90
+ skillsPerSecond: Math.round((results.length / durationMs) * 1000 * 10) / 10,
91
+ },
92
+ quarantined: quarantinedSkills,
93
+ safe: safeSkills,
94
+ outputFiles: {
95
+ report: path.join(config.outputDir, 'security-report.json'),
96
+ quarantine: path.join(config.outputDir, 'quarantine-skills.json'),
97
+ safe: path.join(config.outputDir, 'safe-skills.json'),
98
+ },
99
+ };
100
+ }
101
+ /**
102
+ * Scan all imported skills
103
+ *
104
+ * @param inputPath - Path to the imported skills JSON file
105
+ * @param config - Scanner configuration
106
+ * @param cliOptions - CLI options for output control
107
+ */
108
+ export async function scanImportedSkills(inputPath, config = DEFAULT_CONFIG, cliOptions = {}) {
109
+ const options = { ...DEFAULT_CLI_OPTIONS, ...cliOptions, inputPath };
110
+ const startTime = performance.now();
111
+ // Validate input file exists (always check, regardless of output mode)
112
+ if (!fileExists(inputPath)) {
113
+ if (options.json) {
114
+ console.log(JSON.stringify({ success: false, error: `Input file not found: ${inputPath}` }));
115
+ }
116
+ else {
117
+ console.error(`Error: Input file not found: ${inputPath}`);
118
+ console.error('Usage: npx tsx packages/core/src/scripts/scan-imported-skills.ts [options] [path-to-imported-skills.json]');
119
+ console.error('\nOptions:');
120
+ console.error(' --json Output results in JSON format (machine-readable)');
121
+ console.error(' --verbose Show detailed output');
122
+ console.error(' --quiet Minimal output');
123
+ }
124
+ process.exit(1);
125
+ }
126
+ // Ensure output directory exists
127
+ ensureDirectoryExists(config.outputDir);
128
+ // Read and parse imported skills
129
+ let skills;
130
+ try {
131
+ skills = await readImportedSkills(inputPath);
132
+ }
133
+ catch (error) {
134
+ if (options.json) {
135
+ console.log(JSON.stringify({
136
+ success: false,
137
+ error: `Failed to read input: ${error.message}`,
138
+ }));
139
+ }
140
+ else {
141
+ console.error(`Error reading/parsing input file: ${error.message}`);
142
+ }
143
+ process.exit(1);
144
+ }
145
+ // For JSON output, skip all console logging until the end
146
+ if (!options.json && !options.quiet) {
147
+ logScanStart(skills.length, inputPath, config.outputDir);
148
+ }
149
+ // Initialize scanner
150
+ const scanner = new SecurityScanner(config.scannerOptions);
151
+ // Scan all skills
152
+ const results = [];
153
+ const allFindings = [];
154
+ let processedCount = 0;
155
+ // Use progress bar for interactive output
156
+ const useProgressBar = !options.json && !options.quiet && process.stdout.isTTY;
157
+ for (const skill of skills) {
158
+ processedCount++;
159
+ const result = scanSkill(skill, scanner, config.trustConfig);
160
+ results.push(result);
161
+ // Collect findings with skill context
162
+ for (const finding of result.scanReport.findings) {
163
+ allFindings.push({ ...finding, skillId: skill.id });
164
+ }
165
+ // Log progress
166
+ if (useProgressBar) {
167
+ logProgressBar(processedCount, skills.length, true);
168
+ }
169
+ else if (!options.json && !options.quiet && processedCount % config.progressInterval === 0) {
170
+ logProgress(processedCount, skills.length);
171
+ }
172
+ }
173
+ // Clear progress bar line
174
+ if (useProgressBar) {
175
+ clearProgressLine();
176
+ }
177
+ if (!options.json && !options.quiet) {
178
+ logCompletion(processedCount, skills.length);
179
+ }
180
+ // Log critical and high findings (if not JSON mode)
181
+ const criticalFindings = allFindings.filter((f) => f.severity === 'critical');
182
+ const highFindings = allFindings.filter((f) => f.severity === 'high');
183
+ if (!options.json && !options.quiet) {
184
+ logFindings(criticalFindings, 20, 'CRITICAL FINDINGS');
185
+ logFindings(highFindings, 10, 'HIGH SEVERITY FINDINGS');
186
+ }
187
+ // Print categorized results
188
+ if (!options.json && !options.quiet) {
189
+ logCategorizedResults(results);
190
+ }
191
+ // Print quarantine table (if not JSON mode)
192
+ if (!options.json && !options.quiet) {
193
+ logHeader('QUARANTINED SKILLS');
194
+ logQuarantineTable(results);
195
+ }
196
+ // Print summary
197
+ if (!options.json && !options.quiet) {
198
+ logSummary(results);
199
+ }
200
+ // Generate output files
201
+ if (!options.json && !options.quiet) {
202
+ console.log('Generating output files...\n');
203
+ }
204
+ // 1. Full security report
205
+ const securityReport = generateSecurityReport(results, allFindings, inputPath);
206
+ const reportPath = path.join(config.outputDir, 'security-report.json');
207
+ await writeJsonFile(reportPath, securityReport);
208
+ if (!options.json && !options.quiet) {
209
+ logFileOutput('security-report.json', results.length);
210
+ }
211
+ // 2. Quarantine list
212
+ const quarantineOutput = generateQuarantineOutput(results);
213
+ const quarantinePath = path.join(config.outputDir, 'quarantine-skills.json');
214
+ await writeJsonFile(quarantinePath, quarantineOutput);
215
+ if (!options.json && !options.quiet) {
216
+ logFileOutput('quarantine-skills.json', quarantineOutput.count, 'blocked');
217
+ }
218
+ // 3. Safe skills list
219
+ const safeOutput = generateSafeSkillsOutput(results);
220
+ const safePath = path.join(config.outputDir, 'safe-skills.json');
221
+ await writeJsonFile(safePath, safeOutput);
222
+ if (!options.json && !options.quiet) {
223
+ logFileOutput('safe-skills.json', safeOutput.count, 'approved');
224
+ }
225
+ // Final timing
226
+ const endTime = performance.now();
227
+ const durationMs = endTime - startTime;
228
+ const duration = formatDuration(durationMs);
229
+ // JSON output mode
230
+ if (options.json) {
231
+ const jsonOutput = generateJsonOutput(results, config, durationMs);
232
+ console.log(JSON.stringify(jsonOutput, null, 2));
233
+ return;
234
+ }
235
+ // Human-readable completion output
236
+ if (!options.quiet) {
237
+ const border = '═'.repeat(60);
238
+ console.log();
239
+ console.log('\x1b[36m' + border + '\x1b[0m');
240
+ console.log('\x1b[1m SCAN COMPLETE\x1b[0m');
241
+ console.log('\x1b[36m' + border + '\x1b[0m');
242
+ console.log();
243
+ console.log(` Duration: ${duration}`);
244
+ console.log(` Skills per second: ${((results.length / durationMs) * 1000).toFixed(1)}`);
245
+ console.log();
246
+ console.log(' Output files:');
247
+ console.log(` - ${reportPath}`);
248
+ console.log(` - ${quarantinePath}`);
249
+ console.log(` - ${safePath}`);
250
+ console.log();
251
+ console.log('\x1b[36m' + border + '\x1b[0m');
252
+ console.log();
253
+ // Recommendations
254
+ logRecommendations(results, criticalFindings.length);
255
+ }
256
+ }
257
+ //# sourceMappingURL=scanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanner.js","sourceRoot":"","sources":["../../../../src/scripts/skill-scanner/scanner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * SMI-1189: Trust Scorer
3
+ *
4
+ * Trust score calculation and quarantine decision logic.
5
+ */
6
+ import type { ScanReport } from '../../security/index.js';
7
+ /**
8
+ * Configuration for trust scoring
9
+ */
10
+ export interface TrustScorerConfig {
11
+ /** Risk threshold for quarantine (skills at or above this are quarantined) */
12
+ quarantineThreshold: number;
13
+ }
14
+ /** Default trust scorer configuration */
15
+ export declare const DEFAULT_TRUST_CONFIG: TrustScorerConfig;
16
+ /**
17
+ * Determines if a skill should be quarantined based on findings
18
+ *
19
+ * A skill is quarantined if:
20
+ * 1. Has critical or high severity findings
21
+ * 2. Risk score exceeds threshold
22
+ * 3. Scan failed (passed = false)
23
+ *
24
+ * @param report - The scan report for the skill
25
+ * @param config - Trust scorer configuration
26
+ * @returns true if the skill should be quarantined
27
+ */
28
+ export declare function shouldQuarantine(report: ScanReport, config?: TrustScorerConfig): boolean;
29
+ /**
30
+ * Calculate average risk score from results
31
+ *
32
+ * @param results - Array of scan results with risk scores
33
+ * @returns Average risk score (0 if no results)
34
+ */
35
+ export declare function calculateAverageRiskScore(results: Array<{
36
+ scanReport: ScanReport;
37
+ }>): number;
38
+ /**
39
+ * Calculate maximum risk score from results
40
+ *
41
+ * @param results - Array of scan results with risk scores
42
+ * @returns Maximum risk score (0 if no results)
43
+ */
44
+ export declare function calculateMaxRiskScore(results: Array<{
45
+ scanReport: ScanReport;
46
+ }>): number;
47
+ /**
48
+ * Get pass/fail statistics from results
49
+ *
50
+ * @param results - Array of scan results
51
+ * @returns Object with passed and quarantined counts
52
+ */
53
+ export declare function getPassFailStats(results: Array<{
54
+ isQuarantined: boolean;
55
+ }>): {
56
+ passed: number;
57
+ quarantined: number;
58
+ };
59
+ //# 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;;;;GAIG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AAEzD;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,8EAA8E;IAC9E,mBAAmB,EAAE,MAAM,CAAA;CAC5B;AAED,yCAAyC;AACzC,eAAO,MAAM,oBAAoB,EAAE,iBAElC,CAAA;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,UAAU,EAClB,MAAM,GAAE,iBAAwC,GAC/C,OAAO,CAMT;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"}
@@ -0,0 +1,62 @@
1
+ /**
2
+ * SMI-1189: Trust Scorer
3
+ *
4
+ * Trust score calculation and quarantine decision logic.
5
+ */
6
+ /** Default trust scorer configuration */
7
+ export const DEFAULT_TRUST_CONFIG = {
8
+ quarantineThreshold: 40,
9
+ };
10
+ /**
11
+ * Determines if a skill should be quarantined based on findings
12
+ *
13
+ * A skill is quarantined if:
14
+ * 1. Has critical or high severity findings
15
+ * 2. Risk score exceeds threshold
16
+ * 3. Scan failed (passed = false)
17
+ *
18
+ * @param report - The scan report for the skill
19
+ * @param config - Trust scorer configuration
20
+ * @returns true if the skill should be quarantined
21
+ */
22
+ export function shouldQuarantine(report, config = DEFAULT_TRUST_CONFIG) {
23
+ return (!report.passed ||
24
+ report.riskScore >= config.quarantineThreshold ||
25
+ report.findings.some((f) => f.severity === 'critical' || f.severity === 'high'));
26
+ }
27
+ /**
28
+ * Calculate average risk score from results
29
+ *
30
+ * @param results - Array of scan results with risk scores
31
+ * @returns Average risk score (0 if no results)
32
+ */
33
+ export function calculateAverageRiskScore(results) {
34
+ const total = results.length;
35
+ if (total === 0)
36
+ return 0;
37
+ const sum = results.reduce((acc, r) => acc + r.scanReport.riskScore, 0);
38
+ return sum / total;
39
+ }
40
+ /**
41
+ * Calculate maximum risk score from results
42
+ *
43
+ * @param results - Array of scan results with risk scores
44
+ * @returns Maximum risk score (0 if no results)
45
+ */
46
+ export function calculateMaxRiskScore(results) {
47
+ if (results.length === 0)
48
+ return 0;
49
+ return Math.max(...results.map((r) => r.scanReport.riskScore));
50
+ }
51
+ /**
52
+ * Get pass/fail statistics from results
53
+ *
54
+ * @param results - Array of scan results
55
+ * @returns Object with passed and quarantined counts
56
+ */
57
+ export function getPassFailStats(results) {
58
+ const passed = results.filter((r) => !r.isQuarantined).length;
59
+ const quarantined = results.filter((r) => r.isQuarantined).length;
60
+ return { passed, quarantined };
61
+ }
62
+ //# sourceMappingURL=trust-scorer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trust-scorer.js","sourceRoot":"","sources":["../../../../src/scripts/skill-scanner/trust-scorer.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAYH,yCAAyC;AACzC,MAAM,CAAC,MAAM,oBAAoB,GAAsB;IACrD,mBAAmB,EAAE,EAAE;CACxB,CAAA;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,gBAAgB,CAC9B,MAAkB,EAClB,SAA4B,oBAAoB;IAEhD,OAAO,CACL,CAAC,MAAM,CAAC,MAAM;QACd,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,mBAAmB;QAC9C,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,UAAU,IAAI,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,CAChF,CAAA;AACH,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,yBAAyB,CAAC,OAA0C;IAClF,MAAM,KAAK,GAAG,OAAO,CAAC,MAAM,CAAA;IAC5B,IAAI,KAAK,KAAK,CAAC;QAAE,OAAO,CAAC,CAAA;IAEzB,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC,CAAC,CAAA;IACvE,OAAO,GAAG,GAAG,KAAK,CAAA;AACpB,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,qBAAqB,CAAC,OAA0C;IAC9E,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,CAAC,CAAA;IAClC,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAA;AAChE,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,gBAAgB,CAAC,OAA0C;IAIzE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAA;IAC7D,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAA;IAEjE,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,CAAA;AAChC,CAAC"}
@@ -0,0 +1,142 @@
1
+ /**
2
+ * SMI-1189: Skill Scanner Types
3
+ *
4
+ * Type definitions for the security scanner script.
5
+ */
6
+ import type { ScanReport, SecurityFinding, SecuritySeverity } from '../../security/index.js';
7
+ /**
8
+ * Structure of an imported skill in imported-skills.json
9
+ */
10
+ export interface ImportedSkill {
11
+ id: string;
12
+ name: string;
13
+ description?: string;
14
+ author?: string;
15
+ content?: string;
16
+ repo_url?: string;
17
+ source?: string;
18
+ tags?: string[];
19
+ instructions?: string;
20
+ trigger?: string;
21
+ metadata?: Record<string, unknown>;
22
+ }
23
+ /**
24
+ * Severity categories for output organization
25
+ */
26
+ export type SeverityCategory = 'CRITICAL' | 'HIGH' | 'MEDIUM' | 'LOW';
27
+ /**
28
+ * Skill scan result with categorization
29
+ */
30
+ export interface SkillScanResult {
31
+ skillId: string;
32
+ skillName: string;
33
+ author: string;
34
+ source: string;
35
+ scanReport: ScanReport;
36
+ severityCategory: SeverityCategory;
37
+ isQuarantined: boolean;
38
+ scanTimestamp: string;
39
+ }
40
+ /**
41
+ * Full security report output structure
42
+ */
43
+ export interface SecurityReportOutput {
44
+ scanDate: string;
45
+ inputFile: string;
46
+ summary: {
47
+ totalScanned: number;
48
+ passed: number;
49
+ quarantined: number;
50
+ bySeverity: Record<SeverityCategory, number>;
51
+ averageRiskScore: number;
52
+ maxRiskScore: number;
53
+ };
54
+ results: SkillScanResult[];
55
+ topFindings: Array<{
56
+ type: string;
57
+ count: number;
58
+ severity: SecuritySeverity;
59
+ }>;
60
+ }
61
+ /**
62
+ * Quarantine list output structure
63
+ */
64
+ export interface QuarantineOutput {
65
+ generatedAt: string;
66
+ reason: string;
67
+ count: number;
68
+ skills: Array<{
69
+ skillId: string;
70
+ skillName: string;
71
+ author: string;
72
+ riskScore: number;
73
+ severityCategory: SeverityCategory;
74
+ topFindings: string[];
75
+ }>;
76
+ }
77
+ /**
78
+ * Safe skills list output structure
79
+ */
80
+ export interface SafeSkillsOutput {
81
+ generatedAt: string;
82
+ count: number;
83
+ skills: Array<{
84
+ skillId: string;
85
+ skillName: string;
86
+ author: string;
87
+ source: string;
88
+ riskScore: number;
89
+ }>;
90
+ }
91
+ /**
92
+ * Finding with skill context
93
+ */
94
+ export interface FindingWithContext extends SecurityFinding {
95
+ skillId: string;
96
+ }
97
+ /**
98
+ * CLI options for the scanner
99
+ */
100
+ export interface ScannerCliOptions {
101
+ /** Output JSON format for machine-readable output */
102
+ json: boolean;
103
+ /** Show verbose output */
104
+ verbose: boolean;
105
+ /** Quiet mode - minimal output */
106
+ quiet: boolean;
107
+ /** Input file path */
108
+ inputPath: string;
109
+ }
110
+ /**
111
+ * JSON output structure for --json flag
112
+ */
113
+ export interface JsonOutput {
114
+ success: boolean;
115
+ summary: {
116
+ totalScanned: number;
117
+ passed: number;
118
+ quarantined: number;
119
+ bySeverity: Record<SeverityCategory, number>;
120
+ averageRiskScore: number;
121
+ maxRiskScore: number;
122
+ duration: number;
123
+ skillsPerSecond: number;
124
+ };
125
+ quarantined: Array<{
126
+ skillId: string;
127
+ riskScore: number;
128
+ severity: SeverityCategory;
129
+ topFinding: string;
130
+ }>;
131
+ safe: Array<{
132
+ skillId: string;
133
+ riskScore: number;
134
+ }>;
135
+ outputFiles: {
136
+ report: string;
137
+ quarantine: string;
138
+ safe: string;
139
+ };
140
+ }
141
+ export type { ScanReport, SecurityFinding, SecuritySeverity };
142
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/scripts/skill-scanner/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * SMI-1189: Skill Scanner Types
3
+ *
4
+ * Type definitions for the security scanner script.
5
+ */
6
+ export {};
7
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/scripts/skill-scanner/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}