@skillsmith/core 0.4.16 → 0.5.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 (285) hide show
  1. package/CHANGELOG.md +34 -0
  2. package/README.md +57 -2
  3. package/dist/.tsbuildinfo +1 -1
  4. package/dist/src/api/client.d.ts +21 -21
  5. package/dist/src/api/client.d.ts.map +1 -1
  6. package/dist/src/api/client.events.d.ts +39 -0
  7. package/dist/src/api/client.events.d.ts.map +1 -0
  8. package/dist/src/api/client.events.js +77 -0
  9. package/dist/src/api/client.events.js.map +1 -0
  10. package/dist/src/api/client.js +39 -33
  11. package/dist/src/api/client.js.map +1 -1
  12. package/dist/src/api/event-batcher.d.ts +81 -0
  13. package/dist/src/api/event-batcher.d.ts.map +1 -0
  14. package/dist/src/api/event-batcher.js +191 -0
  15. package/dist/src/api/event-batcher.js.map +1 -0
  16. package/dist/src/api/index.d.ts +1 -0
  17. package/dist/src/api/index.d.ts.map +1 -1
  18. package/dist/src/api/index.js +2 -0
  19. package/dist/src/api/index.js.map +1 -1
  20. package/dist/src/api/schemas.d.ts +62 -4
  21. package/dist/src/api/schemas.d.ts.map +1 -1
  22. package/dist/src/api/schemas.js +45 -0
  23. package/dist/src/api/schemas.js.map +1 -1
  24. package/dist/src/db/migration-runner.d.ts +44 -0
  25. package/dist/src/db/migration-runner.d.ts.map +1 -0
  26. package/dist/src/db/migration-runner.js +175 -0
  27. package/dist/src/db/migration-runner.js.map +1 -0
  28. package/dist/src/db/migration.d.ts.map +1 -1
  29. package/dist/src/db/migration.js +2 -1
  30. package/dist/src/db/migration.js.map +1 -1
  31. package/dist/src/db/migrations/v12-risk-score-history.d.ts +10 -0
  32. package/dist/src/db/migrations/v12-risk-score-history.d.ts.map +1 -0
  33. package/dist/src/db/migrations/v12-risk-score-history.js +25 -0
  34. package/dist/src/db/migrations/v12-risk-score-history.js.map +1 -0
  35. package/dist/src/db/migrations/v13-team-tables.d.ts +11 -0
  36. package/dist/src/db/migrations/v13-team-tables.d.ts.map +1 -0
  37. package/dist/src/db/migrations/v13-team-tables.js +14 -0
  38. package/dist/src/db/migrations/v13-team-tables.js.map +1 -0
  39. package/dist/src/db/schema-sql.d.ts +16 -0
  40. package/dist/src/db/schema-sql.d.ts.map +1 -0
  41. package/dist/src/db/schema-sql.js +161 -0
  42. package/dist/src/db/schema-sql.js.map +1 -0
  43. package/dist/src/db/schema.d.ts +7 -32
  44. package/dist/src/db/schema.d.ts.map +1 -1
  45. package/dist/src/db/schema.js +14 -298
  46. package/dist/src/db/schema.js.map +1 -1
  47. package/dist/src/embeddings/hnsw-store.d.ts +1 -1
  48. package/dist/src/embeddings/hnsw-store.d.ts.map +1 -1
  49. package/dist/src/embeddings/hnsw-store.js +4 -34
  50. package/dist/src/embeddings/hnsw-store.js.map +1 -1
  51. package/dist/src/embeddings/hnsw-store.types.d.ts +18 -0
  52. package/dist/src/embeddings/hnsw-store.types.d.ts.map +1 -1
  53. package/dist/src/embeddings/hnsw-store.types.js.map +1 -1
  54. package/dist/src/exports/repositories.d.ts +1 -0
  55. package/dist/src/exports/repositories.d.ts.map +1 -1
  56. package/dist/src/exports/repositories.js +4 -0
  57. package/dist/src/exports/repositories.js.map +1 -1
  58. package/dist/src/exports/services.d.ts +4 -0
  59. package/dist/src/exports/services.d.ts.map +1 -1
  60. package/dist/src/exports/services.js +7 -0
  61. package/dist/src/exports/services.js.map +1 -1
  62. package/dist/src/index.d.ts +1 -1
  63. package/dist/src/index.js +1 -1
  64. package/dist/src/learning/PatternStore.d.ts.map +1 -1
  65. package/dist/src/learning/PatternStore.js +2 -9
  66. package/dist/src/learning/PatternStore.js.map +1 -1
  67. package/dist/src/repositories/RiskScoreHistoryRepository.d.ts +37 -0
  68. package/dist/src/repositories/RiskScoreHistoryRepository.d.ts.map +1 -0
  69. package/dist/src/repositories/RiskScoreHistoryRepository.js +66 -0
  70. package/dist/src/repositories/RiskScoreHistoryRepository.js.map +1 -0
  71. package/dist/src/routing/SONARouter.d.ts.map +1 -1
  72. package/dist/src/routing/SONARouter.js +4 -15
  73. package/dist/src/routing/SONARouter.js.map +1 -1
  74. package/dist/src/scoring/index.d.ts +1 -0
  75. package/dist/src/scoring/index.d.ts.map +1 -1
  76. package/dist/src/scoring/index.js +1 -0
  77. package/dist/src/scoring/index.js.map +1 -1
  78. package/dist/src/scoring/quality-score.d.ts +49 -0
  79. package/dist/src/scoring/quality-score.d.ts.map +1 -0
  80. package/dist/src/scoring/quality-score.js +73 -0
  81. package/dist/src/scoring/quality-score.js.map +1 -0
  82. package/dist/src/scripts/__tests__/scan-imported-skills.test.js +10 -0
  83. package/dist/src/scripts/__tests__/scan-imported-skills.test.js.map +1 -1
  84. package/dist/src/scripts/validation/types.d.ts +2 -2
  85. package/dist/src/security/index.d.ts +2 -0
  86. package/dist/src/security/index.d.ts.map +1 -1
  87. package/dist/src/security/index.js +2 -0
  88. package/dist/src/security/index.js.map +1 -1
  89. package/dist/src/security/risk-trend.d.ts +21 -0
  90. package/dist/src/security/risk-trend.d.ts.map +1 -0
  91. package/dist/src/security/risk-trend.js +81 -0
  92. package/dist/src/security/risk-trend.js.map +1 -0
  93. package/dist/src/security/scanner/SecurityScanner.d.ts +6 -2
  94. package/dist/src/security/scanner/SecurityScanner.d.ts.map +1 -1
  95. package/dist/src/security/scanner/SecurityScanner.helpers.d.ts +24 -2
  96. package/dist/src/security/scanner/SecurityScanner.helpers.d.ts.map +1 -1
  97. package/dist/src/security/scanner/SecurityScanner.helpers.js +111 -9
  98. package/dist/src/security/scanner/SecurityScanner.helpers.js.map +1 -1
  99. package/dist/src/security/scanner/SecurityScanner.js +64 -71
  100. package/dist/src/security/scanner/SecurityScanner.js.map +1 -1
  101. package/dist/src/security/scanner/SecurityScanner.ssrf.d.ts +15 -0
  102. package/dist/src/security/scanner/SecurityScanner.ssrf.d.ts.map +1 -0
  103. package/dist/src/security/scanner/SecurityScanner.ssrf.js +76 -0
  104. package/dist/src/security/scanner/SecurityScanner.ssrf.js.map +1 -0
  105. package/dist/src/security/scanner/index.d.ts +1 -1
  106. package/dist/src/security/scanner/index.d.ts.map +1 -1
  107. package/dist/src/security/scanner/index.js +1 -1
  108. package/dist/src/security/scanner/index.js.map +1 -1
  109. package/dist/src/security/scanner/patterns.d.ts +12 -0
  110. package/dist/src/security/scanner/patterns.d.ts.map +1 -1
  111. package/dist/src/security/scanner/patterns.js +57 -0
  112. package/dist/src/security/scanner/patterns.js.map +1 -1
  113. package/dist/src/security/scanner/types.d.ts +3 -1
  114. package/dist/src/security/scanner/types.d.ts.map +1 -1
  115. package/dist/src/security/scanner/weights.d.ts.map +1 -1
  116. package/dist/src/security/scanner/weights.js +2 -0
  117. package/dist/src/security/scanner/weights.js.map +1 -1
  118. package/dist/src/services/skill-config-schema.d.ts +36 -0
  119. package/dist/src/services/skill-config-schema.d.ts.map +1 -0
  120. package/dist/src/services/skill-config-schema.js +76 -0
  121. package/dist/src/services/skill-config-schema.js.map +1 -0
  122. package/dist/src/services/skill-installation.feedback.d.ts +24 -0
  123. package/dist/src/services/skill-installation.feedback.d.ts.map +1 -0
  124. package/dist/src/services/skill-installation.feedback.js +37 -0
  125. package/dist/src/services/skill-installation.feedback.js.map +1 -0
  126. package/dist/src/services/skill-installation.helpers.d.ts +88 -0
  127. package/dist/src/services/skill-installation.helpers.d.ts.map +1 -0
  128. package/dist/src/services/skill-installation.helpers.js +377 -0
  129. package/dist/src/services/skill-installation.helpers.js.map +1 -0
  130. package/dist/src/services/skill-installation.service.d.ts +37 -0
  131. package/dist/src/services/skill-installation.service.d.ts.map +1 -0
  132. package/dist/src/services/skill-installation.service.js +432 -0
  133. package/dist/src/services/skill-installation.service.js.map +1 -0
  134. package/dist/src/services/skill-installation.types.d.ts +166 -0
  135. package/dist/src/services/skill-installation.types.d.ts.map +1 -0
  136. package/dist/src/services/skill-installation.types.js +38 -0
  137. package/dist/src/services/skill-installation.types.js.map +1 -0
  138. package/dist/src/services/skill-manifest.d.ts +20 -0
  139. package/dist/src/services/skill-manifest.d.ts.map +1 -0
  140. package/dist/src/services/skill-manifest.js +84 -0
  141. package/dist/src/services/skill-manifest.js.map +1 -0
  142. package/dist/src/session/SessionManager.helpers.d.ts +1 -27
  143. package/dist/src/session/SessionManager.helpers.d.ts.map +1 -1
  144. package/dist/src/session/SessionManager.helpers.js +0 -64
  145. package/dist/src/session/SessionManager.helpers.js.map +1 -1
  146. package/dist/src/session/SessionManager.memory.d.ts +12 -11
  147. package/dist/src/session/SessionManager.memory.d.ts.map +1 -1
  148. package/dist/src/session/SessionManager.memory.js +23 -115
  149. package/dist/src/session/SessionManager.memory.js.map +1 -1
  150. package/dist/src/session/SessionManager.types.d.ts +0 -37
  151. package/dist/src/session/SessionManager.types.d.ts.map +1 -1
  152. package/dist/src/session/SessionManager.types.js.map +1 -1
  153. package/dist/src/session/SessionRecovery.js +4 -4
  154. package/dist/src/session/SessionRecovery.js.map +1 -1
  155. package/dist/src/testing/MultiLLMProvider.d.ts.map +1 -1
  156. package/dist/src/testing/MultiLLMProvider.js +5 -19
  157. package/dist/src/testing/MultiLLMProvider.js.map +1 -1
  158. package/dist/src/types.d.ts +2 -0
  159. package/dist/src/types.d.ts.map +1 -1
  160. package/dist/tests/SecurityScanner.ai-defence.test.d.ts +6 -0
  161. package/dist/tests/SecurityScanner.ai-defence.test.d.ts.map +1 -0
  162. package/dist/tests/SecurityScanner.ai-defence.test.js +221 -0
  163. package/dist/tests/SecurityScanner.ai-defence.test.js.map +1 -0
  164. package/dist/tests/SecurityScanner.performance.test.d.ts +6 -0
  165. package/dist/tests/SecurityScanner.performance.test.d.ts.map +1 -0
  166. package/dist/tests/SecurityScanner.performance.test.js +132 -0
  167. package/dist/tests/SecurityScanner.performance.test.js.map +1 -0
  168. package/dist/tests/SecurityScanner.scoring.test.d.ts +6 -0
  169. package/dist/tests/SecurityScanner.scoring.test.d.ts.map +1 -0
  170. package/dist/tests/SecurityScanner.scoring.test.js +197 -0
  171. package/dist/tests/SecurityScanner.scoring.test.js.map +1 -0
  172. package/dist/tests/SecurityScanner.test.d.ts +2 -2
  173. package/dist/tests/SecurityScanner.test.js +2 -520
  174. package/dist/tests/SecurityScanner.test.js.map +1 -1
  175. package/dist/tests/SkillMatcher.test.js +5 -5
  176. package/dist/tests/SkillMatcher.test.js.map +1 -1
  177. package/dist/tests/billing/StripeClient.test.d.ts +18 -0
  178. package/dist/tests/billing/StripeClient.test.d.ts.map +1 -0
  179. package/dist/tests/billing/StripeClient.test.js +566 -0
  180. package/dist/tests/billing/StripeClient.test.js.map +1 -0
  181. package/dist/tests/billing/StripeWebhookHandler.test.d.ts +16 -0
  182. package/dist/tests/billing/StripeWebhookHandler.test.d.ts.map +1 -0
  183. package/dist/tests/billing/StripeWebhookHandler.test.js +240 -0
  184. package/dist/tests/billing/StripeWebhookHandler.test.js.map +1 -0
  185. package/dist/tests/billing/stripe-helpers.test.d.ts +7 -0
  186. package/dist/tests/billing/stripe-helpers.test.d.ts.map +1 -0
  187. package/dist/tests/billing/stripe-helpers.test.js +91 -0
  188. package/dist/tests/billing/stripe-helpers.test.js.map +1 -0
  189. package/dist/tests/billing/webhook-handlers.test.d.ts +16 -0
  190. package/dist/tests/billing/webhook-handlers.test.d.ts.map +1 -0
  191. package/dist/tests/billing/webhook-handlers.test.js +519 -0
  192. package/dist/tests/billing/webhook-handlers.test.js.map +1 -0
  193. package/dist/tests/db/migration.test.d.ts +11 -0
  194. package/dist/tests/db/migration.test.d.ts.map +1 -0
  195. package/dist/tests/db/migration.test.js +265 -0
  196. package/dist/tests/db/migration.test.js.map +1 -0
  197. package/dist/tests/db/schema-migrations.test.js +8 -6
  198. package/dist/tests/db/schema-migrations.test.js.map +1 -1
  199. package/dist/tests/integration/events-batch-contract.test.d.ts +12 -0
  200. package/dist/tests/integration/events-batch-contract.test.d.ts.map +1 -0
  201. package/dist/tests/integration/events-batch-contract.test.js +69 -0
  202. package/dist/tests/integration/events-batch-contract.test.js.map +1 -0
  203. package/dist/tests/scoring/quality-score.test.d.ts +7 -0
  204. package/dist/tests/scoring/quality-score.test.d.ts.map +1 -0
  205. package/dist/tests/scoring/quality-score.test.js +78 -0
  206. package/dist/tests/scoring/quality-score.test.js.map +1 -0
  207. package/dist/tests/security/ContinuousSecurity.false-positives.test.d.ts +6 -0
  208. package/dist/tests/security/ContinuousSecurity.false-positives.test.d.ts.map +1 -0
  209. package/dist/tests/security/ContinuousSecurity.false-positives.test.js +89 -0
  210. package/dist/tests/security/ContinuousSecurity.false-positives.test.js.map +1 -0
  211. package/dist/tests/security/ContinuousSecurity.performance.test.d.ts +6 -0
  212. package/dist/tests/security/ContinuousSecurity.performance.test.d.ts.map +1 -0
  213. package/dist/tests/security/ContinuousSecurity.performance.test.js +177 -0
  214. package/dist/tests/security/ContinuousSecurity.performance.test.js.map +1 -0
  215. package/dist/tests/security/ContinuousSecurity.reporting.test.d.ts +6 -0
  216. package/dist/tests/security/ContinuousSecurity.reporting.test.d.ts.map +1 -0
  217. package/dist/tests/security/ContinuousSecurity.reporting.test.js +106 -0
  218. package/dist/tests/security/ContinuousSecurity.reporting.test.js.map +1 -0
  219. package/dist/tests/security/ContinuousSecurity.test.d.ts +9 -2
  220. package/dist/tests/security/ContinuousSecurity.test.d.ts.map +1 -1
  221. package/dist/tests/security/ContinuousSecurity.test.js +9 -336
  222. package/dist/tests/security/ContinuousSecurity.test.js.map +1 -1
  223. package/dist/tests/security/pii-detection.test.d.ts +7 -0
  224. package/dist/tests/security/pii-detection.test.d.ts.map +1 -0
  225. package/dist/tests/security/pii-detection.test.js +91 -0
  226. package/dist/tests/security/pii-detection.test.js.map +1 -0
  227. package/dist/tests/security/risk-trend.test.d.ts +6 -0
  228. package/dist/tests/security/risk-trend.test.d.ts.map +1 -0
  229. package/dist/tests/security/risk-trend.test.js +68 -0
  230. package/dist/tests/security/risk-trend.test.js.map +1 -0
  231. package/dist/tests/security/scanner-regression-guard.test.d.ts +12 -0
  232. package/dist/tests/security/scanner-regression-guard.test.d.ts.map +1 -0
  233. package/dist/tests/security/scanner-regression-guard.test.js +111 -0
  234. package/dist/tests/security/scanner-regression-guard.test.js.map +1 -0
  235. package/dist/tests/security.test.js +200 -0
  236. package/dist/tests/security.test.js.map +1 -1
  237. package/dist/tests/services/aidefence-feedback.test.d.ts +6 -0
  238. package/dist/tests/services/aidefence-feedback.test.d.ts.map +1 -0
  239. package/dist/tests/services/aidefence-feedback.test.js +115 -0
  240. package/dist/tests/services/aidefence-feedback.test.js.map +1 -0
  241. package/dist/tests/services/dep-quarantine-check.test.d.ts +5 -0
  242. package/dist/tests/services/dep-quarantine-check.test.d.ts.map +1 -0
  243. package/dist/tests/services/dep-quarantine-check.test.js +92 -0
  244. package/dist/tests/services/dep-quarantine-check.test.js.map +1 -0
  245. package/dist/tests/services/skill-config-schema.test.d.ts +5 -0
  246. package/dist/tests/services/skill-config-schema.test.d.ts.map +1 -0
  247. package/dist/tests/services/skill-config-schema.test.js +98 -0
  248. package/dist/tests/services/skill-config-schema.test.js.map +1 -0
  249. package/dist/tests/session/SessionManager.helpers.test.js +1 -9
  250. package/dist/tests/session/SessionManager.helpers.test.js.map +1 -1
  251. package/dist/tests/session/SessionManager.memory.test.d.ts +3 -4
  252. package/dist/tests/session/SessionManager.memory.test.d.ts.map +1 -1
  253. package/dist/tests/session/SessionManager.memory.test.js +41 -123
  254. package/dist/tests/session/SessionManager.memory.test.js.map +1 -1
  255. package/dist/tests/sync/BackgroundSyncService.test.d.ts +13 -0
  256. package/dist/tests/sync/BackgroundSyncService.test.d.ts.map +1 -0
  257. package/dist/tests/sync/BackgroundSyncService.test.js +259 -0
  258. package/dist/tests/sync/BackgroundSyncService.test.js.map +1 -0
  259. package/dist/tests/testkit.d.ts +14 -0
  260. package/dist/tests/testkit.d.ts.map +1 -0
  261. package/dist/tests/testkit.js +14 -0
  262. package/dist/tests/testkit.js.map +1 -0
  263. package/dist/tests/unit/api-client-events.test.d.ts +10 -0
  264. package/dist/tests/unit/api-client-events.test.d.ts.map +1 -0
  265. package/dist/tests/unit/api-client-events.test.js +73 -0
  266. package/dist/tests/unit/api-client-events.test.js.map +1 -0
  267. package/dist/tests/unit/event-batcher.test.d.ts +13 -0
  268. package/dist/tests/unit/event-batcher.test.d.ts.map +1 -0
  269. package/dist/tests/unit/event-batcher.test.js +155 -0
  270. package/dist/tests/unit/event-batcher.test.js.map +1 -0
  271. package/dist/tests/unit/migrations/v10-dependencies.test.js +3 -3
  272. package/dist/tests/unit/migrations/v10-dependencies.test.js.map +1 -1
  273. package/dist/tests/unit/services/skill-installation-extended.test.d.ts +8 -0
  274. package/dist/tests/unit/services/skill-installation-extended.test.d.ts.map +1 -0
  275. package/dist/tests/unit/services/skill-installation-extended.test.js +423 -0
  276. package/dist/tests/unit/services/skill-installation-extended.test.js.map +1 -0
  277. package/dist/tests/unit/services/skill-installation.service.test.d.ts +8 -0
  278. package/dist/tests/unit/services/skill-installation.service.test.d.ts.map +1 -0
  279. package/dist/tests/unit/services/skill-installation.service.test.js +342 -0
  280. package/dist/tests/unit/services/skill-installation.service.test.js.map +1 -0
  281. package/package.json +22 -10
  282. package/dist/vitest.config.d.ts +0 -3
  283. package/dist/vitest.config.d.ts.map +0 -1
  284. package/dist/vitest.config.js +0 -13
  285. package/dist/vitest.config.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migration-runner.js","sourceRoot":"","sources":["../../../src/db/migration-runner.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"migration.d.ts","sourceRoot":"","sources":["../../../src/db/migration.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,QAAQ,IAAI,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAIvE,YAAY,EACV,mBAAmB,EACnB,WAAW,EACX,aAAa,EACb,aAAa,EACb,YAAY,EACZ,UAAU,EACV,kBAAkB,EAClB,QAAQ,EACR,gBAAgB,GACjB,MAAM,sBAAsB,CAAA;AAG7B,OAAO,KAAK,EACV,mBAAmB,EACnB,WAAW,EAEX,YAAY,EACZ,gBAAgB,EACjB,MAAM,sBAAsB,CAAA;AAM7B,wBAAgB,wBAAwB,CAAC,EAAE,EAAE,YAAY,GAAG,mBAAmB,CAuD9E;AAED,wBAAgB,yBAAyB,CAAC,EAAE,EAAE,YAAY,GAAG,IAAI,CAmBhE;AAqBD,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,YAAY,EACpB,OAAO,GAAE,YAAyC,GACjD,WAAW,CAiLb;AAMD,wBAAgB,aAAa,CAAC,EAAE,EAAE,YAAY,GAAG,IAAI,CACnD;IACE,SAAS,EAAE,OAAO,CAAA;IAClB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,aAAa,EAAE,MAAM,CAAA;IACrB,cAAc,EAAE,MAAM,CAAA;IACtB,cAAc,EAAE,MAAM,CAAA;IACtB,gBAAgB,EAAE,MAAM,CAAA;CACzB,EACD,WAAW,GAAG,gBAAgB,CAC/B,CAcA;AAED,wBAAgB,gBAAgB,CAC9B,EAAE,EAAE,YAAY,EAChB,MAAM,EAAE;IAAE,WAAW,EAAE,MAAM,CAAC;IAAC,aAAa,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,GACrE,IAAI,CAkBN;AAED,wBAAgB,aAAa,CAC3B,EAAE,EAAE,YAAY,EAChB,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,QAAQ,GAAG,SAAS,EACpD,MAAM,CAAC,EAAE,WAAW,EACpB,KAAK,CAAC,EAAE,MAAM,GACb,MAAM,CAuBR;AAED,wBAAgB,cAAc,CAAC,EAAE,EAAE,YAAY,EAAE,KAAK,SAAK,GAAG,gBAAgB,EAAE,CAI/E"}
