@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
@@ -16,6 +16,8 @@ export { AuditLogger } from './AuditLogger.js';
16
16
  export type { AuditLogEntry, AuditEventType, AuditActor, AuditResult, AuditQueryFilter, AuditStats, } from './AuditLogger.js';
17
17
  export { RateLimiter, InMemoryRateLimitStorage, RATE_LIMIT_PRESETS, createRateLimiterFromPreset, RateLimitQueueTimeoutError, RateLimitQueueFullError, } from './rate-limiter/index.js';
18
18
  export type { RateLimitConfig, RateLimitResult, RateLimitStorage, RateLimitMetrics, } from './rate-limiter/index.js';
19
+ export { detectRiskTrend } from './risk-trend.js';
20
+ export type { RiskTrendResult } from './risk-trend.js';
19
21
  export { SkillSandbox, SandboxUnavailableError, withSandbox } from './SkillSandbox.js';
20
22
  export type { SandboxOptions, ExecutionResult, SandboxFile, SandboxStatus } from './SkillSandbox.js';
21
23
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/security/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACpD,YAAY,EACV,eAAe,EACf,mBAAmB,EACnB,gBAAgB,EAChB,UAAU,EACV,cAAc,EACd,kBAAkB,GACnB,MAAM,oBAAoB,CAAA;AAG3B,OAAO,EACL,YAAY,EACZ,gBAAgB,EAChB,YAAY,EACZ,WAAW,EACX,YAAY,EAEZ,eAAe,EACf,wBAAwB,EACxB,4BAA4B,EAC5B,qBAAqB,EACrB,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,mBAAmB,CAAA;AAG1B,OAAO,EACL,cAAc,EACd,qBAAqB,EACrB,UAAU,EACV,oBAAoB,GACrB,MAAM,qBAAqB,CAAA;AAC5B,YAAY,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAGtF,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,YAAY,EACV,aAAa,EACb,cAAc,EACd,UAAU,EACV,WAAW,EACX,gBAAgB,EAChB,UAAU,GACX,MAAM,kBAAkB,CAAA;AAGzB,OAAO,EACL,WAAW,EACX,wBAAwB,EACxB,kBAAkB,EAClB,2BAA2B,EAC3B,0BAA0B,EAC1B,uBAAuB,GACxB,MAAM,yBAAyB,CAAA;AAChC,YAAY,EACV,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,yBAAyB,CAAA;AAGhC,OAAO,EAAE,YAAY,EAAE,uBAAuB,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA;AACtF,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/security/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACpD,YAAY,EACV,eAAe,EACf,mBAAmB,EACnB,gBAAgB,EAChB,UAAU,EACV,cAAc,EACd,kBAAkB,GACnB,MAAM,oBAAoB,CAAA;AAG3B,OAAO,EACL,YAAY,EACZ,gBAAgB,EAChB,YAAY,EACZ,WAAW,EACX,YAAY,EAEZ,eAAe,EACf,wBAAwB,EACxB,4BAA4B,EAC5B,qBAAqB,EACrB,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,mBAAmB,CAAA;AAG1B,OAAO,EACL,cAAc,EACd,qBAAqB,EACrB,UAAU,EACV,oBAAoB,GACrB,MAAM,qBAAqB,CAAA;AAC5B,YAAY,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAGtF,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,YAAY,EACV,aAAa,EACb,cAAc,EACd,UAAU,EACV,WAAW,EACX,gBAAgB,EAChB,UAAU,GACX,MAAM,kBAAkB,CAAA;AAGzB,OAAO,EACL,WAAW,EACX,wBAAwB,EACxB,kBAAkB,EAClB,2BAA2B,EAC3B,0BAA0B,EAC1B,uBAAuB,GACxB,MAAM,yBAAyB,CAAA;AAChC,YAAY,EACV,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,yBAAyB,CAAA;AAGhC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACjD,YAAY,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAGtD,OAAO,EAAE,YAAY,EAAE,uBAAuB,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA;AACtF,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA"}
@@ -19,6 +19,8 @@ export { validateDbPath, validateDbPathOrThrow, isPathSafe, DEFAULT_ALLOWED_DIRS
19
19
  export { AuditLogger } from './AuditLogger.js';
20
20
  // Rate limiter module
21
21
  export { RateLimiter, InMemoryRateLimitStorage, RATE_LIMIT_PRESETS, createRateLimiterFromPreset, RateLimitQueueTimeoutError, RateLimitQueueFullError, } from './rate-limiter/index.js';
22
+ // SMI-3874: Risk trend detection
23
+ export { detectRiskTrend } from './risk-trend.js';
22
24
  // SMI-1534: E2B Sandbox for skill testing
23
25
  export { SkillSandbox, SandboxUnavailableError, withSandbox } from './SkillSandbox.js';
24
26
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/security/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,iBAAiB;AACjB,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AAUpD,eAAe;AACf,OAAO,EACL,YAAY,EACZ,gBAAgB,EAChB,YAAY,EACZ,WAAW,EACX,YAAY;AACZ,iCAAiC;AACjC,eAAe,EACf,wBAAwB,EACxB,4BAA4B,EAC5B,qBAAqB,EACrB,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,mBAAmB,CAAA;AAE1B,kBAAkB;AAClB,OAAO,EACL,cAAc,EACd,qBAAqB,EACrB,UAAU,EACV,oBAAoB,GACrB,MAAM,qBAAqB,CAAA;AAG5B,eAAe;AACf,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAU9C,sBAAsB;AACtB,OAAO,EACL,WAAW,EACX,wBAAwB,EACxB,kBAAkB,EAClB,2BAA2B,EAC3B,0BAA0B,EAC1B,uBAAuB,GACxB,MAAM,yBAAyB,CAAA;AAQhC,0CAA0C;AAC1C,OAAO,EAAE,YAAY,EAAE,uBAAuB,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/security/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,iBAAiB;AACjB,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AAUpD,eAAe;AACf,OAAO,EACL,YAAY,EACZ,gBAAgB,EAChB,YAAY,EACZ,WAAW,EACX,YAAY;AACZ,iCAAiC;AACjC,eAAe,EACf,wBAAwB,EACxB,4BAA4B,EAC5B,qBAAqB,EACrB,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,mBAAmB,CAAA;AAE1B,kBAAkB;AAClB,OAAO,EACL,cAAc,EACd,qBAAqB,EACrB,UAAU,EACV,oBAAoB,GACrB,MAAM,qBAAqB,CAAA;AAG5B,eAAe;AACf,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAU9C,sBAAsB;AACtB,OAAO,EACL,WAAW,EACX,wBAAwB,EACxB,kBAAkB,EAClB,2BAA2B,EAC3B,0BAA0B,EAC1B,uBAAuB,GACxB,MAAM,yBAAyB,CAAA;AAQhC,iCAAiC;AACjC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAGjD,0CAA0C;AAC1C,OAAO,EAAE,YAAY,EAAE,uBAAuB,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAA"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * @fileoverview Risk trend detection for supply chain attack monitoring
3
+ * @module @skillsmith/core/security/risk-trend
4
+ * @see SMI-3874: Risk Trend Detection
5
+ */
6
+ import type { RiskScoreSnapshot } from '../repositories/RiskScoreHistoryRepository.js';
7
+ export interface RiskTrendResult {
8
+ anomaly: boolean;
9
+ message: string;
10
+ currentScore: number;
11
+ previousScore: number | null;
12
+ delta: number;
13
+ }
14
+ /**
15
+ * Detect anomalous risk score changes that may indicate supply chain attacks.
16
+ * Thresholds: 20pt warning, 35pt critical, 40pt boundary crossing.
17
+ */
18
+ export declare function detectRiskTrend(currentScore: number, history: RiskScoreSnapshot[], options?: {
19
+ isNewCategoryBaseline?: boolean;
20
+ }): RiskTrendResult;
21
+ //# sourceMappingURL=risk-trend.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"risk-trend.d.ts","sourceRoot":"","sources":["../../../src/security/risk-trend.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+CAA+C,CAAA;AAEtF,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,OAAO,CAAA;IAChB,OAAO,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,MAAM,CAAA;IACpB,aAAa,EAAE,MAAM,GAAG,IAAI,CAAA;IAC5B,KAAK,EAAE,MAAM,CAAA;CACd;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAC7B,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,iBAAiB,EAAE,EAC5B,OAAO,CAAC,EAAE;IAAE,qBAAqB,CAAC,EAAE,OAAO,CAAA;CAAE,GAC5C,eAAe,CAyEjB"}
@@ -0,0 +1,81 @@
1
+ /**
2
+ * @fileoverview Risk trend detection for supply chain attack monitoring
3
+ * @module @skillsmith/core/security/risk-trend
4
+ * @see SMI-3874: Risk Trend Detection
5
+ */
6
+ /**
7
+ * Detect anomalous risk score changes that may indicate supply chain attacks.
8
+ * Thresholds: 20pt warning, 35pt critical, 40pt boundary crossing.
9
+ */
10
+ export function detectRiskTrend(currentScore, history, options) {
11
+ if (history.length === 0) {
12
+ return {
13
+ anomaly: false,
14
+ message: 'No prior scan history for comparison.',
15
+ currentScore,
16
+ previousScore: null,
17
+ delta: 0,
18
+ };
19
+ }
20
+ const previous = history[0];
21
+ const delta = currentScore - previous.riskScore;
22
+ if (options?.isNewCategoryBaseline) {
23
+ return {
24
+ anomaly: false,
25
+ message: 'New scanner category baseline (' +
26
+ previous.riskScore +
27
+ ' -> ' +
28
+ currentScore +
29
+ '). Not flagged as anomaly.',
30
+ currentScore,
31
+ previousScore: previous.riskScore,
32
+ delta,
33
+ };
34
+ }
35
+ const crossesBoundary = previous.riskScore < 40 && currentScore >= 40;
36
+ const isLargeJump = delta >= 20;
37
+ const isCriticalJump = delta >= 35;
38
+ const anomaly = isLargeJump || crossesBoundary;
39
+ let message;
40
+ if (isCriticalJump) {
41
+ message =
42
+ 'CRITICAL: Risk score jumped from ' +
43
+ previous.riskScore +
44
+ ' to ' +
45
+ currentScore +
46
+ ' (+' +
47
+ delta +
48
+ '). Possible supply chain compromise.';
49
+ }
50
+ else if (crossesBoundary) {
51
+ message =
52
+ 'WARNING: Risk score crossed safety threshold (' +
53
+ previous.riskScore +
54
+ ' -> ' +
55
+ currentScore +
56
+ '). Review recent changes.';
57
+ }
58
+ else if (isLargeJump) {
59
+ message =
60
+ 'WARNING: Risk score increased by ' +
61
+ delta +
62
+ ' points (' +
63
+ previous.riskScore +
64
+ ' -> ' +
65
+ currentScore +
66
+ ').';
67
+ }
68
+ else {
69
+ message =
70
+ 'Risk score stable (' +
71
+ previous.riskScore +
72
+ ' -> ' +
73
+ currentScore +
74
+ ', delta: ' +
75
+ (delta >= 0 ? '+' : '') +
76
+ delta +
77
+ ').';
78
+ }
79
+ return { anomaly, message, currentScore, previousScore: previous.riskScore, delta };
80
+ }
81
+ //# sourceMappingURL=risk-trend.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"risk-trend.js","sourceRoot":"","sources":["../../../src/security/risk-trend.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAYH;;;GAGG;AACH,MAAM,UAAU,eAAe,CAC7B,YAAoB,EACpB,OAA4B,EAC5B,OAA6C;IAE7C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO;YACL,OAAO,EAAE,KAAK;YACd,OAAO,EAAE,uCAAuC;YAChD,YAAY;YACZ,aAAa,EAAE,IAAI;YACnB,KAAK,EAAE,CAAC;SACT,CAAA;IACH,CAAC;IAED,MAAM,QAAQ,GAAG,OAAO,CAAC,CAAC,CAAC,CAAA;IAC3B,MAAM,KAAK,GAAG,YAAY,GAAG,QAAQ,CAAC,SAAS,CAAA;IAE/C,IAAI,OAAO,EAAE,qBAAqB,EAAE,CAAC;QACnC,OAAO;YACL,OAAO,EAAE,KAAK;YACd,OAAO,EACL,iCAAiC;gBACjC,QAAQ,CAAC,SAAS;gBAClB,MAAM;gBACN,YAAY;gBACZ,4BAA4B;YAC9B,YAAY;YACZ,aAAa,EAAE,QAAQ,CAAC,SAAS;YACjC,KAAK;SACN,CAAA;IACH,CAAC;IAED,MAAM,eAAe,GAAG,QAAQ,CAAC,SAAS,GAAG,EAAE,IAAI,YAAY,IAAI,EAAE,CAAA;IACrE,MAAM,WAAW,GAAG,KAAK,IAAI,EAAE,CAAA;IAC/B,MAAM,cAAc,GAAG,KAAK,IAAI,EAAE,CAAA;IAClC,MAAM,OAAO,GAAG,WAAW,IAAI,eAAe,CAAA;IAE9C,IAAI,OAAe,CAAA;IACnB,IAAI,cAAc,EAAE,CAAC;QACnB,OAAO;YACL,mCAAmC;gBACnC,QAAQ,CAAC,SAAS;gBAClB,MAAM;gBACN,YAAY;gBACZ,KAAK;gBACL,KAAK;gBACL,sCAAsC,CAAA;IAC1C,CAAC;SAAM,IAAI,eAAe,EAAE,CAAC;QAC3B,OAAO;YACL,gDAAgD;gBAChD,QAAQ,CAAC,SAAS;gBAClB,MAAM;gBACN,YAAY;gBACZ,2BAA2B,CAAA;IAC/B,CAAC;SAAM,IAAI,WAAW,EAAE,CAAC;QACvB,OAAO;YACL,mCAAmC;gBACnC,KAAK;gBACL,WAAW;gBACX,QAAQ,CAAC,SAAS;gBAClB,MAAM;gBACN,YAAY;gBACZ,IAAI,CAAA;IACR,CAAC;SAAM,CAAC;QACN,OAAO;YACL,qBAAqB;gBACrB,QAAQ,CAAC,SAAS;gBAClB,MAAM;gBACN,YAAY;gBACZ,WAAW;gBACX,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;gBACvB,KAAK;gBACL,IAAI,CAAA;IACR,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,QAAQ,CAAC,SAAS,EAAE,KAAK,EAAE,CAAA;AACrF,CAAC"}
@@ -5,9 +5,11 @@
5
5
  */
6
6
  import type { ScanReport, ScannerOptions } from './types.js';
7
7
  import type { LineContext } from './SecurityScanner.helpers.js';
8
- import { isMultilinePattern, analyzeMarkdownContext, isDocumentationContext, calculateRiskScore } from './SecurityScanner.helpers.js';
8
+ import { isMultilinePattern, analyzeMarkdownContext, isDocumentationContext, isWithinInlineCode, calculateRiskScore } from './SecurityScanner.helpers.js';
9
+ import { scanSsrfPatterns } from './SecurityScanner.ssrf.js';
9
10
  import { toMinimalRefs, toSARIF, toGitHubAnnotations, toSummary } from './SecurityScanner.formatters.js';
10
- export { LineContext, isMultilinePattern, analyzeMarkdownContext, isDocumentationContext, calculateRiskScore, };
11
+ export { LineContext, isMultilinePattern, analyzeMarkdownContext, isDocumentationContext, isWithinInlineCode, calculateRiskScore, };
12
+ export { scanSsrfPatterns };
11
13
  export { toMinimalRefs, toSARIF, toGitHubAnnotations, toSummary };
12
14
  export declare class SecurityScanner {
13
15
  private allowedDomains;
@@ -25,6 +27,8 @@ export declare class SecurityScanner {
25
27
  private scanPromptLeaking;
26
28
  private scanDataExfiltration;
27
29
  private scanPrivilegeEscalation;
30
+ /** SMI-3864: Detect PII patterns. Email in YAML frontmatter gets low severity. */
31
+ private scanPiiPatterns;
28
32
  private scanAIDefenceVulnerabilities;
29
33
  /** @deprecated Use standalone calculateRiskScore function for new code */
30
34
  calculateRiskScore: typeof calculateRiskScore;
@@ -1 +1 @@
1
- {"version":3,"file":"SecurityScanner.d.ts","sourceRoot":"","sources":["../../../../src/security/scanner/SecurityScanner.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAmB,UAAU,EAAE,cAAc,EAAqB,MAAM,YAAY,CAAA;AAehG,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;AAC/D,OAAO,EACL,kBAAkB,EAClB,sBAAsB,EACtB,sBAAsB,EACtB,kBAAkB,EACnB,MAAM,8BAA8B,CAAA;AAGrC,OAAO,EACL,aAAa,EACb,OAAO,EACP,mBAAmB,EACnB,SAAS,EACV,MAAM,iCAAiC,CAAA;AAGxC,OAAO,EACL,WAAW,EACX,kBAAkB,EAClB,sBAAsB,EACtB,sBAAsB,EACtB,kBAAkB,GACnB,CAAA;AACD,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,mBAAmB,EAAE,SAAS,EAAE,CAAA;AAEjE,qBAAa,eAAe;IAC1B,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,eAAe,CAAU;IACjC,OAAO,CAAC,gBAAgB,CAAQ;IAChC,OAAO,CAAC,aAAa,CAAQ;gBAEjB,OAAO,GAAE,cAAmB;IAOxC,OAAO,CAAC,WAAW;IAenB,OAAO,CAAC,eAAe;IAYvB,OAAO,CAAC,QAAQ;IAmBhB,OAAO,CAAC,kBAAkB;IA+B1B,OAAO,CAAC,qBAAqB;IAgC7B,OAAO,CAAC,sBAAsB;IAqC9B,OAAO,CAAC,qBAAqB;IAiC7B,OAAO,CAAC,iBAAiB;IAiCzB,OAAO,CAAC,oBAAoB;IAiC5B,OAAO,CAAC,uBAAuB;IAoC/B,OAAO,CAAC,4BAA4B;IAuEpC,0EAA0E;IAC1E,kBAAkB,4BAAqB;IAEvC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,UAAU;IAyClD,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAOpC,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAItC,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAKxC,MAAM,CAAC,aAAa,uBAAgB;IACpC,MAAM,CAAC,OAAO,iBAAU;IACxB,MAAM,CAAC,mBAAmB,6BAAsB;IAChD,MAAM,CAAC,SAAS,mBAAY;CAC7B;AAED,eAAe,eAAe,CAAA"}
1
+ {"version":3,"file":"SecurityScanner.d.ts","sourceRoot":"","sources":["../../../../src/security/scanner/SecurityScanner.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAmB,UAAU,EAAE,cAAc,EAAqB,MAAM,YAAY,CAAA;AAgBhG,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;AAC/D,OAAO,EACL,kBAAkB,EAClB,sBAAsB,EACtB,sBAAsB,EACtB,kBAAkB,EAClB,kBAAkB,EAEnB,MAAM,8BAA8B,CAAA;AAGrC,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AAG5D,OAAO,EACL,aAAa,EACb,OAAO,EACP,mBAAmB,EACnB,SAAS,EACV,MAAM,iCAAiC,CAAA;AAGxC,OAAO,EACL,WAAW,EACX,kBAAkB,EAClB,sBAAsB,EACtB,sBAAsB,EACtB,kBAAkB,EAClB,kBAAkB,GACnB,CAAA;AACD,OAAO,EAAE,gBAAgB,EAAE,CAAA;AAC3B,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,mBAAmB,EAAE,SAAS,EAAE,CAAA;AAEjE,qBAAa,eAAe;IAC1B,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,eAAe,CAAU;IACjC,OAAO,CAAC,gBAAgB,CAAQ;IAChC,OAAO,CAAC,aAAa,CAAQ;gBAEjB,OAAO,GAAE,cAAmB;IAOxC,OAAO,CAAC,WAAW;IAenB,OAAO,CAAC,eAAe;IAYvB,OAAO,CAAC,QAAQ;IAmBhB,OAAO,CAAC,kBAAkB;IAiC1B,OAAO,CAAC,qBAAqB;IAa7B,OAAO,CAAC,sBAAsB;IAqC9B,OAAO,CAAC,qBAAqB;IAkC7B,OAAO,CAAC,iBAAiB;IAkCzB,OAAO,CAAC,oBAAoB;IAkC5B,OAAO,CAAC,uBAAuB;IAqC/B,kFAAkF;IAClF,OAAO,CAAC,eAAe;IAiDvB,OAAO,CAAC,4BAA4B;IAgBpC,0EAA0E;IAC1E,kBAAkB,4BAAqB;IAEvC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,UAAU;IA2ClD,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAOpC,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAItC,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAKxC,MAAM,CAAC,aAAa,uBAAgB;IACpC,MAAM,CAAC,OAAO,iBAAU;IACxB,MAAM,CAAC,mBAAmB,6BAAsB;IAChD,MAAM,CAAC,SAAS,mBAAY;CAC7B;AAED,eAAe,eAAe,CAAA"}
@@ -2,7 +2,7 @@
2
2
  * Security Scanner Helper Functions
3
3
  * @module @skillsmith/core/security/scanner/SecurityScanner.helpers
4
4
  */
5
- import type { SecurityFinding, RiskScoreBreakdown } from './types.js';
5
+ import type { SecurityFinding, SecurityFindingType, RiskScoreBreakdown, SecuritySeverity } from './types.js';
6
6
  /**
7
7
  * Context information for each line in markdown content
8
8
  */
@@ -25,9 +25,30 @@ export declare function isMultilinePattern(pattern: RegExp): boolean;
25
25
  */
26
26
  export declare function analyzeMarkdownContext(content: string): LineContext[];
27
27
  /**
28
- * Check if a line is in a documentation context (code block, table, example)
28
+ * Check if a line is in a documentation context (code block, table, example).
29
+ * Note: isInlineCode is intentionally excluded — it marks the entire line,
30
+ * but only specific match positions within backtick spans should reduce severity.
31
+ * Use isWithinInlineCode() for per-span granularity (SMI-3521).
29
32
  */
30
33
  export declare function isDocumentationContext(ctx: LineContext): boolean;
34
+ /**
35
+ * SMI-3521: Check if a match position falls within an inline code span (backtick-delimited).
36
+ * Unlike the line-level isInlineCode flag, this provides per-span granularity:
37
+ * only content actually between backticks is considered inline code.
38
+ */
39
+ export declare function isWithinInlineCode(line: string, matchIndex: number): boolean;
40
+ interface MultilineScanConfig {
41
+ type: SecurityFindingType;
42
+ messagePrefix: string;
43
+ patterns: RegExp[];
44
+ /** Severity pair: [inDocContext, normalContext] */
45
+ severities: [SecuritySeverity, SecuritySeverity];
46
+ }
47
+ /**
48
+ * Scan content for patterns that may span multiple lines.
49
+ * Multi-line patterns are tested against full content; single-line patterns per-line.
50
+ */
51
+ export declare function scanPatternsWithMultilineSupport(content: string, config: MultilineScanConfig, lineContexts?: LineContext[]): SecurityFinding[];
31
52
  /**
32
53
  * SMI-685: Calculate risk score from findings
33
54
  * SMI-1513: Accounts for confidence levels (low confidence = reduced weight)
@@ -37,4 +58,5 @@ export declare function calculateRiskScore(findings: SecurityFinding[]): {
37
58
  total: number;
38
59
  breakdown: RiskScoreBreakdown;
39
60
  };
61
+ export {};
40
62
  //# sourceMappingURL=SecurityScanner.helpers.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"SecurityScanner.helpers.d.ts","sourceRoot":"","sources":["../../../../src/security/scanner/SecurityScanner.helpers.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,kBAAkB,EAAqB,MAAM,YAAY,CAAA;AAOxF;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,UAAU,EAAE,MAAM,CAAA;IAClB,WAAW,EAAE,OAAO,CAAA;IACpB,OAAO,EAAE,OAAO,CAAA;IAChB,cAAc,EAAE,OAAO,CAAA;IACvB,YAAY,EAAE,OAAO,CAAA;CACtB;AAMD;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAK3D;AAMD;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,MAAM,GAAG,WAAW,EAAE,CAqCrE;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAAC,GAAG,EAAE,WAAW,GAAG,OAAO,CAEhE;AAMD;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,eAAe,EAAE,GAAG;IAC/D,KAAK,EAAE,MAAM,CAAA;IACb,SAAS,EAAE,kBAAkB,CAAA;CAC9B,CAmFA"}
1
+ {"version":3,"file":"SecurityScanner.helpers.d.ts","sourceRoot":"","sources":["../../../../src/security/scanner/SecurityScanner.helpers.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EACV,eAAe,EACf,mBAAmB,EACnB,kBAAkB,EAElB,gBAAgB,EACjB,MAAM,YAAY,CAAA;AAQnB;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,UAAU,EAAE,MAAM,CAAA;IAClB,WAAW,EAAE,OAAO,CAAA;IACpB,OAAO,EAAE,OAAO,CAAA;IAChB,cAAc,EAAE,OAAO,CAAA;IACvB,YAAY,EAAE,OAAO,CAAA;CACtB;AAMD;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAK3D;AAMD;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,MAAM,GAAG,WAAW,EAAE,CAqCrE;AAED;;;;;GAKG;AACH,wBAAgB,sBAAsB,CAAC,GAAG,EAAE,WAAW,GAAG,OAAO,CAEhE;AAED;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAW5E;AAMD,UAAU,mBAAmB;IAC3B,IAAI,EAAE,mBAAmB,CAAA;IACzB,aAAa,EAAE,MAAM,CAAA;IACrB,QAAQ,EAAE,MAAM,EAAE,CAAA;IAClB,mDAAmD;IACnD,UAAU,EAAE,CAAC,gBAAgB,EAAE,gBAAgB,CAAC,CAAA;CACjD;AAED;;;GAGG;AACH,wBAAgB,gCAAgC,CAC9C,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,mBAAmB,EAC3B,YAAY,CAAC,EAAE,WAAW,EAAE,GAC3B,eAAe,EAAE,CAoEnB;AAMD;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,eAAe,EAAE,GAAG;IAC/D,KAAK,EAAE,MAAM,CAAA;IACb,SAAS,EAAE,kBAAkB,CAAA;CAC9B,CA+FA"}
@@ -3,6 +3,7 @@
3
3
  * @module @skillsmith/core/security/scanner/SecurityScanner.helpers
4
4
  */
5
5
  import { SEVERITY_WEIGHTS, CATEGORY_WEIGHTS } from './weights.js';
6
+ import { safeRegexTest } from './regex-utils.js';
6
7
  // ============================================================================
7
8
  // Pattern Helpers
8
9
  // ============================================================================
@@ -53,11 +54,100 @@ export function analyzeMarkdownContext(content) {
53
54
  return contexts;
54
55
  }
55
56
  /**
56
- * Check if a line is in a documentation context (code block, table, example)
57
+ * Check if a line is in a documentation context (code block, table, example).
58
+ * Note: isInlineCode is intentionally excluded — it marks the entire line,
59
+ * but only specific match positions within backtick spans should reduce severity.
60
+ * Use isWithinInlineCode() for per-span granularity (SMI-3521).
57
61
  */
58
62
  export function isDocumentationContext(ctx) {
59
63
  return ctx.inCodeBlock || ctx.inTable || ctx.isIndentedCode;
60
64
  }
65
+ /**
66
+ * SMI-3521: Check if a match position falls within an inline code span (backtick-delimited).
67
+ * Unlike the line-level isInlineCode flag, this provides per-span granularity:
68
+ * only content actually between backticks is considered inline code.
69
+ */
70
+ export function isWithinInlineCode(line, matchIndex) {
71
+ const backtickRegex = /`([^`]+)`/g;
72
+ let match;
73
+ while ((match = backtickRegex.exec(line)) !== null) {
74
+ const spanStart = match.index;
75
+ const spanEnd = match.index + match[0].length;
76
+ if (matchIndex >= spanStart && matchIndex < spanEnd) {
77
+ return true;
78
+ }
79
+ }
80
+ return false;
81
+ }
82
+ /**
83
+ * Scan content for patterns that may span multiple lines.
84
+ * Multi-line patterns are tested against full content; single-line patterns per-line.
85
+ */
86
+ export function scanPatternsWithMultilineSupport(content, config, lineContexts) {
87
+ const findings = [];
88
+ const lines = content.split('\n');
89
+ const contexts = lineContexts ?? analyzeMarkdownContext(content);
90
+ const flaggedLines = new Set();
91
+ // First pass: multi-line patterns against full content
92
+ for (const pattern of config.patterns) {
93
+ if (isMultilinePattern(pattern)) {
94
+ const match = safeRegexTest(pattern, content);
95
+ if (match) {
96
+ const matchIndex = content.indexOf(match[0]);
97
+ const lineNumber = content.slice(0, matchIndex).split('\n').length;
98
+ const ctx = contexts[lineNumber - 1];
99
+ const matchLine = lines[lineNumber - 1] ?? '';
100
+ const lineOffset = content.lastIndexOf('\n', matchIndex - 1) + 1;
101
+ const matchCol = matchIndex - lineOffset;
102
+ const inInlineCode = ctx?.isInlineCode && isWithinInlineCode(matchLine, matchCol);
103
+ const inDocContext = ctx ? isDocumentationContext(ctx) || inInlineCode : false;
104
+ const confidence = inDocContext ? 'low' : 'high';
105
+ const severity = inDocContext ? config.severities[0] : config.severities[1];
106
+ const truncated = match[0].slice(0, 50);
107
+ findings.push({
108
+ type: config.type,
109
+ severity,
110
+ message: `${config.messagePrefix}: "${truncated}${match[0].length > 50 ? '...' : ''}"`,
111
+ location: match[0].trim().slice(0, 100),
112
+ lineNumber,
113
+ category: config.type,
114
+ inDocumentationContext: inDocContext,
115
+ confidence,
116
+ });
117
+ flaggedLines.add(lineNumber);
118
+ }
119
+ }
120
+ }
121
+ // Second pass: single-line patterns per-line
122
+ lines.forEach((line, index) => {
123
+ if (flaggedLines.has(index + 1))
124
+ return;
125
+ const ctx = contexts[index];
126
+ for (const pattern of config.patterns) {
127
+ if (isMultilinePattern(pattern))
128
+ continue;
129
+ const match = safeRegexTest(pattern, line);
130
+ if (match) {
131
+ const inInlineCode = ctx?.isInlineCode && isWithinInlineCode(line, match.index ?? 0);
132
+ const inDocContext = ctx ? isDocumentationContext(ctx) || inInlineCode : false;
133
+ const confidence = inDocContext ? 'low' : 'high';
134
+ const severity = inDocContext ? config.severities[0] : config.severities[1];
135
+ findings.push({
136
+ type: config.type,
137
+ severity,
138
+ message: `${config.messagePrefix}: "${match[0].slice(0, 50)}${match[0].length > 50 ? '...' : ''}"`,
139
+ location: line.trim().slice(0, 100),
140
+ lineNumber: index + 1,
141
+ category: config.type,
142
+ inDocumentationContext: inDocContext,
143
+ confidence,
144
+ });
145
+ break;
146
+ }
147
+ }
148
+ });
149
+ return findings;
150
+ }
61
151
  // ============================================================================
62
152
  // Risk Score Calculation
63
153
  // ============================================================================
@@ -77,6 +167,8 @@ export function calculateRiskScore(findings) {
77
167
  sensitivePaths: 0,
78
168
  externalUrls: 0,
79
169
  aiDefence: 0,
170
+ ssrf: 0,
171
+ pii: 0,
80
172
  };
81
173
  const confidenceWeights = {
82
174
  high: 1.0,
@@ -116,6 +208,12 @@ export function calculateRiskScore(findings) {
116
208
  case 'ai_defence':
117
209
  breakdown.aiDefence += score;
118
210
  break;
211
+ case 'ssrf':
212
+ breakdown.ssrf += score;
213
+ break;
214
+ case 'pii':
215
+ breakdown.pii += score;
216
+ break;
119
217
  }
120
218
  }
121
219
  // Cap each category at 100
@@ -128,15 +226,19 @@ export function calculateRiskScore(findings) {
128
226
  breakdown.sensitivePaths = Math.min(100, breakdown.sensitivePaths);
129
227
  breakdown.externalUrls = Math.min(100, breakdown.externalUrls);
130
228
  breakdown.aiDefence = Math.min(100, breakdown.aiDefence);
131
- const total = Math.min(100, Math.round(breakdown.jailbreak * 0.22 +
132
- breakdown.socialEngineering * 0.12 +
133
- breakdown.promptLeaking * 0.12 +
134
- breakdown.dataExfiltration * 0.1 +
229
+ breakdown.ssrf = Math.min(100, breakdown.ssrf);
230
+ breakdown.pii = Math.min(100, breakdown.pii);
231
+ const total = Math.min(100, Math.round(breakdown.jailbreak * 0.2 +
232
+ breakdown.socialEngineering * 0.11 +
233
+ breakdown.promptLeaking * 0.11 +
234
+ breakdown.dataExfiltration * 0.08 +
135
235
  breakdown.privilegeEscalation * 0.11 +
136
- breakdown.suspiciousCode * 0.08 +
137
- breakdown.sensitivePaths * 0.05 +
138
- breakdown.externalUrls * 0.05 +
139
- breakdown.aiDefence * 0.15));
236
+ breakdown.suspiciousCode * 0.07 +
237
+ breakdown.sensitivePaths * 0.04 +
238
+ breakdown.externalUrls * 0.04 +
239
+ breakdown.aiDefence * 0.12 +
240
+ breakdown.ssrf * 0.04 +
241
+ breakdown.pii * 0.08));
140
242
  return { total, breakdown };
141
243
  }
142
244
  //# sourceMappingURL=SecurityScanner.helpers.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SecurityScanner.helpers.js","sourceRoot":"","sources":["../../../../src/security/scanner/SecurityScanner.helpers.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"SecurityScanner.helpers.js","sourceRoot":"","sources":["../../../../src/security/scanner/SecurityScanner.helpers.ts"],"names":[],"mappings":"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"}