@rexymayderio/sentinel 0.1.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.
- package/README.md +295 -0
- package/dist/acquire/acquirer.d.ts +38 -0
- package/dist/acquire/acquirer.d.ts.map +1 -0
- package/dist/acquire/acquirer.js +178 -0
- package/dist/acquire/acquirer.js.map +1 -0
- package/dist/adapters/cli-approval-prompt.d.ts +13 -0
- package/dist/adapters/cli-approval-prompt.d.ts.map +1 -0
- package/dist/adapters/cli-approval-prompt.js +44 -0
- package/dist/adapters/cli-approval-prompt.js.map +1 -0
- package/dist/adapters/github-repo-client.d.ts +9 -0
- package/dist/adapters/github-repo-client.d.ts.map +1 -0
- package/dist/adapters/github-repo-client.js +48 -0
- package/dist/adapters/github-repo-client.js.map +1 -0
- package/dist/adapters/index.d.ts +5 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/index.js +5 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/node-process-runner.d.ts +8 -0
- package/dist/adapters/node-process-runner.d.ts.map +1 -0
- package/dist/adapters/node-process-runner.js +21 -0
- package/dist/adapters/node-process-runner.js.map +1 -0
- package/dist/adapters/npm-registry-client.d.ts +8 -0
- package/dist/adapters/npm-registry-client.d.ts.map +1 -0
- package/dist/adapters/npm-registry-client.js +66 -0
- package/dist/adapters/npm-registry-client.js.map +1 -0
- package/dist/analyzers/ai-prompt-analyzer.d.ts +7 -0
- package/dist/analyzers/ai-prompt-analyzer.d.ts.map +1 -0
- package/dist/analyzers/ai-prompt-analyzer.js +88 -0
- package/dist/analyzers/ai-prompt-analyzer.js.map +1 -0
- package/dist/analyzers/analyzer.d.ts +14 -0
- package/dist/analyzers/analyzer.d.ts.map +1 -0
- package/dist/analyzers/analyzer.js +11 -0
- package/dist/analyzers/analyzer.js.map +1 -0
- package/dist/analyzers/dependency-analyzer.d.ts +10 -0
- package/dist/analyzers/dependency-analyzer.d.ts.map +1 -0
- package/dist/analyzers/dependency-analyzer.js +79 -0
- package/dist/analyzers/dependency-analyzer.js.map +1 -0
- package/dist/analyzers/index.d.ts +13 -0
- package/dist/analyzers/index.d.ts.map +1 -0
- package/dist/analyzers/index.js +30 -0
- package/dist/analyzers/index.js.map +1 -0
- package/dist/analyzers/install-script-analyzer.d.ts +7 -0
- package/dist/analyzers/install-script-analyzer.d.ts.map +1 -0
- package/dist/analyzers/install-script-analyzer.js +64 -0
- package/dist/analyzers/install-script-analyzer.js.map +1 -0
- package/dist/analyzers/match-evidence.d.ts +6 -0
- package/dist/analyzers/match-evidence.d.ts.map +1 -0
- package/dist/analyzers/match-evidence.js +15 -0
- package/dist/analyzers/match-evidence.js.map +1 -0
- package/dist/analyzers/metadata-analyzer.d.ts +7 -0
- package/dist/analyzers/metadata-analyzer.d.ts.map +1 -0
- package/dist/analyzers/metadata-analyzer.js +105 -0
- package/dist/analyzers/metadata-analyzer.js.map +1 -0
- package/dist/analyzers/network-analyzer.d.ts +7 -0
- package/dist/analyzers/network-analyzer.d.ts.map +1 -0
- package/dist/analyzers/network-analyzer.js +47 -0
- package/dist/analyzers/network-analyzer.js.map +1 -0
- package/dist/analyzers/rules/index.d.ts +19 -0
- package/dist/analyzers/rules/index.d.ts.map +1 -0
- package/dist/analyzers/rules/index.js +70 -0
- package/dist/analyzers/rules/index.js.map +1 -0
- package/dist/analyzers/secret-analyzer.d.ts +7 -0
- package/dist/analyzers/secret-analyzer.d.ts.map +1 -0
- package/dist/analyzers/secret-analyzer.js +33 -0
- package/dist/analyzers/secret-analyzer.js.map +1 -0
- package/dist/analyzers/source-analyzer.d.ts +7 -0
- package/dist/analyzers/source-analyzer.d.ts.map +1 -0
- package/dist/analyzers/source-analyzer.js +73 -0
- package/dist/analyzers/source-analyzer.js.map +1 -0
- package/dist/analyzers/static-code-analyzer.d.ts +7 -0
- package/dist/analyzers/static-code-analyzer.d.ts.map +1 -0
- package/dist/analyzers/static-code-analyzer.js +67 -0
- package/dist/analyzers/static-code-analyzer.js.map +1 -0
- package/dist/analyzers/test-path.d.ts +2 -0
- package/dist/analyzers/test-path.d.ts.map +1 -0
- package/dist/analyzers/test-path.js +32 -0
- package/dist/analyzers/test-path.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +176 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/spinner.d.ts +5 -0
- package/dist/cli/spinner.d.ts.map +1 -0
- package/dist/cli/spinner.js +39 -0
- package/dist/cli/spinner.js.map +1 -0
- package/dist/core/index.d.ts +3 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +3 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/permissions.d.ts +4 -0
- package/dist/core/permissions.d.ts.map +1 -0
- package/dist/core/permissions.js +28 -0
- package/dist/core/permissions.js.map +1 -0
- package/dist/core/sentinel.d.ts +32 -0
- package/dist/core/sentinel.d.ts.map +1 -0
- package/dist/core/sentinel.js +164 -0
- package/dist/core/sentinel.js.map +1 -0
- package/dist/domain/artifact.d.ts +34 -0
- package/dist/domain/artifact.d.ts.map +1 -0
- package/dist/domain/artifact.js +2 -0
- package/dist/domain/artifact.js.map +1 -0
- package/dist/domain/finding.d.ts +22 -0
- package/dist/domain/finding.d.ts.map +1 -0
- package/dist/domain/finding.js +30 -0
- package/dist/domain/finding.js.map +1 -0
- package/dist/domain/index.d.ts +7 -0
- package/dist/domain/index.d.ts.map +1 -0
- package/dist/domain/index.js +7 -0
- package/dist/domain/index.js.map +1 -0
- package/dist/domain/permission.d.ts +8 -0
- package/dist/domain/permission.d.ts.map +1 -0
- package/dist/domain/permission.js +21 -0
- package/dist/domain/permission.js.map +1 -0
- package/dist/domain/report.d.ts +35 -0
- package/dist/domain/report.d.ts.map +1 -0
- package/dist/domain/report.js +2 -0
- package/dist/domain/report.js.map +1 -0
- package/dist/domain/risk.d.ts +14 -0
- package/dist/domain/risk.d.ts.map +1 -0
- package/dist/domain/risk.js +15 -0
- package/dist/domain/risk.js.map +1 -0
- package/dist/domain/target.d.ts +12 -0
- package/dist/domain/target.d.ts.map +1 -0
- package/dist/domain/target.js +43 -0
- package/dist/domain/target.js.map +1 -0
- package/dist/engine/data-assessment.d.ts +10 -0
- package/dist/engine/data-assessment.d.ts.map +1 -0
- package/dist/engine/data-assessment.js +39 -0
- package/dist/engine/data-assessment.js.map +1 -0
- package/dist/engine/default-policy.d.ts +16 -0
- package/dist/engine/default-policy.d.ts.map +1 -0
- package/dist/engine/default-policy.js +15 -0
- package/dist/engine/default-policy.js.map +1 -0
- package/dist/engine/index.d.ts +4 -0
- package/dist/engine/index.d.ts.map +1 -0
- package/dist/engine/index.js +4 -0
- package/dist/engine/index.js.map +1 -0
- package/dist/engine/policy-engine.d.ts +13 -0
- package/dist/engine/policy-engine.d.ts.map +1 -0
- package/dist/engine/policy-engine.js +78 -0
- package/dist/engine/policy-engine.js.map +1 -0
- package/dist/engine/risk-calculator.d.ts +15 -0
- package/dist/engine/risk-calculator.d.ts.map +1 -0
- package/dist/engine/risk-calculator.js +57 -0
- package/dist/engine/risk-calculator.js.map +1 -0
- package/dist/factory.d.ts +14 -0
- package/dist/factory.d.ts.map +1 -0
- package/dist/factory.js +25 -0
- package/dist/factory.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/server.d.ts +3 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +151 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/ports/approval-prompt.d.ts +5 -0
- package/dist/ports/approval-prompt.d.ts.map +1 -0
- package/dist/ports/approval-prompt.js +2 -0
- package/dist/ports/approval-prompt.js.map +1 -0
- package/dist/ports/clock.d.ts +5 -0
- package/dist/ports/clock.d.ts.map +1 -0
- package/dist/ports/clock.js +4 -0
- package/dist/ports/clock.js.map +1 -0
- package/dist/ports/index.d.ts +6 -0
- package/dist/ports/index.d.ts.map +1 -0
- package/dist/ports/index.js +6 -0
- package/dist/ports/index.js.map +1 -0
- package/dist/ports/process-runner.d.ts +12 -0
- package/dist/ports/process-runner.d.ts.map +1 -0
- package/dist/ports/process-runner.js +2 -0
- package/dist/ports/process-runner.js.map +1 -0
- package/dist/ports/registry-client.d.ts +14 -0
- package/dist/ports/registry-client.d.ts.map +1 -0
- package/dist/ports/registry-client.js +2 -0
- package/dist/ports/registry-client.js.map +1 -0
- package/dist/ports/repo-client.d.ts +18 -0
- package/dist/ports/repo-client.d.ts.map +1 -0
- package/dist/ports/repo-client.js +2 -0
- package/dist/ports/repo-client.js.map +1 -0
- package/dist/report/index.d.ts +2 -0
- package/dist/report/index.d.ts.map +1 -0
- package/dist/report/index.js +2 -0
- package/dist/report/index.js.map +1 -0
- package/dist/report/report-generator.d.ts +29 -0
- package/dist/report/report-generator.d.ts.map +1 -0
- package/dist/report/report-generator.js +167 -0
- package/dist/report/report-generator.js.map +1 -0
- package/package.json +50 -0
- package/skills/sentinel/SKILL.md +525 -0
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
|
|
3
|
+
import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
|
|
4
|
+
import { z } from 'zod';
|
|
5
|
+
import { createDefaultSentinel } from '../factory.js';
|
|
6
|
+
const server = new McpServer({
|
|
7
|
+
name: 'sentinel',
|
|
8
|
+
version: '0.1.0',
|
|
9
|
+
});
|
|
10
|
+
const sentinel = createDefaultSentinel();
|
|
11
|
+
server.tool('verify_package', 'Verify an npm package for security risks', { name: z.string(), version: z.string().optional() }, async ({ name, version }) => {
|
|
12
|
+
const target = version ? `${name}@${version}` : name;
|
|
13
|
+
const report = await sentinel.verify('npm', target);
|
|
14
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, 'json') }] };
|
|
15
|
+
});
|
|
16
|
+
server.tool('verify_repository', 'Verify a GitHub repository for security risks', { owner: z.string(), repo: z.string() }, async ({ owner, repo }) => {
|
|
17
|
+
const report = await sentinel.verify('github', `${owner}/${repo}`);
|
|
18
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, 'json') }] };
|
|
19
|
+
});
|
|
20
|
+
server.tool('verify_skill', 'Verify a local AI skill directory or SKILL.md file', { path: z.string() }, async ({ path }) => {
|
|
21
|
+
const report = await sentinel.verify('skill', path);
|
|
22
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, 'json') }] };
|
|
23
|
+
});
|
|
24
|
+
server.tool('verify_mcp', 'Verify an MCP server (not yet implemented - returns error)', { name: z.string() }, async ({ name }) => {
|
|
25
|
+
try {
|
|
26
|
+
const report = await sentinel.verify('mcp', name);
|
|
27
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, 'json') }] };
|
|
28
|
+
}
|
|
29
|
+
catch (error) {
|
|
30
|
+
return { content: [{ type: 'text', text: JSON.stringify({ error: String(error) }) }] };
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
server.tool('verify_extension', 'Verify a VSCode extension (not yet implemented - returns error)', { name: z.string() }, async ({ name }) => {
|
|
34
|
+
try {
|
|
35
|
+
const report = await sentinel.verify('vscode', name);
|
|
36
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, 'json') }] };
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
39
|
+
return { content: [{ type: 'text', text: JSON.stringify({ error: String(error) }) }] };
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
server.tool('verify_docker', 'Verify a Docker image (not yet implemented - returns error)', { image: z.string() }, async ({ image }) => {
|
|
43
|
+
try {
|
|
44
|
+
const report = await sentinel.verify('docker', image);
|
|
45
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, 'json') }] };
|
|
46
|
+
}
|
|
47
|
+
catch (error) {
|
|
48
|
+
return { content: [{ type: 'text', text: JSON.stringify({ error: String(error) }) }] };
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
server.tool('calculate_risk', 'Calculate risk score from findings for a target', { type: z.string(), target: z.string() }, async ({ type, target }) => {
|
|
52
|
+
const report = await sentinel.verify(type, target);
|
|
53
|
+
return {
|
|
54
|
+
content: [{
|
|
55
|
+
type: 'text',
|
|
56
|
+
text: JSON.stringify({
|
|
57
|
+
score: report.risk.score,
|
|
58
|
+
level: report.risk.level,
|
|
59
|
+
confidence: report.risk.confidence,
|
|
60
|
+
decision: report.policy.decision,
|
|
61
|
+
}),
|
|
62
|
+
}],
|
|
63
|
+
};
|
|
64
|
+
});
|
|
65
|
+
server.tool('generate_report', 'Generate a security report for a target', {
|
|
66
|
+
type: z.string(),
|
|
67
|
+
target: z.string(),
|
|
68
|
+
format: z.enum(['terminal', 'json', 'markdown']).optional(),
|
|
69
|
+
}, async ({ type, target, format }) => {
|
|
70
|
+
const report = await sentinel.verify(type, target);
|
|
71
|
+
const reportFormat = (format ?? 'json');
|
|
72
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, reportFormat) }] };
|
|
73
|
+
});
|
|
74
|
+
server.tool('scan_directory', 'Scan a local directory for security issues', { path: z.string() }, async ({ path }) => {
|
|
75
|
+
const report = await sentinel.verify('local', path);
|
|
76
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, 'json') }] };
|
|
77
|
+
});
|
|
78
|
+
server.tool('scan_archive', 'Scan a zip archive (not yet implemented - scans as local path)', { path: z.string() }, async ({ path }) => {
|
|
79
|
+
try {
|
|
80
|
+
const report = await sentinel.verify('zip', path);
|
|
81
|
+
return { content: [{ type: 'text', text: sentinel.generateReport(report, 'json') }] };
|
|
82
|
+
}
|
|
83
|
+
catch (error) {
|
|
84
|
+
return { content: [{ type: 'text', text: JSON.stringify({ error: String(error) }) }] };
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
server.tool('approve_install', 'Check if a target would be approved for installation', { type: z.string(), target: z.string() }, async ({ type, target }) => {
|
|
88
|
+
const report = await sentinel.verify(type, target);
|
|
89
|
+
const approvable = report.policy.decision !== 'BLOCK';
|
|
90
|
+
return {
|
|
91
|
+
content: [{
|
|
92
|
+
type: 'text',
|
|
93
|
+
text: JSON.stringify({
|
|
94
|
+
approvable,
|
|
95
|
+
decision: report.policy.decision,
|
|
96
|
+
risk: report.risk,
|
|
97
|
+
reasons: report.policy.reasons,
|
|
98
|
+
dataAssessment: report.dataAssessment,
|
|
99
|
+
}),
|
|
100
|
+
}],
|
|
101
|
+
};
|
|
102
|
+
});
|
|
103
|
+
server.tool('install', 'Verify and install a target (requires explicit confirm flag)', {
|
|
104
|
+
type: z.string(),
|
|
105
|
+
target: z.string(),
|
|
106
|
+
confirm: z.boolean().describe('Must be true to proceed with installation'),
|
|
107
|
+
}, async ({ type, target, confirm }) => {
|
|
108
|
+
if (!confirm) {
|
|
109
|
+
return {
|
|
110
|
+
content: [{
|
|
111
|
+
type: 'text',
|
|
112
|
+
text: JSON.stringify({
|
|
113
|
+
success: false,
|
|
114
|
+
message: 'Installation requires confirm=true. Run verify first, then install with confirm.',
|
|
115
|
+
}),
|
|
116
|
+
}],
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
const result = await sentinel.install(type, target, { forceApprove: true });
|
|
120
|
+
if (result.report.policy.decision === 'BLOCK') {
|
|
121
|
+
return {
|
|
122
|
+
content: [{
|
|
123
|
+
type: 'text',
|
|
124
|
+
text: JSON.stringify({
|
|
125
|
+
success: false,
|
|
126
|
+
message: 'Installation BLOCKED by policy. Cannot override.',
|
|
127
|
+
report: result.report,
|
|
128
|
+
}),
|
|
129
|
+
}],
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
return {
|
|
133
|
+
content: [{
|
|
134
|
+
type: 'text',
|
|
135
|
+
text: JSON.stringify({
|
|
136
|
+
success: result.success,
|
|
137
|
+
message: result.message,
|
|
138
|
+
report: result.report,
|
|
139
|
+
}),
|
|
140
|
+
}],
|
|
141
|
+
};
|
|
142
|
+
});
|
|
143
|
+
async function main() {
|
|
144
|
+
const transport = new StdioServerTransport();
|
|
145
|
+
await server.connect(transport);
|
|
146
|
+
}
|
|
147
|
+
main().catch((error) => {
|
|
148
|
+
console.error('Sentinel MCP server error:', error);
|
|
149
|
+
process.exit(1);
|
|
150
|
+
});
|
|
151
|
+
//# sourceMappingURL=server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"approval-prompt.d.ts","sourceRoot":"","sources":["../../src/ports/approval-prompt.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAE9D,MAAM,WAAW,cAAc;IAC7B,eAAe,CAAC,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CAC/D"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"approval-prompt.js","sourceRoot":"","sources":["../../src/ports/approval-prompt.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clock.d.ts","sourceRoot":"","sources":["../../src/ports/clock.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,KAAK;IACpB,GAAG,IAAI,IAAI,CAAC;CACb;AAED,eAAO,MAAM,WAAW,EAAE,KAEzB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clock.js","sourceRoot":"","sources":["../../src/ports/clock.ts"],"names":[],"mappings":"AAIA,MAAM,CAAC,MAAM,WAAW,GAAU;IAChC,GAAG,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;CACtB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ports/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ports/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface ProcessResult {
|
|
2
|
+
readonly exitCode: number;
|
|
3
|
+
readonly stdout: string;
|
|
4
|
+
readonly stderr: string;
|
|
5
|
+
}
|
|
6
|
+
export interface ProcessRunner {
|
|
7
|
+
run(command: string, args: string[], options?: {
|
|
8
|
+
cwd?: string;
|
|
9
|
+
env?: Record<string, string>;
|
|
10
|
+
}): Promise<ProcessResult>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=process-runner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"process-runner.d.ts","sourceRoot":"","sources":["../../src/ports/process-runner.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;CACzB;AAED,MAAM,WAAW,aAAa;IAC5B,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,OAAO,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;KAAE,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;CACxH"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"process-runner.js","sourceRoot":"","sources":["../../src/ports/process-runner.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { PackageMetadata } from '../domain/artifact.js';
|
|
2
|
+
export interface NpmPackageInfo extends PackageMetadata {
|
|
3
|
+
readonly tarballUrl: string;
|
|
4
|
+
}
|
|
5
|
+
export interface OsvVulnerability {
|
|
6
|
+
readonly id: string;
|
|
7
|
+
readonly summary: string;
|
|
8
|
+
readonly severity?: string;
|
|
9
|
+
}
|
|
10
|
+
export interface RegistryClient {
|
|
11
|
+
getNpmPackage(name: string, version?: string): Promise<NpmPackageInfo>;
|
|
12
|
+
checkOsv(packageName: string, version: string, ecosystem: string): Promise<OsvVulnerability[]>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=registry-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry-client.d.ts","sourceRoot":"","sources":["../../src/ports/registry-client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAE7D,MAAM,WAAW,cAAe,SAAQ,eAAe;IACrD,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;CAC7B;AAED,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,cAAc;IAC7B,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;IACvE,QAAQ,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;CAChG"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry-client.js","sourceRoot":"","sources":["../../src/ports/registry-client.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export interface RepoInfo {
|
|
2
|
+
readonly fullName: string;
|
|
3
|
+
readonly description?: string;
|
|
4
|
+
readonly stars: number;
|
|
5
|
+
readonly forks: number;
|
|
6
|
+
readonly defaultBranch: string;
|
|
7
|
+
readonly archived: boolean;
|
|
8
|
+
readonly createdAt: string;
|
|
9
|
+
readonly updatedAt: string;
|
|
10
|
+
readonly hasSecurityPolicy: boolean;
|
|
11
|
+
readonly tarballUrl: string;
|
|
12
|
+
readonly topics?: string[];
|
|
13
|
+
}
|
|
14
|
+
export interface RepoClient {
|
|
15
|
+
getRepo(owner: string, repo: string): Promise<RepoInfo>;
|
|
16
|
+
downloadTarball(url: string): Promise<Buffer>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=repo-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repo-client.d.ts","sourceRoot":"","sources":["../../src/ports/repo-client.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,QAAQ;IACvB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC;IAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,iBAAiB,EAAE,OAAO,CAAC;IACpC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;CAC5B;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;IACxD,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CAC/C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repo-client.js","sourceRoot":"","sources":["../../src/ports/repo-client.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/report/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/report/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { VerificationReport } from '../domain/report.js';
|
|
2
|
+
import type { ReportFormat } from '../domain/report.js';
|
|
3
|
+
export interface ReportStrategy {
|
|
4
|
+
format: ReportFormat;
|
|
5
|
+
generate(report: VerificationReport): string;
|
|
6
|
+
}
|
|
7
|
+
export declare class TerminalReporter implements ReportStrategy {
|
|
8
|
+
readonly format: "terminal";
|
|
9
|
+
generate(report: VerificationReport): string;
|
|
10
|
+
}
|
|
11
|
+
export declare class JsonReporter implements ReportStrategy {
|
|
12
|
+
readonly format: "json";
|
|
13
|
+
generate(report: VerificationReport): string;
|
|
14
|
+
}
|
|
15
|
+
export declare class MarkdownReporter implements ReportStrategy {
|
|
16
|
+
readonly format: "markdown";
|
|
17
|
+
generate(report: VerificationReport): string;
|
|
18
|
+
}
|
|
19
|
+
export declare class StubReporter implements ReportStrategy {
|
|
20
|
+
readonly format: ReportFormat;
|
|
21
|
+
constructor(format: ReportFormat);
|
|
22
|
+
generate(_report: VerificationReport): string;
|
|
23
|
+
}
|
|
24
|
+
export declare class ReportGenerator {
|
|
25
|
+
private readonly strategies;
|
|
26
|
+
constructor();
|
|
27
|
+
generate(report: VerificationReport, format?: ReportFormat): string;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=report-generator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report-generator.d.ts","sourceRoot":"","sources":["../../src/report/report-generator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGxD,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,YAAY,CAAC;IACrB,QAAQ,CAAC,MAAM,EAAE,kBAAkB,GAAG,MAAM,CAAC;CAC9C;AAqBD,qBAAa,gBAAiB,YAAW,cAAc;IACrD,QAAQ,CAAC,MAAM,EAAG,UAAU,CAAU;IAEtC,QAAQ,CAAC,MAAM,EAAE,kBAAkB,GAAG,MAAM;CA4E7C;AAED,qBAAa,YAAa,YAAW,cAAc;IACjD,QAAQ,CAAC,MAAM,EAAG,MAAM,CAAU;IAElC,QAAQ,CAAC,MAAM,EAAE,kBAAkB,GAAG,MAAM;CAG7C;AAED,qBAAa,gBAAiB,YAAW,cAAc;IACrD,QAAQ,CAAC,MAAM,EAAG,UAAU,CAAU;IAEtC,QAAQ,CAAC,MAAM,EAAE,kBAAkB,GAAG,MAAM;CAyC7C;AAED,qBAAa,YAAa,YAAW,cAAc;IACrC,QAAQ,CAAC,MAAM,EAAE,YAAY;gBAApB,MAAM,EAAE,YAAY;IAEzC,QAAQ,CAAC,OAAO,EAAE,kBAAkB,GAAG,MAAM;CAG9C;AAED,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoC;;IAa/D,QAAQ,CAAC,MAAM,EAAE,kBAAkB,EAAE,MAAM,GAAE,YAAyB,GAAG,MAAM;CAOhF"}
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import kleur from 'kleur';
|
|
2
|
+
function riskColor(level) {
|
|
3
|
+
switch (level) {
|
|
4
|
+
case 'CRITICAL': return kleur.red().bold;
|
|
5
|
+
case 'HIGH': return kleur.red;
|
|
6
|
+
case 'MEDIUM': return kleur.yellow;
|
|
7
|
+
case 'LOW': return kleur.green;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
function decisionColor(decision) {
|
|
11
|
+
switch (decision) {
|
|
12
|
+
case 'BLOCK': return kleur.red().bold;
|
|
13
|
+
case 'REQUIRE_APPROVAL': return kleur.yellow().bold;
|
|
14
|
+
case 'WARN': return kleur.yellow;
|
|
15
|
+
case 'AUTO_APPROVE': return kleur.green().bold;
|
|
16
|
+
default: return kleur.white;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
export class TerminalReporter {
|
|
20
|
+
format = 'terminal';
|
|
21
|
+
generate(report) {
|
|
22
|
+
const lines = [];
|
|
23
|
+
const color = riskColor(report.risk.level);
|
|
24
|
+
lines.push('');
|
|
25
|
+
lines.push(kleur.bold().cyan('═══ Sentinel Security Report ═══'));
|
|
26
|
+
lines.push('');
|
|
27
|
+
lines.push(` Target: ${kleur.white(report.target.ecosystem)}:${kleur.cyan(report.target.name)}`);
|
|
28
|
+
lines.push(` Risk: ${color(report.risk.level)} (${report.risk.score}/100)`);
|
|
29
|
+
lines.push(` Confidence: ${report.risk.confidence}%`);
|
|
30
|
+
lines.push(` Decision: ${decisionColor(report.policy.decision)(report.policy.decision)}`);
|
|
31
|
+
lines.push(` Action: ${report.recommendedAction}`);
|
|
32
|
+
lines.push('');
|
|
33
|
+
if (!report.dataAssessment.sufficient && report.dataAssessment.reasons.length > 0) {
|
|
34
|
+
lines.push(kleur.yellow().bold(' Limited data gathered - manual review recommended:'));
|
|
35
|
+
for (const reason of report.dataAssessment.reasons) {
|
|
36
|
+
lines.push(` • ${reason}`);
|
|
37
|
+
}
|
|
38
|
+
lines.push('');
|
|
39
|
+
}
|
|
40
|
+
if (report.policy.reasons.length > 0) {
|
|
41
|
+
lines.push(kleur.bold(' Policy Reasons:'));
|
|
42
|
+
for (const reason of report.policy.reasons) {
|
|
43
|
+
lines.push(` • ${reason}`);
|
|
44
|
+
}
|
|
45
|
+
lines.push('');
|
|
46
|
+
}
|
|
47
|
+
const critical = report.findings.filter((f) => f.severity === 'CRITICAL' && !f.positive);
|
|
48
|
+
const high = report.findings.filter((f) => f.severity === 'HIGH' && !f.positive);
|
|
49
|
+
const medium = report.findings.filter((f) => f.severity === 'MEDIUM' && !f.positive);
|
|
50
|
+
const low = report.findings.filter((f) => f.severity === 'LOW' && !f.positive);
|
|
51
|
+
const positive = report.findings.filter((f) => f.positive);
|
|
52
|
+
const testFindingCount = report.findings.filter((f) => f.isTest && !f.positive).length;
|
|
53
|
+
lines.push(kleur.bold(' Findings Summary:'));
|
|
54
|
+
lines.push(` Critical: ${kleur.red(String(critical.length))} High: ${kleur.red(String(high.length))} Medium: ${kleur.yellow(String(medium.length))} Low: ${kleur.green(String(low.length))} Positive: ${kleur.green(String(positive.length))}`);
|
|
55
|
+
if (testFindingCount > 0) {
|
|
56
|
+
lines.push(kleur.dim(` (${testFindingCount} finding(s) in test/fixture files, down-weighted in scoring)`));
|
|
57
|
+
}
|
|
58
|
+
lines.push('');
|
|
59
|
+
const displayFindings = [...critical, ...high, ...medium].slice(0, 20);
|
|
60
|
+
if (displayFindings.length > 0) {
|
|
61
|
+
lines.push(kleur.bold(' Top Findings:'));
|
|
62
|
+
for (const f of displayFindings) {
|
|
63
|
+
const sev = f.severity === 'CRITICAL' ? kleur.red('[CRITICAL]') :
|
|
64
|
+
f.severity === 'HIGH' ? kleur.red('[HIGH]') :
|
|
65
|
+
kleur.yellow(`[${f.severity}]`);
|
|
66
|
+
const loc = f.file ? ` (${f.file}${f.line ? `:${f.line}` : ''})` : '';
|
|
67
|
+
const testTag = f.isTest ? kleur.dim(' [test-file]') : '';
|
|
68
|
+
lines.push(` ${sev} ${f.title}${loc}${testTag}`);
|
|
69
|
+
lines.push(` ${kleur.dim(f.description)}`);
|
|
70
|
+
if (f.evidence) {
|
|
71
|
+
lines.push(` ${kleur.dim('>')} ${kleur.dim(f.evidence)}`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
lines.push('');
|
|
75
|
+
}
|
|
76
|
+
if (report.permissions.length > 0) {
|
|
77
|
+
lines.push(kleur.bold(' Permissions Requested:'));
|
|
78
|
+
for (const p of report.permissions) {
|
|
79
|
+
lines.push(` • ${p.type}: ${p.description}`);
|
|
80
|
+
}
|
|
81
|
+
lines.push('');
|
|
82
|
+
}
|
|
83
|
+
lines.push(kleur.dim(` Scanned at ${report.scannedAt} (${report.durationMs}ms)`));
|
|
84
|
+
lines.push('');
|
|
85
|
+
return lines.join('\n');
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
export class JsonReporter {
|
|
89
|
+
format = 'json';
|
|
90
|
+
generate(report) {
|
|
91
|
+
return JSON.stringify(report, null, 2);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
export class MarkdownReporter {
|
|
95
|
+
format = 'markdown';
|
|
96
|
+
generate(report) {
|
|
97
|
+
const lines = [];
|
|
98
|
+
lines.push(`# Sentinel Security Report`);
|
|
99
|
+
lines.push('');
|
|
100
|
+
lines.push(`**Target:** ${report.target.ecosystem}:${report.target.name}`);
|
|
101
|
+
lines.push(`**Risk:** ${report.risk.level} (${report.risk.score}/100)`);
|
|
102
|
+
lines.push(`**Confidence:** ${report.risk.confidence}%`);
|
|
103
|
+
lines.push(`**Decision:** ${report.policy.decision}`);
|
|
104
|
+
lines.push(`**Recommended Action:** ${report.recommendedAction}`);
|
|
105
|
+
lines.push('');
|
|
106
|
+
if (!report.dataAssessment.sufficient && report.dataAssessment.reasons.length > 0) {
|
|
107
|
+
lines.push('> Limited data could be gathered for this target - manual review is recommended.');
|
|
108
|
+
lines.push('');
|
|
109
|
+
lines.push('## Data Limitations');
|
|
110
|
+
for (const reason of report.dataAssessment.reasons) {
|
|
111
|
+
lines.push(`- ${reason}`);
|
|
112
|
+
}
|
|
113
|
+
lines.push('');
|
|
114
|
+
}
|
|
115
|
+
lines.push('## Policy Reasons');
|
|
116
|
+
for (const reason of report.policy.reasons) {
|
|
117
|
+
lines.push(`- ${reason}`);
|
|
118
|
+
}
|
|
119
|
+
lines.push('');
|
|
120
|
+
lines.push('## Findings');
|
|
121
|
+
lines.push('| Severity | Category | Title | File | Line | Evidence |');
|
|
122
|
+
lines.push('|----------|----------|-------|------|------|----------|');
|
|
123
|
+
for (const f of report.findings.filter((f) => !f.positive)) {
|
|
124
|
+
const evidence = f.evidence ? `\`${f.evidence.replace(/\|/g, '\\|')}\`` : '-';
|
|
125
|
+
const file = f.file ? `${f.file}${f.isTest ? ' _(test)_' : ''}` : '-';
|
|
126
|
+
lines.push(`| ${f.severity} | ${f.category} | ${f.title} | ${file} | ${f.line ?? '-'} | ${evidence} |`);
|
|
127
|
+
}
|
|
128
|
+
if (report.permissions.length > 0) {
|
|
129
|
+
lines.push('');
|
|
130
|
+
lines.push('## Permissions');
|
|
131
|
+
for (const p of report.permissions) {
|
|
132
|
+
lines.push(`- **${p.type}**: ${p.description}`);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
return lines.join('\n');
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
export class StubReporter {
|
|
139
|
+
format;
|
|
140
|
+
constructor(format) {
|
|
141
|
+
this.format = format;
|
|
142
|
+
}
|
|
143
|
+
generate(_report) {
|
|
144
|
+
return `[${this.format} report format not yet implemented in MVP]`;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
export class ReportGenerator {
|
|
148
|
+
strategies;
|
|
149
|
+
constructor() {
|
|
150
|
+
this.strategies = new Map([
|
|
151
|
+
['terminal', new TerminalReporter()],
|
|
152
|
+
['json', new JsonReporter()],
|
|
153
|
+
['markdown', new MarkdownReporter()],
|
|
154
|
+
['sarif', new StubReporter('sarif')],
|
|
155
|
+
['html', new StubReporter('html')],
|
|
156
|
+
['pdf', new StubReporter('pdf')],
|
|
157
|
+
]);
|
|
158
|
+
}
|
|
159
|
+
generate(report, format = 'terminal') {
|
|
160
|
+
const strategy = this.strategies.get(format);
|
|
161
|
+
if (!strategy) {
|
|
162
|
+
throw new Error(`Unsupported report format: ${format}`);
|
|
163
|
+
}
|
|
164
|
+
return strategy.generate(report);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
//# sourceMappingURL=report-generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report-generator.js","sourceRoot":"","sources":["../../src/report/report-generator.ts"],"names":[],"mappings":"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"}
|
package/package.json
ADDED
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@rexymayderio/sentinel",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Universal Security Verification Framework for AI Agent Installations",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"bin": {
|
|
7
|
+
"sentinel-mcp": "./dist/mcp/server.js",
|
|
8
|
+
"sentinel": "./dist/cli/index.js"
|
|
9
|
+
},
|
|
10
|
+
"main": "./dist/index.js",
|
|
11
|
+
"types": "./dist/index.d.ts",
|
|
12
|
+
"files": [
|
|
13
|
+
"dist",
|
|
14
|
+
"skills"
|
|
15
|
+
],
|
|
16
|
+
"scripts": {
|
|
17
|
+
"build": "tsc",
|
|
18
|
+
"dev": "tsx src/cli/index.ts",
|
|
19
|
+
"start": "node dist/cli/index.js",
|
|
20
|
+
"mcp": "tsx src/mcp/server.ts",
|
|
21
|
+
"test": "vitest run",
|
|
22
|
+
"test:watch": "vitest",
|
|
23
|
+
"prepublishOnly": "npm run build"
|
|
24
|
+
},
|
|
25
|
+
"engines": {
|
|
26
|
+
"node": ">=20.0.0"
|
|
27
|
+
},
|
|
28
|
+
"keywords": [
|
|
29
|
+
"security",
|
|
30
|
+
"verification",
|
|
31
|
+
"ai-agent",
|
|
32
|
+
"supply-chain"
|
|
33
|
+
],
|
|
34
|
+
"license": "MIT",
|
|
35
|
+
"dependencies": {
|
|
36
|
+
"@modelcontextprotocol/sdk": "^1.29.0",
|
|
37
|
+
"commander": "^15.0.0",
|
|
38
|
+
"fast-glob": "^3.3.3",
|
|
39
|
+
"kleur": "^4.1.5",
|
|
40
|
+
"tar": "^7.4.3",
|
|
41
|
+
"zod": "^4.4.3"
|
|
42
|
+
},
|
|
43
|
+
"devDependencies": {
|
|
44
|
+
"@types/node": "^22.15.0",
|
|
45
|
+
"@types/tar": "^6.1.13",
|
|
46
|
+
"tsx": "^4.19.4",
|
|
47
|
+
"typescript": "^5.8.3",
|
|
48
|
+
"vitest": "^3.2.4"
|
|
49
|
+
}
|
|
50
|
+
}
|