1
+ {"version":3,"file":"migration.d.ts","sourceRoot":"","sources":["../../../src/db/migration.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,QAAQ,IAAI,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAKvE,YAAY,EACV,mBAAmB,EACnB,WAAW,EACX,aAAa,EACb,aAAa,EACb,YAAY,EACZ,UAAU,EACV,kBAAkB,EAClB,QAAQ,EACR,gBAAgB,GACjB,MAAM,sBAAsB,CAAA;AAG7B,OAAO,KAAK,EACV,mBAAmB,EACnB,WAAW,EAEX,YAAY,EACZ,gBAAgB,EACjB,MAAM,sBAAsB,CAAA;AAM7B,wBAAgB,wBAAwB,CAAC,EAAE,EAAE,YAAY,GAAG,mBAAmB,CAuD9E;AAED,wBAAgB,yBAAyB,CAAC,EAAE,EAAE,YAAY,GAAG,IAAI,CAmBhE;AAqBD,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,YAAY,EACpB,OAAO,GAAE,YAAyC,GACjD,WAAW,CAiLb;AAMD,wBAAgB,aAAa,CAAC,EAAE,EAAE,YAAY,GAAG,IAAI,CACnD;IACE,SAAS,EAAE,OAAO,CAAA;IAClB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,aAAa,EAAE,MAAM,CAAA;IACrB,cAAc,EAAE,MAAM,CAAA;IACtB,cAAc,EAAE,MAAM,CAAA;IACtB,gBAAgB,EAAE,MAAM,CAAA;CACzB,EACD,WAAW,GAAG,gBAAgB,CAC/B,CAcA;AAED,wBAAgB,gBAAgB,CAC9B,EAAE,EAAE,YAAY,EAChB,MAAM,EAAE;IAAE,WAAW,EAAE,MAAM,CAAC;IAAC,aAAa,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,GACrE,IAAI,CAkBN;AAED,wBAAgB,aAAa,CAC3B,EAAE,EAAE,YAAY,EAChB,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,QAAQ,GAAG,SAAS,EACpD,MAAM,CAAC,EAAE,WAAW,EACpB,KAAK,CAAC,EAAE,MAAM,GACb,MAAM,CAuBR;AAED,wBAAgB,cAAc,CAAC,EAAE,EAAE,YAAY,EAAE,KAAK,SAAK,GAAG,gBAAgB,EAAE,CAI/E"}
@@ -7,7 +7,8 @@
7
7
  *
8
8
  * @see migration-types.ts for type definitions
9
9
  */
10
- import { SCHEMA_VERSION, getSchemaVersion, runMigrationsSafe, MIGRATIONS } from './schema.js';
10
+ import { SCHEMA_VERSION } from './schema.js';
11
+ import { getSchemaVersion, runMigrationsSafe, MIGRATIONS } from './migration-runner.js';
11
12
  // ============================================================================
12
13
  // SMI-1446: Schema Version Compatibility
13
14
  // ============================================================================
@@ -1 +1 @@
1
- {"version":3,"file":"migration.js","sourceRoot":"","sources":["../../../src/db/migration.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"migration.js","sourceRoot":"","sources":["../../../src/db/migration.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * @fileoverview Migration v12 -- Risk score history for trend detection
3
+ * @see SMI-3864
4
+ *
5
+ * Stores point-in-time risk score snapshots after each security scan.
6
+ * No FOREIGN KEY on skill_id — direct-install skills (GitHub URLs) may not
7
+ * exist in the local skills table (Review #6).
8
+ */
9
+ export declare const MIGRATION_V12_SQL = "\nCREATE TABLE IF NOT EXISTS risk_score_history (\n id INTEGER PRIMARY KEY AUTOINCREMENT,\n skill_id TEXT NOT NULL,\n risk_score INTEGER NOT NULL CHECK(risk_score >= 0 AND risk_score <= 100),\n findings_count INTEGER NOT NULL DEFAULT 0,\n content_hash TEXT,\n scanned_at TEXT NOT NULL DEFAULT (datetime('now')),\n source TEXT NOT NULL DEFAULT 'install'\n);\n\nCREATE INDEX IF NOT EXISTS idx_risk_score_history_skill_id\n ON risk_score_history(skill_id);\nCREATE INDEX IF NOT EXISTS idx_risk_score_history_scanned_at\n ON risk_score_history(skill_id, scanned_at);\n";
10
+ //# sourceMappingURL=v12-risk-score-history.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"v12-risk-score-history.d.ts","sourceRoot":"","sources":["../../../../src/db/migrations/v12-risk-score-history.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,eAAO,MAAM,iBAAiB,kkBAe7B,CAAA"}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * @fileoverview Migration v12 -- Risk score history for trend detection
3
+ * @see SMI-3864
4
+ *
5
+ * Stores point-in-time risk score snapshots after each security scan.
6
+ * No FOREIGN KEY on skill_id — direct-install skills (GitHub URLs) may not
7
+ * exist in the local skills table (Review #6).
8
+ */
9
+ export const MIGRATION_V12_SQL = `
10
+ CREATE TABLE IF NOT EXISTS risk_score_history (
11
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
12
+ skill_id TEXT NOT NULL,
13
+ risk_score INTEGER NOT NULL CHECK(risk_score >= 0 AND risk_score <= 100),
14
+ findings_count INTEGER NOT NULL DEFAULT 0,
15
+ content_hash TEXT,
16
+ scanned_at TEXT NOT NULL DEFAULT (datetime('now')),
17
+ source TEXT NOT NULL DEFAULT 'install'
18
+ );
19
+
20
+ CREATE INDEX IF NOT EXISTS idx_risk_score_history_skill_id
21
+ ON risk_score_history(skill_id);
22
+ CREATE INDEX IF NOT EXISTS idx_risk_score_history_scanned_at
23
+ ON risk_score_history(skill_id, scanned_at);
24
+ `;
25
+ //# sourceMappingURL=v12-risk-score-history.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"v12-risk-score-history.js","sourceRoot":"","sources":["../../../../src/db/migrations/v12-risk-score-history.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG;;;;;;;;;;;;;;;CAehC,CAAA"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * @fileoverview Migration v13 -- Team visibility and ownership columns
3
+ * @see SMI-3896: Private Skills Publishing
4
+ *
5
+ * Adds `visibility` and `team_id` columns to the skills table so that
6
+ * private skills can be scoped to a team. Community users see only
7
+ * `visibility = 'public'` skills; team members also see skills matching
8
+ * their team_id.
9
+ */
10
+ export declare const MIGRATION_V13_SQL = "\nALTER TABLE skills ADD COLUMN visibility TEXT NOT NULL DEFAULT 'public';\nALTER TABLE skills ADD COLUMN team_id TEXT;\n";
11
+ //# sourceMappingURL=v13-team-tables.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"v13-team-tables.d.ts","sourceRoot":"","sources":["../../../../src/db/migrations/v13-team-tables.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,eAAO,MAAM,iBAAiB,8HAG7B,CAAA"}
@@ -0,0 +1,14 @@
1
+ /**
2
+ * @fileoverview Migration v13 -- Team visibility and ownership columns
3
+ * @see SMI-3896: Private Skills Publishing
4
+ *
5
+ * Adds `visibility` and `team_id` columns to the skills table so that
6
+ * private skills can be scoped to a team. Community users see only
7
+ * `visibility = 'public'` skills; team members also see skills matching
8
+ * their team_id.
9
+ */
10
+ export const MIGRATION_V13_SQL = `
11
+ ALTER TABLE skills ADD COLUMN visibility TEXT NOT NULL DEFAULT 'public';
12
+ ALTER TABLE skills ADD COLUMN team_id TEXT;
13
+ `;
14
+ //# sourceMappingURL=v13-team-tables.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"v13-team-tables.js","sourceRoot":"","sources":["../../../../src/db/migrations/v13-team-tables.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG;;;CAGhC,CAAA"}
@@ -0,0 +1,16 @@
1
+ /**
2
+ * SQL constants for database schema and FTS5.
3
+ *
4
+ * Extracted to a standalone module (SMI-3910) so both schema.ts and
5
+ * migration-runner.ts can import them without circular dependencies.
6
+ */
7
+ /**
8
+ * SQL statements for creating the database schema
9
+ */
10
+ export declare const SCHEMA_SQL = "\n-- Enable WAL mode for better concurrent performance\nPRAGMA journal_mode = WAL;\nPRAGMA synchronous = NORMAL;\nPRAGMA cache_size = -64000; -- 64MB cache\nPRAGMA temp_store = MEMORY;\n\n-- Schema version tracking\nCREATE TABLE IF NOT EXISTS schema_version (\n version INTEGER PRIMARY KEY,\n applied_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- Skills table - main storage for discovered skills\nCREATE TABLE IF NOT EXISTS skills (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n description TEXT,\n author TEXT,\n repo_url TEXT UNIQUE,\n quality_score REAL CHECK(quality_score IS NULL OR (quality_score >= 0 AND quality_score <= 1)),\n trust_tier TEXT CHECK(trust_tier IN ('verified', 'community', 'experimental', 'unknown')) DEFAULT 'unknown',\n tags TEXT DEFAULT '[]', -- JSON array of tags\n risk_score INTEGER CHECK(risk_score IS NULL OR (risk_score >= 0 AND risk_score <= 100)), -- SMI-825\n security_findings_count INTEGER DEFAULT 0,\n security_scanned_at TEXT,\n security_passed INTEGER, -- boolean: 1 = passed, 0 = failed, NULL = not scanned\n compatibility TEXT DEFAULT '[]', -- SMI-2760: JSON array of IDE/LLM/platform slugs\n content_hash TEXT, -- SMI-3510: SHA-256 hash of SKILL.md for tamper detection\n created_at TEXT NOT NULL DEFAULT (datetime('now')),\n updated_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- FTS5 virtual table for full-text search with BM25 ranking\nCREATE VIRTUAL TABLE IF NOT EXISTS skills_fts USING fts5(\n name,\n description,\n tags,\n author,\n content='skills',\n content_rowid='rowid',\n tokenize='porter unicode61'\n);\n\n-- Triggers to keep FTS index in sync with skills table\nCREATE TRIGGER IF NOT EXISTS skills_ai AFTER INSERT ON skills BEGIN\n INSERT INTO skills_fts(rowid, name, description, tags, author)\n VALUES (NEW.rowid, NEW.name, NEW.description, NEW.tags, NEW.author);\nEND;\n\nCREATE TRIGGER IF NOT EXISTS skills_ad AFTER DELETE ON skills BEGIN\n INSERT INTO skills_fts(skills_fts, rowid, name, description, tags, author)\n VALUES ('delete', OLD.rowid, OLD.name, OLD.description, OLD.tags, OLD.author);\nEND;\n\nCREATE TRIGGER IF NOT EXISTS skills_au AFTER UPDATE ON skills BEGIN\n INSERT INTO skills_fts(skills_fts, rowid, name, description, tags, author)\n VALUES ('delete', OLD.rowid, OLD.name, OLD.description, OLD.tags, OLD.author);\n INSERT INTO skills_fts(rowid, name, description, tags, author)\n VALUES (NEW.rowid, NEW.name, NEW.description, NEW.tags, NEW.author);\nEND;\n\n-- Sources table - tracks where skills are discovered from\nCREATE TABLE IF NOT EXISTS sources (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n type TEXT NOT NULL CHECK(type IN ('github', 'gitlab', 'local', 'registry')),\n url TEXT NOT NULL UNIQUE,\n last_sync_at TEXT,\n is_active INTEGER NOT NULL DEFAULT 1,\n created_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- Categories table - hierarchical organization of skills\nCREATE TABLE IF NOT EXISTS categories (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL UNIQUE,\n description TEXT,\n parent_id TEXT REFERENCES categories(id) ON DELETE SET NULL,\n skill_count INTEGER NOT NULL DEFAULT 0,\n created_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- Skill-Category junction table\nCREATE TABLE IF NOT EXISTS skill_categories (\n skill_id TEXT NOT NULL REFERENCES skills(id) ON DELETE CASCADE,\n category_id TEXT NOT NULL REFERENCES categories(id) ON DELETE CASCADE,\n PRIMARY KEY (skill_id, category_id)\n);\n\n-- Cache table for search results and API responses\nCREATE TABLE IF NOT EXISTS cache (\n key TEXT PRIMARY KEY,\n value TEXT NOT NULL,\n expires_at INTEGER, -- Unix timestamp, NULL for no expiry\n created_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- Indexes for common query patterns\nCREATE INDEX IF NOT EXISTS idx_skills_author ON skills(author);\nCREATE INDEX IF NOT EXISTS idx_skills_trust_tier ON skills(trust_tier);\nCREATE INDEX IF NOT EXISTS idx_skills_quality_score ON skills(quality_score);\nCREATE INDEX IF NOT EXISTS idx_skills_updated_at ON skills(updated_at);\nCREATE INDEX IF NOT EXISTS idx_skills_created_at ON skills(created_at);\nCREATE INDEX IF NOT EXISTS idx_skills_risk_score ON skills(risk_score);\nCREATE INDEX IF NOT EXISTS idx_skills_security_passed ON skills(security_passed);\nCREATE INDEX IF NOT EXISTS idx_sources_type ON sources(type);\nCREATE INDEX IF NOT EXISTS idx_sources_is_active ON sources(is_active);\nCREATE INDEX IF NOT EXISTS idx_categories_parent ON categories(parent_id);\nCREATE INDEX IF NOT EXISTS idx_cache_expires ON cache(expires_at);\n\n-- SMI-733: Audit logs table for security monitoring\n-- See: docs/security/index.md \u00A73 Audit Logging\nCREATE TABLE IF NOT EXISTS audit_logs (\n id TEXT PRIMARY KEY,\n event_type TEXT NOT NULL,\n timestamp TEXT NOT NULL DEFAULT (datetime('now')),\n actor TEXT,\n resource TEXT,\n action TEXT,\n result TEXT,\n metadata TEXT,\n created_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\nCREATE INDEX IF NOT EXISTS idx_audit_event_type ON audit_logs(event_type);\nCREATE INDEX IF NOT EXISTS idx_audit_timestamp ON audit_logs(timestamp);\nCREATE INDEX IF NOT EXISTS idx_audit_resource ON audit_logs(resource);\nCREATE INDEX IF NOT EXISTS idx_audit_result ON audit_logs(result);\nCREATE INDEX IF NOT EXISTS idx_audit_actor ON audit_logs(actor);\n";
11
+ /**
12
+ * SMI-974: Migration SQL for adding FTS5 to existing database
13
+ * Run separately as FTS5 creation can fail if table exists
14
+ */
15
+ export declare const FTS5_MIGRATION_SQL = "\n-- Create FTS5 virtual table if not exists\nCREATE VIRTUAL TABLE IF NOT EXISTS skills_fts USING fts5(\n name,\n description,\n tags,\n author,\n content='skills',\n content_rowid='rowid',\n tokenize='porter unicode61'\n);\n\n-- Populate FTS from existing skills (safe to run multiple times)\nINSERT OR IGNORE INTO skills_fts(rowid, name, description, tags, author)\nSELECT rowid, name, description, tags, author FROM skills;\n";
16
+ //# sourceMappingURL=schema-sql.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema-sql.d.ts","sourceRoot":"","sources":["../../../src/db/schema-sql.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH;;GAEG;AACH,eAAO,MAAM,UAAU,stKAkItB,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,kBAAkB,wbAe9B,CAAA"}
@@ -0,0 +1,161 @@
1
+ /**
2
+ * SQL constants for database schema and FTS5.
3
+ *
4
+ * Extracted to a standalone module (SMI-3910) so both schema.ts and
5
+ * migration-runner.ts can import them without circular dependencies.
6
+ */
7
+ /**
8
+ * SQL statements for creating the database schema
9
+ */
10
+ export const SCHEMA_SQL = `
11
+ -- Enable WAL mode for better concurrent performance
12
+ PRAGMA journal_mode = WAL;
13
+ PRAGMA synchronous = NORMAL;
14
+ PRAGMA cache_size = -64000; -- 64MB cache
15
+ PRAGMA temp_store = MEMORY;
16
+
17
+ -- Schema version tracking
18
+ CREATE TABLE IF NOT EXISTS schema_version (
19
+ version INTEGER PRIMARY KEY,
20
+ applied_at TEXT NOT NULL DEFAULT (datetime('now'))
21
+ );
22
+
23
+ -- Skills table - main storage for discovered skills
24
+ CREATE TABLE IF NOT EXISTS skills (
25
+ id TEXT PRIMARY KEY,
26
+ name TEXT NOT NULL,
27
+ description TEXT,
28
+ author TEXT,
29
+ repo_url TEXT UNIQUE,
30
+ quality_score REAL CHECK(quality_score IS NULL OR (quality_score >= 0 AND quality_score <= 1)),
31
+ trust_tier TEXT CHECK(trust_tier IN ('verified', 'community', 'experimental', 'unknown')) DEFAULT 'unknown',
32
+ tags TEXT DEFAULT '[]', -- JSON array of tags
33
+ risk_score INTEGER CHECK(risk_score IS NULL OR (risk_score >= 0 AND risk_score <= 100)), -- SMI-825
34
+ security_findings_count INTEGER DEFAULT 0,
35
+ security_scanned_at TEXT,
36
+ security_passed INTEGER, -- boolean: 1 = passed, 0 = failed, NULL = not scanned
37
+ compatibility TEXT DEFAULT '[]', -- SMI-2760: JSON array of IDE/LLM/platform slugs
38
+ content_hash TEXT, -- SMI-3510: SHA-256 hash of SKILL.md for tamper detection
39
+ created_at TEXT NOT NULL DEFAULT (datetime('now')),
40
+ updated_at TEXT NOT NULL DEFAULT (datetime('now'))
41
+ );
42
+
43
+ -- FTS5 virtual table for full-text search with BM25 ranking
44
+ CREATE VIRTUAL TABLE IF NOT EXISTS skills_fts USING fts5(
45
+ name,
46
+ description,
47
+ tags,
48
+ author,
49
+ content='skills',
50
+ content_rowid='rowid',
51
+ tokenize='porter unicode61'
52
+ );
53
+
54
+ -- Triggers to keep FTS index in sync with skills table
55
+ CREATE TRIGGER IF NOT EXISTS skills_ai AFTER INSERT ON skills BEGIN
56
+ INSERT INTO skills_fts(rowid, name, description, tags, author)
57
+ VALUES (NEW.rowid, NEW.name, NEW.description, NEW.tags, NEW.author);
58
+ END;
59
+
60
+ CREATE TRIGGER IF NOT EXISTS skills_ad AFTER DELETE ON skills BEGIN
61
+ INSERT INTO skills_fts(skills_fts, rowid, name, description, tags, author)
62
+ VALUES ('delete', OLD.rowid, OLD.name, OLD.description, OLD.tags, OLD.author);
63
+ END;
64
+
65
+ CREATE TRIGGER IF NOT EXISTS skills_au AFTER UPDATE ON skills BEGIN
66
+ INSERT INTO skills_fts(skills_fts, rowid, name, description, tags, author)
67
+ VALUES ('delete', OLD.rowid, OLD.name, OLD.description, OLD.tags, OLD.author);
68
+ INSERT INTO skills_fts(rowid, name, description, tags, author)
69
+ VALUES (NEW.rowid, NEW.name, NEW.description, NEW.tags, NEW.author);
70
+ END;
71
+
72
+ -- Sources table - tracks where skills are discovered from
73
+ CREATE TABLE IF NOT EXISTS sources (
74
+ id TEXT PRIMARY KEY,
75
+ name TEXT NOT NULL,
76
+ type TEXT NOT NULL CHECK(type IN ('github', 'gitlab', 'local', 'registry')),
77
+ url TEXT NOT NULL UNIQUE,
78
+ last_sync_at TEXT,
79
+ is_active INTEGER NOT NULL DEFAULT 1,
80
+ created_at TEXT NOT NULL DEFAULT (datetime('now'))
81
+ );
82
+
83
+ -- Categories table - hierarchical organization of skills
84
+ CREATE TABLE IF NOT EXISTS categories (
85
+ id TEXT PRIMARY KEY,
86
+ name TEXT NOT NULL UNIQUE,
87
+ description TEXT,
88
+ parent_id TEXT REFERENCES categories(id) ON DELETE SET NULL,
89
+ skill_count INTEGER NOT NULL DEFAULT 0,
90
+ created_at TEXT NOT NULL DEFAULT (datetime('now'))
91
+ );
92
+
93
+ -- Skill-Category junction table
94
+ CREATE TABLE IF NOT EXISTS skill_categories (
95
+ skill_id TEXT NOT NULL REFERENCES skills(id) ON DELETE CASCADE,
96
+ category_id TEXT NOT NULL REFERENCES categories(id) ON DELETE CASCADE,
97
+ PRIMARY KEY (skill_id, category_id)
98
+ );
99
+
100
+ -- Cache table for search results and API responses
101
+ CREATE TABLE IF NOT EXISTS cache (
102
+ key TEXT PRIMARY KEY,
103
+ value TEXT NOT NULL,
104
+ expires_at INTEGER, -- Unix timestamp, NULL for no expiry
105
+ created_at TEXT NOT NULL DEFAULT (datetime('now'))
106
+ );
107
+
108
+ -- Indexes for common query patterns
109
+ CREATE INDEX IF NOT EXISTS idx_skills_author ON skills(author);
110
+ CREATE INDEX IF NOT EXISTS idx_skills_trust_tier ON skills(trust_tier);
111
+ CREATE INDEX IF NOT EXISTS idx_skills_quality_score ON skills(quality_score);
112
+ CREATE INDEX IF NOT EXISTS idx_skills_updated_at ON skills(updated_at);
113
+ CREATE INDEX IF NOT EXISTS idx_skills_created_at ON skills(created_at);
114
+ CREATE INDEX IF NOT EXISTS idx_skills_risk_score ON skills(risk_score);
115
+ CREATE INDEX IF NOT EXISTS idx_skills_security_passed ON skills(security_passed);
116
+ CREATE INDEX IF NOT EXISTS idx_sources_type ON sources(type);
117
+ CREATE INDEX IF NOT EXISTS idx_sources_is_active ON sources(is_active);
118
+ CREATE INDEX IF NOT EXISTS idx_categories_parent ON categories(parent_id);
119
+ CREATE INDEX IF NOT EXISTS idx_cache_expires ON cache(expires_at);
120
+
121
+ -- SMI-733: Audit logs table for security monitoring
122
+ -- See: docs/security/index.md §3 Audit Logging
123
+ CREATE TABLE IF NOT EXISTS audit_logs (
124
+ id TEXT PRIMARY KEY,
125
+ event_type TEXT NOT NULL,
126
+ timestamp TEXT NOT NULL DEFAULT (datetime('now')),
127
+ actor TEXT,
128
+ resource TEXT,
129
+ action TEXT,
130
+ result TEXT,
131
+ metadata TEXT,
132
+ created_at TEXT NOT NULL DEFAULT (datetime('now'))
133
+ );
134
+
135
+ CREATE INDEX IF NOT EXISTS idx_audit_event_type ON audit_logs(event_type);
136
+ CREATE INDEX IF NOT EXISTS idx_audit_timestamp ON audit_logs(timestamp);
137
+ CREATE INDEX IF NOT EXISTS idx_audit_resource ON audit_logs(resource);
138
+ CREATE INDEX IF NOT EXISTS idx_audit_result ON audit_logs(result);
139
+ CREATE INDEX IF NOT EXISTS idx_audit_actor ON audit_logs(actor);
140
+ `;
141
+ /**
142
+ * SMI-974: Migration SQL for adding FTS5 to existing database
143
+ * Run separately as FTS5 creation can fail if table exists
144
+ */
145
+ export const FTS5_MIGRATION_SQL = `
146
+ -- Create FTS5 virtual table if not exists
147
+ CREATE VIRTUAL TABLE IF NOT EXISTS skills_fts USING fts5(
148
+ name,
149
+ description,
150
+ tags,
151
+ author,
152
+ content='skills',
153
+ content_rowid='rowid',
154
+ tokenize='porter unicode61'
155
+ );
156
+
157
+ -- Populate FTS from existing skills (safe to run multiple times)
158
+ INSERT OR IGNORE INTO skills_fts(rowid, name, description, tags, author)
159
+ SELECT rowid, name, description, tags, author FROM skills;
160
+ `;
161
+ //# sourceMappingURL=schema-sql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema-sql.js","sourceRoot":"","sources":["../../../src/db/schema-sql.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH;;GAEG;AACH,MAAM,CAAC,MAAM,UAAU,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkIzB,CAAA;AAED;;;GAGG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG;;;;;;;;;;;;;;;CAejC,CAAA"}
@@ -7,43 +7,20 @@
7
7
  * - Sources, Categories, and Cache tables
8
8
  * - WAL mode for performance
9
9
  * - Indexes for common query patterns
10
+ *
11
+ * SQL constants live in schema-sql.ts (SMI-3910) to avoid circular imports
12
+ * with migration-runner.ts. This file re-exports them for backward compat.
10
13
  */
11
14
  import type { Database } from './database-interface.js';
15
+ export { SCHEMA_SQL, FTS5_MIGRATION_SQL } from './schema-sql.js';
16
+ export { MIGRATIONS, getSchemaVersion, runMigrations, runMigrationsSafe, } from './migration-runner.js';
17
+ export type { Migration } from './migration-runner.js';
12
18
  export type DatabaseType = Database;
13
- export declare const SCHEMA_VERSION = 10;
14
- /**
15
- * SQL statements for creating the database schema
16
- */
17
- export declare const SCHEMA_SQL = "\n-- Enable WAL mode for better concurrent performance\nPRAGMA journal_mode = WAL;\nPRAGMA synchronous = NORMAL;\nPRAGMA cache_size = -64000; -- 64MB cache\nPRAGMA temp_store = MEMORY;\n\n-- Schema version tracking\nCREATE TABLE IF NOT EXISTS schema_version (\n version INTEGER PRIMARY KEY,\n applied_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- Skills table - main storage for discovered skills\nCREATE TABLE IF NOT EXISTS skills (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n description TEXT,\n author TEXT,\n repo_url TEXT UNIQUE,\n quality_score REAL CHECK(quality_score IS NULL OR (quality_score >= 0 AND quality_score <= 1)),\n trust_tier TEXT CHECK(trust_tier IN ('verified', 'community', 'experimental', 'unknown')) DEFAULT 'unknown',\n tags TEXT DEFAULT '[]', -- JSON array of tags\n risk_score INTEGER CHECK(risk_score IS NULL OR (risk_score >= 0 AND risk_score <= 100)), -- SMI-825\n security_findings_count INTEGER DEFAULT 0,\n security_scanned_at TEXT,\n security_passed INTEGER, -- boolean: 1 = passed, 0 = failed, NULL = not scanned\n compatibility TEXT DEFAULT '[]', -- SMI-2760: JSON array of IDE/LLM/platform slugs\n created_at TEXT NOT NULL DEFAULT (datetime('now')),\n updated_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- FTS5 virtual table for full-text search with BM25 ranking\nCREATE VIRTUAL TABLE IF NOT EXISTS skills_fts USING fts5(\n name,\n description,\n tags,\n author,\n content='skills',\n content_rowid='rowid',\n tokenize='porter unicode61'\n);\n\n-- Triggers to keep FTS index in sync with skills table\nCREATE TRIGGER IF NOT EXISTS skills_ai AFTER INSERT ON skills BEGIN\n INSERT INTO skills_fts(rowid, name, description, tags, author)\n VALUES (NEW.rowid, NEW.name, NEW.description, NEW.tags, NEW.author);\nEND;\n\nCREATE TRIGGER IF NOT EXISTS skills_ad AFTER DELETE ON skills BEGIN\n INSERT INTO skills_fts(skills_fts, rowid, name, description, tags, author)\n VALUES ('delete', OLD.rowid, OLD.name, OLD.description, OLD.tags, OLD.author);\nEND;\n\nCREATE TRIGGER IF NOT EXISTS skills_au AFTER UPDATE ON skills BEGIN\n INSERT INTO skills_fts(skills_fts, rowid, name, description, tags, author)\n VALUES ('delete', OLD.rowid, OLD.name, OLD.description, OLD.tags, OLD.author);\n INSERT INTO skills_fts(rowid, name, description, tags, author)\n VALUES (NEW.rowid, NEW.name, NEW.description, NEW.tags, NEW.author);\nEND;\n\n-- Sources table - tracks where skills are discovered from\nCREATE TABLE IF NOT EXISTS sources (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n type TEXT NOT NULL CHECK(type IN ('github', 'gitlab', 'local', 'registry')),\n url TEXT NOT NULL UNIQUE,\n last_sync_at TEXT,\n is_active INTEGER NOT NULL DEFAULT 1,\n created_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- Categories table - hierarchical organization of skills\nCREATE TABLE IF NOT EXISTS categories (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL UNIQUE,\n description TEXT,\n parent_id TEXT REFERENCES categories(id) ON DELETE SET NULL,\n skill_count INTEGER NOT NULL DEFAULT 0,\n created_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- Skill-Category junction table\nCREATE TABLE IF NOT EXISTS skill_categories (\n skill_id TEXT NOT NULL REFERENCES skills(id) ON DELETE CASCADE,\n category_id TEXT NOT NULL REFERENCES categories(id) ON DELETE CASCADE,\n PRIMARY KEY (skill_id, category_id)\n);\n\n-- Cache table for search results and API responses\nCREATE TABLE IF NOT EXISTS cache (\n key TEXT PRIMARY KEY,\n value TEXT NOT NULL,\n expires_at INTEGER, -- Unix timestamp, NULL for no expiry\n created_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\n-- Indexes for common query patterns\nCREATE INDEX IF NOT EXISTS idx_skills_author ON skills(author);\nCREATE INDEX IF NOT EXISTS idx_skills_trust_tier ON skills(trust_tier);\nCREATE INDEX IF NOT EXISTS idx_skills_quality_score ON skills(quality_score);\nCREATE INDEX IF NOT EXISTS idx_skills_updated_at ON skills(updated_at);\nCREATE INDEX IF NOT EXISTS idx_skills_created_at ON skills(created_at);\nCREATE INDEX IF NOT EXISTS idx_skills_risk_score ON skills(risk_score);\nCREATE INDEX IF NOT EXISTS idx_skills_security_passed ON skills(security_passed);\nCREATE INDEX IF NOT EXISTS idx_sources_type ON sources(type);\nCREATE INDEX IF NOT EXISTS idx_sources_is_active ON sources(is_active);\nCREATE INDEX IF NOT EXISTS idx_categories_parent ON categories(parent_id);\nCREATE INDEX IF NOT EXISTS idx_cache_expires ON cache(expires_at);\n\n-- SMI-733: Audit logs table for security monitoring\n-- See: docs/security/index.md \u00A73 Audit Logging\nCREATE TABLE IF NOT EXISTS audit_logs (\n id TEXT PRIMARY KEY,\n event_type TEXT NOT NULL,\n timestamp TEXT NOT NULL DEFAULT (datetime('now')),\n actor TEXT,\n resource TEXT,\n action TEXT,\n result TEXT,\n metadata TEXT,\n created_at TEXT NOT NULL DEFAULT (datetime('now'))\n);\n\nCREATE INDEX IF NOT EXISTS idx_audit_event_type ON audit_logs(event_type);\nCREATE INDEX IF NOT EXISTS idx_audit_timestamp ON audit_logs(timestamp);\nCREATE INDEX IF NOT EXISTS idx_audit_resource ON audit_logs(resource);\nCREATE INDEX IF NOT EXISTS idx_audit_result ON audit_logs(result);\nCREATE INDEX IF NOT EXISTS idx_audit_actor ON audit_logs(actor);\n";
18
- /**
19
- * Migration definitions for schema upgrades
20
- */
21
- export interface Migration {
22
- version: number;
23
- description: string;
24
- sql: string;
25
- }
26
- export declare const MIGRATIONS: Migration[];
27
- /**
28
- * SMI-974: Migration SQL for adding FTS5 to existing database
29
- * Run separately as FTS5 creation can fail if table exists
30
- */
31
- export declare const FTS5_MIGRATION_SQL = "\n-- Create FTS5 virtual table if not exists\nCREATE VIRTUAL TABLE IF NOT EXISTS skills_fts USING fts5(\n name,\n description,\n tags,\n author,\n content='skills',\n content_rowid='rowid',\n tokenize='porter unicode61'\n);\n\n-- Populate FTS from existing skills (safe to run multiple times)\nINSERT OR IGNORE INTO skills_fts(rowid, name, description, tags, author)\nSELECT rowid, name, description, tags, author FROM skills;\n";
19
+ export declare const SCHEMA_VERSION = 13;
32
20
  /**
33
21
  * Initialize the database with the complete schema
34
22
  */
35
23
  export declare function initializeSchema(db: DatabaseType): void;
36
- /**
37
- * Get the current schema version from the database
38
- */
39
- export declare function getSchemaVersion(db: DatabaseType): number;
40
- /**
41
- * Run pending migrations to upgrade the schema
42
- * Handles duplicate column errors gracefully since the initial schema
43
- * already includes all columns, but migrations need to support databases
44
- * created by other means (e.g., Phase 5 import scripts)
45
- */
46
- export declare function runMigrations(db: DatabaseType): number;
47
24
  /** @deprecated Use createDatabaseAsync() — requires better-sqlite3 native module. */
48
25
  export declare function createDatabase(path?: string): DatabaseType;
49
26
  /**
@@ -51,8 +28,6 @@ export declare function createDatabase(path?: string): DatabaseType;
51
28
  * @deprecated Use openDatabaseAsync() for cross-platform WASM support.
52
29
  */
53
30
  export declare function openDatabase(path: string): DatabaseType;
54
- /** SMI-974: Run migrations with error handling for existing columns */
55
- export declare function runMigrationsSafe(db: DatabaseType): number;
56
31
  /**
57
32
  * Close the database connection safely
58
33
  */
@@ -1 +1 @@
1
- {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/db/schema.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAA;AAevD,MAAM,MAAM,YAAY,GAAG,QAAQ,CAAA;AAGnC,eAAO,MAAM,cAAc,KAAK,CAAA;AAEhC;;GAEG;AACH,eAAO,MAAM,UAAU,qoKAiItB,CAAA;AAED;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,OAAO,EAAE,MAAM,CAAA;IACf,WAAW,EAAE,MAAM,CAAA;IACnB,GAAG,EAAE,MAAM,CAAA;CACZ;AAED,eAAO,MAAM,UAAU,EAAE,SAAS,EAmDjC,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,kBAAkB,wbAe9B,CAAA;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,YAAY,GAAG,IAAI,CAMvD;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,CASzD;AAED;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,CAyBtD;AAED,qFAAqF;AACrF,wBAAgB,cAAc,CAAC,IAAI,GAAE,MAAmB,GAAG,YAAY,CAUtE;AAED;;;GAGG;AACH,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,YAAY,CA2BvD;AAED,uEAAuE;AACvE,wBAAgB,iBAAiB,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,CAqC1D;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,EAAE,EAAE,YAAY,GAAG,IAAI,CAEpD;AAED;;;;;;;;GAQG;AACH,wBAAsB,mBAAmB,CAAC,IAAI,GAAE,MAAmB,GAAG,OAAO,CAAC,YAAY,CAAC,CAU1F;AAED;;;;;;;;GAQG;AACH,wBAAsB,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CA0B3E"}
1
+ {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/db/schema.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAA;AAOvD,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAIhE,OAAO,EACL,UAAU,EACV,gBAAgB,EAChB,aAAa,EACb,iBAAiB,GAClB,MAAM,uBAAuB,CAAA;AAC9B,YAAY,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAA;AAKtD,MAAM,MAAM,YAAY,GAAG,QAAQ,CAAA;AAKnC,eAAO,MAAM,cAAc,KAAK,CAAA;AAEhC;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,YAAY,GAAG,IAAI,CAMvD;AAED,qFAAqF;AACrF,wBAAgB,cAAc,CAAC,IAAI,GAAE,MAAmB,GAAG,YAAY,CAUtE;AAED;;;GAGG;AACH,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,YAAY,CA2BvD;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,EAAE,EAAE,YAAY,GAAG,IAAI,CAEpD;AAED;;;;;;;;GAQG;AACH,wBAAsB,mBAAmB,CAAC,IAAI,GAAE,MAAmB,GAAG,OAAO,CAAC,YAAY,CAAC,CAU1F;AAED;;;;;;;;GAQG;AACH,wBAAsB,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CA0B3E"}