@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,432 @@
1
+ /** @fileoverview SkillInstallationService — shared install/uninstall business logic (SMI-3483) */
2
+ import * as fs from 'fs/promises';
3
+ import * as path from 'path';
4
+ import * as os from 'os';
5
+ import { SecurityScanner } from '../security/index.js';
6
+ import { safeWriteFile } from '../utils/safe-fs.js';
7
+ import { parseRepoUrl } from '../utils/github-url.js';
8
+ import { TRUST_TIER_SCANNER_OPTIONS, } from './skill-installation.types.js';
9
+ import { recordAiDefenceFeedback, collectTrendWarnings } from './skill-installation.feedback.js';
10
+ import { ManifestManager } from './skill-manifest.js';
11
+ import { parseSkillIdInternal, hashContent, validateSkillMd, fetchFromGitHub, generateTips, extractDepIntel, persistDependencies, applyOptimization, performUninstall, sanitizeInstallError, validateOptionalConfig, checkDepsAgainstQuarantine, } from './skill-installation.helpers.js';
12
+ const DEFAULT_SKILLS_DIR = path.join(os.homedir(), '.claude', 'skills');
13
+ const DEFAULT_MANIFEST_PATH = path.join(os.homedir(), '.skillsmith', 'manifest.json');
14
+ export class SkillInstallationService {
15
+ db;
16
+ skillRepo;
17
+ skillDependencyRepo;
18
+ skillsDir;
19
+ manifest;
20
+ onProgress;
21
+ registryLookup;
22
+ coInstallRecorder;
23
+ sessionInstalledSkillIds;
24
+ quarantineLookup;
25
+ riskHistoryRepo;
26
+ aiDefenceFeedback;
27
+ constructor(params) {
28
+ this.db = params.db;
29
+ this.skillRepo = params.skillRepo;
30
+ this.skillDependencyRepo = params.skillDependencyRepo;
31
+ this.skillsDir = params.skillsDir ?? DEFAULT_SKILLS_DIR;
32
+ this.manifest = new ManifestManager(params.manifestPath ?? DEFAULT_MANIFEST_PATH);
33
+ this.onProgress = params.onProgress ?? (() => { });
34
+ this.registryLookup = params.registryLookup;
35
+ this.coInstallRecorder = params.coInstallRecorder;
36
+ this.quarantineLookup = params.quarantineLookup;
37
+ this.riskHistoryRepo = params.riskHistoryRepo;
38
+ this.aiDefenceFeedback = params.aiDefenceFeedback;
39
+ this.sessionInstalledSkillIds = params.sessionInstalledSkillIds ?? [];
40
+ }
41
+ async install(skillId, options = {}) {
42
+ let trustTier = 'unknown';
43
+ try {
44
+ this.onProgress('parse', 'Parsing skill ID');
45
+ const parsed = parseSkillIdInternal(skillId);
46
+ let owner;
47
+ let repo;
48
+ let basePath;
49
+ let skillName;
50
+ let branch = 'main';
51
+ let fromRegistry = false;
52
+ let indexedContentHash;
53
+ if (parsed.isRegistryId) {
54
+ if (!this.registryLookup) {
55
+ return {
56
+ success: false,
57
+ skillId,
58
+ installPath: '',
59
+ error: 'Registry lookup not available. ' +
60
+ 'Use a full GitHub URL: install { skillId: "https://github.com/owner/repo" }',
61
+ };
62
+ }
63
+ this.onProgress('lookup', 'Looking up skill in registry');
64
+ const registrySkill = await this.registryLookup.lookup(skillId);
65
+ if (!registrySkill) {
66
+ return {
67
+ success: false,
68
+ skillId,
69
+ installPath: '',
70
+ error: 'Skill "' +
71
+ skillId +
72
+ '" is indexed for discovery only. ' +
73
+ 'No installation source available (repo_url is missing). ' +
74
+ 'This may be placeholder/seed data or a metadata-only entry.',
75
+ tips: [
76
+ 'Use a full GitHub URL instead: install { skillId: "https://github.com/owner/repo" }',
77
+ 'Search for installable skills using the search tool',
78
+ 'Many indexed skills are metadata-only and cannot be installed directly',
79
+ ],
80
+ };
81
+ }
82
+ if (registrySkill.quarantined) {
83
+ return {
84
+ success: false,
85
+ skillId,
86
+ installPath: '',
87
+ error: 'Skill "' +
88
+ skillId +
89
+ '" has been quarantined due to security concerns. ' +
90
+ 'Installation is blocked to protect your environment.',
91
+ tips: [
92
+ 'Visit https://skillsmith.app/docs/quarantine for details on quarantine policies',
93
+ 'If you believe this is a false positive, contact support via https://skillsmith.app/contact?topic=security',
94
+ 'Contact the skill author or visit the quarantine documentation for more information',
95
+ ],
96
+ };
97
+ }
98
+ const repoInfo = parseRepoUrl(registrySkill.repoUrl);
99
+ owner = repoInfo.owner;
100
+ repo = repoInfo.repo;
101
+ basePath = repoInfo.path ? repoInfo.path + '/' : '';
102
+ branch = repoInfo.branch;
103
+ skillName = registrySkill.name;
104
+ trustTier = registrySkill.trustTier;
105
+ fromRegistry = true;
106
+ indexedContentHash = registrySkill.contentHash;
107
+ }
108
+ else {
109
+ owner = parsed.owner;
110
+ repo = parsed.repo;
111
+ basePath = parsed.path ? parsed.path + '/' : '';
112
+ skillName = parsed.path ? path.basename(parsed.path) : repo;
113
+ }
114
+ const installPath = path.join(this.skillsDir, skillName);
115
+ this.onProgress('manifest', 'Checking manifest');
116
+ const manifest = await this.manifest.load();
117
+ if (manifest.installedSkills[skillName] && !options.force) {
118
+ return {
119
+ success: false,
120
+ skillId,
121
+ installPath,
122
+ error: 'Skill "' + skillName + '" is already installed. Use force=true to reinstall.',
123
+ };
124
+ }
125
+ this.onProgress('fetch', 'Fetching SKILL.md from GitHub');
126
+ const skillMdPath = basePath + 'SKILL.md';
127
+ let skillMdContent;
128
+ try {
129
+ skillMdContent = await fetchFromGitHub(owner, repo, skillMdPath, branch);
130
+ }
131
+ catch {
132
+ const repoUrl = 'https://github.com/' + owner + '/' + repo;
133
+ return {
134
+ success: false,
135
+ skillId,
136
+ installPath,
137
+ error: fromRegistry
138
+ ? 'This skill is indexed in the Skillsmith registry but its installation source appears broken (SKILL.md not found at ' +
139
+ (basePath || 'repository root') +
140
+ '). This is a registry data quality issue. Please report it at https://skillsmith.app/contact?topic=registry-quality. Repository: ' +
141
+ repoUrl
142
+ : 'Could not find SKILL.md at ' +
143
+ (basePath || 'repository root') +
144
+ '. Skills must have a SKILL.md file with YAML frontmatter to be installable. Repository: ' +
145
+ repoUrl,
146
+ tips: fromRegistry
147
+ ? [
148
+ 'This is a registry data quality issue, not a path format error',
149
+ 'Report the broken entry: https://skillsmith.app/contact?topic=registry-quality',
150
+ ]
151
+ : [
152
+ 'This skill may be browse-only (no SKILL.md at expected location)',
153
+ 'Verify the repository exists: ' + repoUrl,
154
+ ],
155
+ };
156
+ }
157
+ this.onProgress('validate', 'Validating SKILL.md');
158
+ const validation = validateSkillMd(skillMdContent);
159
+ if (!validation.valid) {
160
+ return {
161
+ success: false,
162
+ skillId,
163
+ installPath,
164
+ error: 'Invalid SKILL.md: ' + validation.errors.join(', '),
165
+ tips: [
166
+ 'SKILL.md must have YAML frontmatter with name and description fields',
167
+ 'Content must be at least 100 characters',
168
+ ],
169
+ };
170
+ }
171
+ const contentHashMismatch = // SMI-3510
172
+ indexedContentHash != null ? hashContent(skillMdContent) !== indexedContentHash : false;
173
+ // Security scan — GAP-06: Restrict skipScan to trusted tiers only
174
+ if (options.skipScan && (trustTier === 'experimental' || trustTier === 'unknown')) {
175
+ return {
176
+ success: false,
177
+ skillId,
178
+ installPath: '',
179
+ error: 'Cannot skip security scan for ' +
180
+ trustTier +
181
+ ' tier skills. ' +
182
+ 'Only verified, curated, community, and local tier skills may use skipScan.',
183
+ tips: [
184
+ 'Trust tier "' + trustTier + '" requires a security scan before installation',
185
+ 'If you believe this skill is safe, request a trust tier upgrade from the author',
186
+ ],
187
+ };
188
+ }
189
+ let securityReport;
190
+ if (!options.skipScan) {
191
+ this.onProgress('scan', 'Running security scan');
192
+ const scannerOptions = TRUST_TIER_SCANNER_OPTIONS[trustTier];
193
+ const scanner = new SecurityScanner(scannerOptions);
194
+ securityReport = scanner.scan(skillId, skillMdContent);
195
+ if (!securityReport.passed) {
196
+ recordAiDefenceFeedback({
197
+ feedback: this.aiDefenceFeedback,
198
+ skillMdContent,
199
+ scanReport: securityReport,
200
+ blocked: true,
201
+ });
202
+ const criticalFindings = securityReport.findings.filter((f) => f.severity === 'critical' || f.severity === 'high');
203
+ const tierContext = trustTier === 'unknown'
204
+ ? ' (Direct GitHub install - strictest scanning applied)'
205
+ : trustTier === 'experimental'
206
+ ? ' (Experimental skill - aggressive scanning applied)'
207
+ : '';
208
+ return {
209
+ success: false,
210
+ skillId,
211
+ installPath,
212
+ securityReport,
213
+ trustTier,
214
+ error: 'Security scan failed with ' +
215
+ criticalFindings.length +
216
+ ' critical/high findings' +
217
+ tierContext +
218
+ (trustTier === 'experimental' || trustTier === 'unknown'
219
+ ? '. skipScan is not available for ' + trustTier + ' tier skills.'
220
+ : '. Use skipScan=true to override (not recommended).'),
221
+ tips: [
222
+ 'Trust tier: ' + trustTier + ' (threshold: ' + scannerOptions.riskThreshold + ')',
223
+ 'Risk score: ' + securityReport.riskScore,
224
+ ],
225
+ };
226
+ }
227
+ }
228
+ // SMI-3863: Pre-install confirmation gate for experimental/unknown registry skills
229
+ const needsConfirmation = fromRegistry &&
230
+ (trustTier === 'experimental' || trustTier === 'unknown') &&
231
+ !options.confirmed;
232
+ if (needsConfirmation) {
233
+ const scanNote = securityReport
234
+ ? securityReport.passed
235
+ ? trustTier + ' tier skills have not been reviewed.'
236
+ : 'Security scan detected issues.'
237
+ : 'No security scan was performed.';
238
+ return {
239
+ success: false,
240
+ skillId,
241
+ installPath,
242
+ securityReport,
243
+ trustTier,
244
+ requiresConfirmation: true,
245
+ confirmationReason: 'This is an ' +
246
+ trustTier +
247
+ ' tier skill. ' +
248
+ scanNote +
249
+ ' Re-run with confirmed=true to proceed.',
250
+ tips: ['Trust tier: ' + trustTier, 'Use confirmed=true to proceed with installation'],
251
+ };
252
+ }
253
+ this.onProgress('optimize', 'Applying optimization');
254
+ const optimizeResult = options.skipOptimize
255
+ ? {
256
+ finalSkillContent: skillMdContent,
257
+ subSkillFiles: [],
258
+ subagentContent: undefined,
259
+ claudeMdSnippet: undefined,
260
+ optimizationInfo: { optimized: false },
261
+ }
262
+ : await applyOptimization(this.db, skillId, skillName, skillMdContent);
263
+ const { finalSkillContent, subSkillFiles, subagentContent, optimizationInfo } = optimizeResult;
264
+ const contentHash = hashContent(finalSkillContent);
265
+ // Write files
266
+ this.onProgress('write', 'Writing skill files');
267
+ const writtenFiles = [];
268
+ try {
269
+ await fs.mkdir(installPath, { recursive: true });
270
+ // Validate directory is not a symlink escape
271
+ const realInstallPath = await fs.realpath(installPath);
272
+ const expectedPrefix = path.resolve(this.skillsDir);
273
+ if (!realInstallPath.startsWith(expectedPrefix + path.sep) &&
274
+ realInstallPath !== expectedPrefix) {
275
+ throw new Error('Install path escapes skills directory: ' + installPath);
276
+ }
277
+ const mainSkillPath = path.join(installPath, 'SKILL.md');
278
+ await safeWriteFile(mainSkillPath, finalSkillContent);
279
+ writtenFiles.push(mainSkillPath);
280
+ // Write sub-skills in parallel
281
+ if (subSkillFiles.length > 0) {
282
+ await Promise.all(subSkillFiles.map(async (subSkill) => {
283
+ const subPath = path.join(installPath, subSkill.filename);
284
+ await safeWriteFile(subPath, subSkill.content);
285
+ writtenFiles.push(subPath);
286
+ }));
287
+ }
288
+ // Write companion subagent if generated
289
+ if (subagentContent) {
290
+ const agentsDir = path.join(os.homedir(), '.claude', 'agents');
291
+ await fs.mkdir(agentsDir, { recursive: true });
292
+ const subagentPath = path.join(agentsDir, skillName + '-specialist.md');
293
+ await safeWriteFile(subagentPath, subagentContent);
294
+ writtenFiles.push(subagentPath);
295
+ optimizationInfo.subagentPath = subagentPath;
296
+ }
297
+ }
298
+ catch (writeError) {
299
+ // Rollback on failure
300
+ for (const filePath of writtenFiles) {
301
+ await fs.unlink(filePath).catch(() => { });
302
+ }
303
+ await fs.rmdir(installPath).catch(() => { });
304
+ throw writeError;
305
+ }
306
+ // Fetch optional files
307
+ const optionalFileScanner = options.skipScan
308
+ ? null
309
+ : new SecurityScanner(TRUST_TIER_SCANNER_OPTIONS[trustTier]);
310
+ const optionalFiles = ['README.md', 'examples.md', 'config.json'];
311
+ const configWarnings = [];
312
+ for (const file of optionalFiles) {
313
+ try {
314
+ const content = await fetchFromGitHub(owner, repo, basePath + file, branch);
315
+ if (optionalFileScanner) {
316
+ const fileScan = optionalFileScanner.scan(skillId + '/' + file, content);
317
+ if (!fileScan.passed)
318
+ continue;
319
+ }
320
+ if (file === 'config.json') {
321
+ const configCheck = validateOptionalConfig(content);
322
+ if (!configCheck.valid)
323
+ continue; // SMI-3870: skip invalid config
324
+ configWarnings.push(...configCheck.warnings);
325
+ }
326
+ await safeWriteFile(path.join(installPath, file), content);
327
+ }
328
+ catch {
329
+ // Optional files are fine to skip
330
+ }
331
+ }
332
+ // Update manifest
333
+ this.onProgress('manifest', 'Updating manifest');
334
+ await this.manifest.updateSafely((currentManifest) => ({
335
+ ...currentManifest,
336
+ installedSkills: {
337
+ ...currentManifest.installedSkills,
338
+ [skillName]: {
339
+ id: skillId,
340
+ name: skillName,
341
+ version: '1.0.0',
342
+ source: 'github:' + owner + '/' + repo,
343
+ installPath,
344
+ installedAt: new Date().toISOString(),
345
+ lastUpdated: new Date().toISOString(),
346
+ originalContentHash: contentHash, // hash of optimized content (post-applyOptimization)
347
+ },
348
+ },
349
+ }));
350
+ if (this.coInstallRecorder) {
351
+ this.coInstallRecorder.recordSessionCoInstalls([...this.sessionInstalledSkillIds, skillId]);
352
+ this.sessionInstalledSkillIds.push(skillId);
353
+ }
354
+ // Persist dependency intelligence (best-effort)
355
+ const depIntel = extractDepIntel(skillMdContent);
356
+ try {
357
+ persistDependencies(this.skillDependencyRepo, skillId, skillMdContent, depIntel.dep_declared);
358
+ }
359
+ catch {
360
+ /* best-effort */
361
+ }
362
+ let quarantinedDeps; // SMI-3871
363
+ if (this.quarantineLookup) {
364
+ try {
365
+ const dqResult = checkDepsAgainstQuarantine(depIntel, this.quarantineLookup);
366
+ if (dqResult.quarantinedDeps.length > 0) {
367
+ quarantinedDeps = dqResult.quarantinedDeps;
368
+ depIntel.dep_warnings.push(...dqResult.warnings);
369
+ }
370
+ }
371
+ catch {
372
+ /* best-effort */
373
+ }
374
+ }
375
+ const trendWarnings = securityReport
376
+ ? collectTrendWarnings({
377
+ historyRepo: this.riskHistoryRepo,
378
+ skillId,
379
+ scanReport: securityReport,
380
+ contentHash,
381
+ })
382
+ : [];
383
+ recordAiDefenceFeedback({
384
+ feedback: this.aiDefenceFeedback,
385
+ skillMdContent,
386
+ scanReport: securityReport,
387
+ blocked: false,
388
+ });
389
+ this.onProgress('done', 'Installation complete');
390
+ const tips = generateTips(skillName, optimizationInfo);
391
+ tips.unshift(...trendWarnings);
392
+ tips.push(...configWarnings);
393
+ if (options.skipScan) {
394
+ tips.unshift('Security scan was skipped. This skill was not scanned for malicious content.');
395
+ }
396
+ if (contentHashMismatch) {
397
+ tips.unshift("Content has changed since Skillsmith last indexed this skill. This may mean the author updated it, or the content was modified. Review recent changes at the skill's repository before using.");
398
+ }
399
+ return {
400
+ success: true,
401
+ skillId,
402
+ installPath,
403
+ securityReport,
404
+ trustTier,
405
+ optimization: optimizationInfo,
406
+ depIntel,
407
+ contentHashMismatch,
408
+ quarantinedDeps,
409
+ tips,
410
+ };
411
+ }
412
+ catch (error) {
413
+ return {
414
+ success: false,
415
+ skillId,
416
+ installPath: '',
417
+ error: sanitizeInstallError(error),
418
+ };
419
+ }
420
+ }
421
+ async uninstall(skillName, options = {}) {
422
+ return performUninstall({
423
+ skillName,
424
+ force: options.force ?? false,
425
+ skillsDir: this.skillsDir,
426
+ manifest: this.manifest,
427
+ skillDependencyRepo: this.skillDependencyRepo,
428
+ onProgress: this.onProgress,
429
+ });
430
+ }
431
+ }
432
+ //# sourceMappingURL=skill-installation.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skill-installation.service.js","sourceRoot":"","sources":["../../../src/services/skill-installation.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,166 @@
1
+ /**
2
+ * @fileoverview Types for SkillInstallationService
3
+ * @module @skillsmith/core/services/skill-installation.types
4
+ * @see SMI-3483: Wave 0 — Extract SkillInstallationService into core
5
+ *
6
+ * Shared types consumed by both mcp-server and CLI for install/uninstall operations.
7
+ */
8
+ import type { ScanReport, ScannerOptions } from '../security/index.js';
9
+ import type { TrustTier } from '../types/skill.js';
10
+ import type { DependencyDeclaration } from '../types/dependencies.js';
11
+ /**
12
+ * Callback invoked during install/uninstall to report progress.
13
+ * CLI wires this to an `ora` spinner; mcp-server wires to MCP notifications.
14
+ */
15
+ export type ProgressCallback = (stage: string, detail: string) => void;
16
+ /** Action to take when a conflict is detected during skill update */
17
+ export type ConflictAction = 'overwrite' | 'merge' | 'cancel';
18
+ /** Options for the install operation */
19
+ export interface InstallOptions {
20
+ /** Force reinstall if the skill already exists */
21
+ force?: boolean;
22
+ /** Skip security scan (not recommended) */
23
+ skipScan?: boolean;
24
+ /** Skip Skillsmith optimization (decomposition, subagent generation) */
25
+ skipOptimize?: boolean;
26
+ /** Action to take when local modifications are detected */
27
+ conflictAction?: ConflictAction;
28
+ /** SMI-3863: User has confirmed they want to install despite security warnings */
29
+ confirmed?: boolean;
30
+ }
31
+ /** Dependency intelligence result from an install */
32
+ export interface DepIntelResult {
33
+ /** Inferred MCP server names from skill content */
34
+ dep_inferred_servers: string[];
35
+ /** Declared dependency block from frontmatter (if present) */
36
+ dep_declared: DependencyDeclaration | undefined;
37
+ /** Warnings about MCP servers referenced but not configured */
38
+ dep_warnings: string[];
39
+ }
40
+ /** Optimization metadata included in install result */
41
+ export interface OptimizationInfo {
42
+ /** Whether skill was optimized */
43
+ optimized: boolean;
44
+ /** Sub-skills created (filenames) */
45
+ subSkills?: string[];
46
+ /** Whether companion subagent was generated */
47
+ subagentGenerated?: boolean;
48
+ /** Path to generated subagent (if any) */
49
+ subagentPath?: string;
50
+ /** Estimated token reduction percentage */
51
+ tokenReductionPercent?: number;
52
+ /** Original line count */
53
+ originalLines?: number;
54
+ /** Optimized line count */
55
+ optimizedLines?: number;
56
+ }
57
+ /** Result of an install operation */
58
+ export interface InstallResult {
59
+ success: boolean;
60
+ skillId: string;
61
+ installPath: string;
62
+ securityReport?: ScanReport;
63
+ tips?: string[];
64
+ error?: string;
65
+ /** Trust tier used for security scanning */
66
+ trustTier?: TrustTier;
67
+ /** Optimization info (Skillsmith Optimization Layer) */
68
+ optimization?: OptimizationInfo;
69
+ /** Path to backup file created during conflict resolution */
70
+ backupPath?: string;
71
+ /** Dependency intelligence extracted during install */
72
+ depIntel?: DepIntelResult;
73
+ /** Whether fetched content hash differs from indexed content hash */
74
+ contentHashMismatch?: boolean;
75
+ /** SMI-3864: Computed quality score (0-1) */
76
+ qualityScore?: number;
77
+ /** SMI-3863: True when the skill requires user confirmation before install */
78
+ requiresConfirmation?: boolean;
79
+ /** SMI-3863: Human-readable reason why confirmation is needed */
80
+ confirmationReason?: string;
81
+ /** SMI-3871: Dependency identifiers that are quarantined */
82
+ quarantinedDeps?: string[];
83
+ }
84
+ /** SMI-3871: Quarantine status for dependency cross-check. */
85
+ export type QuarantineStatus = 'pending' | 'rejected';
86
+ export interface AiDefenceFeedback {
87
+ recordFeedback(params: {
88
+ input: string;
89
+ wasAccurate: boolean;
90
+ verdict: string;
91
+ threatType?: string;
92
+ mitigation?: 'block' | 'warn' | 'log';
93
+ mitigationSuccess?: boolean;
94
+ }): Promise<void>;
95
+ }
96
+ /** Options for the uninstall operation */
97
+ export interface UninstallOptions {
98
+ /** Force removal even if skill has been modified since installation */
99
+ force?: boolean;
100
+ }
101
+ /** Result of an uninstall operation */
102
+ export interface UninstallResult {
103
+ success: boolean;
104
+ skillName: string;
105
+ message: string;
106
+ removedPath?: string;
107
+ warning?: string;
108
+ }
109
+ /** Entry for a single installed skill in the manifest */
110
+ export interface SkillManifestEntry {
111
+ id: string;
112
+ name: string;
113
+ version: string;
114
+ source: string;
115
+ /**
116
+ * Absolute path where the skill is installed.
117
+ * Required by type, but runtime JSON may omit it -- consumers must guard.
118
+ */
119
+ installPath: string;
120
+ installedAt: string;
121
+ lastUpdated: string;
122
+ /** SHA-256 hash of SKILL.md at install time for modification detection */
123
+ originalContentHash?: string;
124
+ /** SHA-256 hash of the content at last update */
125
+ contentHash?: string;
126
+ /** Pinned semver */
127
+ pinnedVersion?: string;
128
+ /** How updates are handled */
129
+ updatePolicy?: 'auto' | 'manual' | 'never';
130
+ }
131
+ /** Manifest tracking all installed skills */
132
+ export interface SkillManifest {
133
+ version: string;
134
+ installedSkills: Record<string, SkillManifestEntry>;
135
+ }
136
+ /** Result from a registry skill lookup */
137
+ export interface RegistrySkillInfo {
138
+ repoUrl: string;
139
+ name: string;
140
+ trustTier: TrustTier;
141
+ /** Whether the skill has been quarantined */
142
+ quarantined?: boolean;
143
+ /** SHA-256 hash of SKILL.md at index time for tamper detection */
144
+ contentHash?: string;
145
+ }
146
+ /**
147
+ * Abstraction for looking up skills in the registry.
148
+ * mcp-server provides the API-first implementation; CLI may provide a simpler one.
149
+ */
150
+ export interface RegistryLookup {
151
+ /**
152
+ * Look up a skill by its ID (e.g. "author/name" or UUID).
153
+ * Returns null if the skill is not found or has no installation source.
154
+ */
155
+ lookup(skillId: string): Promise<RegistrySkillInfo | null>;
156
+ }
157
+ /**
158
+ * Abstraction for recording co-install sessions.
159
+ * mcp-server provides the real implementation; CLI may skip or stub this.
160
+ */
161
+ export interface CoInstallRecorder {
162
+ recordSessionCoInstalls(skillIds: string[]): void;
163
+ }
164
+ /** Security scan configuration per trust tier */
165
+ export declare const TRUST_TIER_SCANNER_OPTIONS: Record<TrustTier, ScannerOptions>;
166
+ //# sourceMappingURL=skill-installation.types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skill-installation.types.d.ts","sourceRoot":"","sources":["../../../src/services/skill-installation.types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,38 @@
1
+ /**
2
+ * @fileoverview Types for SkillInstallationService
3
+ * @module @skillsmith/core/services/skill-installation.types
4
+ * @see SMI-3483: Wave 0 — Extract SkillInstallationService into core
5
+ *
6
+ * Shared types consumed by both mcp-server and CLI for install/uninstall operations.
7
+ */
8
+ // ============================================================================
9
+ // Scanner Config
10
+ // ============================================================================
11
+ /** Security scan configuration per trust tier */
12
+ export const TRUST_TIER_SCANNER_OPTIONS = {
13
+ verified: {
14
+ riskThreshold: 70,
15
+ maxContentLength: 2_000_000,
16
+ },
17
+ curated: {
18
+ riskThreshold: 60,
19
+ maxContentLength: 2_000_000,
20
+ },
21
+ community: {
22
+ riskThreshold: 40,
23
+ maxContentLength: 1_000_000,
24
+ },
25
+ local: {
26
+ riskThreshold: 100,
27
+ maxContentLength: 10_000_000,
28
+ },
29
+ experimental: {
30
+ riskThreshold: 25,
31
+ maxContentLength: 500_000,
32
+ },
33
+ unknown: {
34
+ riskThreshold: 20,
35
+ maxContentLength: 250_000,
36
+ },
37
+ };
38
+ //# sourceMappingURL=skill-installation.types.js.map