chainwall 2.1.0 → 2.2.2
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/LICENSE +44 -1
- package/README.md +213 -105
- package/dist/auditor/miner-detector.d.ts +16 -0
- package/dist/auditor/miner-detector.d.ts.map +1 -1
- package/dist/auditor/miner-detector.js +54 -10
- package/dist/auditor/miner-detector.js.map +1 -1
- package/dist/auditor/remediation.d.ts +9 -0
- package/dist/auditor/remediation.d.ts.map +1 -1
- package/dist/auditor/remediation.js +292 -1
- package/dist/auditor/remediation.js.map +1 -1
- package/dist/cli.js +29 -1
- package/dist/cli.js.map +1 -1
- package/dist/commands/monitor.d.ts +13 -0
- package/dist/commands/monitor.d.ts.map +1 -0
- package/dist/commands/monitor.js +102 -0
- package/dist/commands/monitor.js.map +1 -0
- package/dist/config.d.ts +4 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +55 -0
- package/dist/config.js.map +1 -1
- package/dist/mcp-server/index.d.ts.map +1 -1
- package/dist/mcp-server/index.js +4 -0
- package/dist/mcp-server/index.js.map +1 -1
- package/dist/mcp-server/schemas.d.ts +2 -0
- package/dist/mcp-server/schemas.d.ts.map +1 -1
- package/dist/mcp-server/schemas.js +2 -0
- package/dist/mcp-server/schemas.js.map +1 -1
- package/dist/mcp-server/tools/capture-baseline.d.ts +3 -0
- package/dist/mcp-server/tools/capture-baseline.d.ts.map +1 -0
- package/dist/mcp-server/tools/capture-baseline.js +42 -0
- package/dist/mcp-server/tools/capture-baseline.js.map +1 -0
- package/dist/mcp-server/tools/monitor-snapshot.d.ts +3 -0
- package/dist/mcp-server/tools/monitor-snapshot.d.ts.map +1 -0
- package/dist/mcp-server/tools/monitor-snapshot.js +53 -0
- package/dist/mcp-server/tools/monitor-snapshot.js.map +1 -0
- package/dist/monitor/baseline.d.ts +6 -0
- package/dist/monitor/baseline.d.ts.map +1 -0
- package/dist/monitor/baseline.js +64 -0
- package/dist/monitor/baseline.js.map +1 -0
- package/dist/monitor/browser-scanner.d.ts +4 -0
- package/dist/monitor/browser-scanner.d.ts.map +1 -0
- package/dist/monitor/browser-scanner.js +141 -0
- package/dist/monitor/browser-scanner.js.map +1 -0
- package/dist/monitor/clipboard-scanner.d.ts +3 -0
- package/dist/monitor/clipboard-scanner.d.ts.map +1 -0
- package/dist/monitor/clipboard-scanner.js +49 -0
- package/dist/monitor/clipboard-scanner.js.map +1 -0
- package/dist/monitor/correlation.d.ts +9 -0
- package/dist/monitor/correlation.d.ts.map +1 -0
- package/dist/monitor/correlation.js +117 -0
- package/dist/monitor/correlation.js.map +1 -0
- package/dist/monitor/index.d.ts +13 -0
- package/dist/monitor/index.d.ts.map +1 -0
- package/dist/monitor/index.js +11 -0
- package/dist/monitor/index.js.map +1 -0
- package/dist/monitor/known-good.d.ts +24 -0
- package/dist/monitor/known-good.d.ts.map +1 -0
- package/dist/monitor/known-good.js +82 -0
- package/dist/monitor/known-good.js.map +1 -0
- package/dist/monitor/network-scanner.d.ts +4 -0
- package/dist/monitor/network-scanner.d.ts.map +1 -0
- package/dist/monitor/network-scanner.js +123 -0
- package/dist/monitor/network-scanner.js.map +1 -0
- package/dist/monitor/persistence-scanner.d.ts +4 -0
- package/dist/monitor/persistence-scanner.d.ts.map +1 -0
- package/dist/monitor/persistence-scanner.js +156 -0
- package/dist/monitor/persistence-scanner.js.map +1 -0
- package/dist/monitor/process-scanner.d.ts +6 -0
- package/dist/monitor/process-scanner.d.ts.map +1 -0
- package/dist/monitor/process-scanner.js +101 -0
- package/dist/monitor/process-scanner.js.map +1 -0
- package/dist/monitor/shadow-ai-scanner.d.ts +3 -0
- package/dist/monitor/shadow-ai-scanner.d.ts.map +1 -0
- package/dist/monitor/shadow-ai-scanner.js +70 -0
- package/dist/monitor/shadow-ai-scanner.js.map +1 -0
- package/dist/monitor/types.d.ts +79 -0
- package/dist/monitor/types.d.ts.map +1 -0
- package/dist/monitor/types.js +12 -0
- package/dist/monitor/types.js.map +1 -0
- package/dist/reporter/monitor-report.d.ts +3 -0
- package/dist/reporter/monitor-report.d.ts.map +1 -0
- package/dist/reporter/monitor-report.js +89 -0
- package/dist/reporter/monitor-report.js.map +1 -0
- package/dist/reporter/risk-scorer.d.ts +2 -0
- package/dist/reporter/risk-scorer.d.ts.map +1 -1
- package/dist/reporter/risk-scorer.js +12 -0
- package/dist/reporter/risk-scorer.js.map +1 -1
- package/dist/reporter/shared.d.ts.map +1 -1
- package/dist/reporter/shared.js +5 -3
- package/dist/reporter/shared.js.map +1 -1
- package/dist/rules/exfiltration-rules.d.ts +3 -0
- package/dist/rules/exfiltration-rules.d.ts.map +1 -0
- package/dist/rules/exfiltration-rules.js +181 -0
- package/dist/rules/exfiltration-rules.js.map +1 -0
- package/dist/rules/index.d.ts +2 -1
- package/dist/rules/index.d.ts.map +1 -1
- package/dist/rules/index.js +3 -1
- package/dist/rules/index.js.map +1 -1
- package/dist/rules/types.d.ts +9 -1
- package/dist/rules/types.d.ts.map +1 -1
- package/dist/scanner/filesystem-scanner.d.ts.map +1 -1
- package/dist/scanner/filesystem-scanner.js +27 -10
- package/dist/scanner/filesystem-scanner.js.map +1 -1
- package/dist/tui/App.d.ts.map +1 -1
- package/dist/tui/App.js +10 -2
- package/dist/tui/App.js.map +1 -1
- package/dist/tui/components/Footer.d.ts +2 -3
- package/dist/tui/components/Footer.d.ts.map +1 -1
- package/dist/tui/components/Footer.js +11 -5
- package/dist/tui/components/Footer.js.map +1 -1
- package/dist/tui/components/WelcomeScreen.d.ts.map +1 -1
- package/dist/tui/components/WelcomeScreen.js +1 -1
- package/dist/tui/components/WelcomeScreen.js.map +1 -1
- package/dist/tui/educational.d.ts +6 -0
- package/dist/tui/educational.d.ts.map +1 -1
- package/dist/tui/educational.js +37 -0
- package/dist/tui/educational.js.map +1 -1
- package/dist/tui/hooks/useLogs.d.ts +1 -1
- package/dist/tui/hooks/useLogs.d.ts.map +1 -1
- package/dist/tui/hooks/useMonitor.d.ts +28 -0
- package/dist/tui/hooks/useMonitor.d.ts.map +1 -0
- package/dist/tui/hooks/useMonitor.js +127 -0
- package/dist/tui/hooks/useMonitor.js.map +1 -0
- package/dist/tui/screens/AuditPanel.d.ts.map +1 -1
- package/dist/tui/screens/AuditPanel.js +109 -9
- package/dist/tui/screens/AuditPanel.js.map +1 -1
- package/dist/tui/screens/MonitorPanel.d.ts +2 -0
- package/dist/tui/screens/MonitorPanel.d.ts.map +1 -0
- package/dist/tui/screens/MonitorPanel.js +370 -0
- package/dist/tui/screens/MonitorPanel.js.map +1 -0
- package/dist/tui/screens/OverviewPanel.d.ts.map +1 -1
- package/dist/tui/screens/OverviewPanel.js +9 -3
- package/dist/tui/screens/OverviewPanel.js.map +1 -1
- package/dist/tui/screens/ScanPanel.d.ts.map +1 -1
- package/dist/tui/screens/ScanPanel.js +5 -5
- package/dist/tui/screens/ScanPanel.js.map +1 -1
- package/dist/tui/screens/ScanResultsPanel.d.ts.map +1 -1
- package/dist/tui/screens/ScanResultsPanel.js +104 -32
- package/dist/tui/screens/ScanResultsPanel.js.map +1 -1
- package/dist/tui/state.d.ts +7 -3
- package/dist/tui/state.d.ts.map +1 -1
- package/dist/tui/state.js +1 -0
- package/dist/tui/state.js.map +1 -1
- package/dist/tui/utils/open-file.d.ts +4 -0
- package/dist/tui/utils/open-file.d.ts.map +1 -0
- package/dist/tui/utils/open-file.js +29 -0
- package/dist/tui/utils/open-file.js.map +1 -0
- package/install.sh +23 -12
- package/package.json +1 -1
- package/patterns/exfiltration.yaml +160 -0
- package/uninstall.sh +14 -10
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { execFileSync } from 'node:child_process';
|
|
2
|
+
import { platform } from 'node:os';
|
|
3
|
+
import { createRuleEngine } from '../scanner/rule-engine.js';
|
|
4
|
+
import { allRules } from '../rules/index.js';
|
|
5
|
+
import { loadConfig } from '../config.js';
|
|
6
|
+
import { SIGNAL_WEIGHTS } from './types.js';
|
|
7
|
+
const CLIPBOARD_HIJACKER_PATTERNS = [/xclip.*-selection.*-o.*loop/i, /pbpaste.*while/i, /clipboard.*monitor/i, /clipjack/i];
|
|
8
|
+
export function scanClipboard(config) {
|
|
9
|
+
const start = Date.now();
|
|
10
|
+
const findings = [];
|
|
11
|
+
if (!config.clipboardScanEnabled) {
|
|
12
|
+
return { category: 'clipboard', findings: [], durationMs: Date.now() - start };
|
|
13
|
+
}
|
|
14
|
+
let clipContent = '';
|
|
15
|
+
try {
|
|
16
|
+
if (platform() === 'darwin') {
|
|
17
|
+
clipContent = execFileSync('pbpaste', [], { timeout: 3000, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] });
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
clipContent = execFileSync('xclip', ['-selection', 'clipboard', '-o'], { timeout: 3000, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] });
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
catch {
|
|
24
|
+
return { category: 'clipboard', findings, durationMs: Date.now() - start };
|
|
25
|
+
}
|
|
26
|
+
if (!clipContent.trim()) {
|
|
27
|
+
return { category: 'clipboard', findings, durationMs: Date.now() - start };
|
|
28
|
+
}
|
|
29
|
+
// Scan clipboard content through rule engine
|
|
30
|
+
const ruleConfig = loadConfig();
|
|
31
|
+
const engine = createRuleEngine({ rules: allRules, config: ruleConfig });
|
|
32
|
+
const scanFindings = engine.scanFile('clipboard', clipContent);
|
|
33
|
+
for (const f of scanFindings) {
|
|
34
|
+
const signals = [
|
|
35
|
+
{ type: 'sensitive-file-access', weight: SIGNAL_WEIGHTS['sensitive-file-access'], detail: `${f.category}: ${f.ruleName}` },
|
|
36
|
+
];
|
|
37
|
+
findings.push({
|
|
38
|
+
id: `clipboard-${f.ruleId}`,
|
|
39
|
+
category: 'clipboard',
|
|
40
|
+
severity: f.severity,
|
|
41
|
+
title: `Secret in clipboard: ${f.ruleName}`,
|
|
42
|
+
description: `Clipboard contains ${f.description}`,
|
|
43
|
+
signals,
|
|
44
|
+
detail: f.matchedText.slice(0, 20) + '...',
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
return { category: 'clipboard', findings, durationMs: Date.now() - start };
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=clipboard-scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clipboard-scanner.js","sourceRoot":"","sources":["../../src/monitor/clipboard-scanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAE5C,MAAM,2BAA2B,GAAG,CAAC,8BAA8B,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,WAAW,CAAC,CAAC;AAE5H,MAAM,UAAU,aAAa,CAAC,MAAqB;IACjD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACzB,MAAM,QAAQ,GAAqB,EAAE,CAAC;IAEtC,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAC;QACjC,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;IACjF,CAAC;IAED,IAAI,WAAW,GAAG,EAAE,CAAC;IACrB,IAAI,CAAC;QACH,IAAI,QAAQ,EAAE,KAAK,QAAQ,EAAE,CAAC;YAC5B,WAAW,GAAG,YAAY,CAAC,SAAS,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC;QACnH,CAAC;aAAM,CAAC;YACN,WAAW,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC,YAAY,EAAE,WAAW,EAAE,IAAI,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC;QAChJ,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;IAC7E,CAAC;IAED,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC;QACxB,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;IAC7E,CAAC;IAED,6CAA6C;IAC7C,MAAM,UAAU,GAAG,UAAU,EAAE,CAAC;IAChC,MAAM,MAAM,GAAG,gBAAgB,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;IACzE,MAAM,YAAY,GAAG,MAAM,CAAC,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;IAE/D,KAAK,MAAM,CAAC,IAAI,YAAY,EAAE,CAAC;QAC7B,MAAM,OAAO,GAAwB;YACnC,EAAE,IAAI,EAAE,uBAAuB,EAAE,MAAM,EAAE,cAAc,CAAC,uBAAuB,CAAC,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ,EAAE,EAAE;SAC3H,CAAC;QACF,QAAQ,CAAC,IAAI,CAAC;YACZ,EAAE,EAAE,aAAa,CAAC,CAAC,MAAM,EAAE;YAC3B,QAAQ,EAAE,WAAW;YACrB,QAAQ,EAAE,CAAC,CAAC,QAAQ;YACpB,KAAK,EAAE,wBAAwB,CAAC,CAAC,QAAQ,EAAE;YAC3C,WAAW,EAAE,sBAAsB,CAAC,CAAC,WAAW,EAAE;YAClD,OAAO;YACP,MAAM,EAAE,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK;SAC3C,CAAC,CAAC;IACL,CAAC;IAED,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;AAC7E,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { MonitorFinding, MonitorResult, ScannerResult, BaselineState } from './types.js';
|
|
2
|
+
import type { ScanFinding } from '../rules/types.js';
|
|
3
|
+
import type { KnownGoodList } from './known-good.js';
|
|
4
|
+
export declare function correlateFindings(scannerResults: ScannerResult[], scanFindings?: ScanFinding[], baseline?: BaselineState | null, knownGood?: KnownGoodList): MonitorResult;
|
|
5
|
+
export declare function calculateMonitorRiskScore(findings: MonitorFinding[]): {
|
|
6
|
+
score: number;
|
|
7
|
+
label: string;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=correlation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"correlation.d.ts","sourceRoot":"","sources":["../../src/monitor/correlation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAoC,MAAM,YAAY,CAAC;AAChI,OAAO,KAAK,EAAE,WAAW,EAAY,MAAM,mBAAmB,CAAC;AAC/D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAgBrD,wBAAgB,iBAAiB,CAC/B,cAAc,EAAE,aAAa,EAAE,EAC/B,YAAY,CAAC,EAAE,WAAW,EAAE,EAC5B,QAAQ,CAAC,EAAE,aAAa,GAAG,IAAI,EAC/B,SAAS,CAAC,EAAE,aAAa,GACxB,aAAa,CAuFf;AAMD,wBAAgB,yBAAyB,CAAC,QAAQ,EAAE,cAAc,EAAE,GAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAiBtG"}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { diffBaseline } from './baseline.js';
|
|
2
|
+
const SEVERITY_ORDER = { critical: 0, high: 1, medium: 2, low: 3 };
|
|
3
|
+
function elevateSeverity(severity) {
|
|
4
|
+
if (severity === 'low')
|
|
5
|
+
return 'medium';
|
|
6
|
+
if (severity === 'medium')
|
|
7
|
+
return 'high';
|
|
8
|
+
if (severity === 'high')
|
|
9
|
+
return 'critical';
|
|
10
|
+
return 'critical';
|
|
11
|
+
}
|
|
12
|
+
function totalSignalWeight(signals) {
|
|
13
|
+
return signals.reduce((sum, s) => sum + s.weight, 0);
|
|
14
|
+
}
|
|
15
|
+
export function correlateFindings(scannerResults, scanFindings, baseline, knownGood) {
|
|
16
|
+
const start = Date.now();
|
|
17
|
+
const allFindings = [];
|
|
18
|
+
// Collect all findings from scanners
|
|
19
|
+
for (const sr of scannerResults) {
|
|
20
|
+
allFindings.push(...sr.findings);
|
|
21
|
+
}
|
|
22
|
+
// Cross-reference process + network findings (same PID = correlated)
|
|
23
|
+
const processFindings = allFindings.filter(f => f.category === 'process' && f.pid);
|
|
24
|
+
const networkFindings = allFindings.filter(f => f.category === 'network' && f.pid);
|
|
25
|
+
for (const netFinding of networkFindings) {
|
|
26
|
+
const matchingProc = processFindings.find(p => p.pid === netFinding.pid);
|
|
27
|
+
if (matchingProc) {
|
|
28
|
+
// Boost both findings
|
|
29
|
+
netFinding.signals.push({ type: 'ai-child-process', weight: 0.4, detail: `Same PID as process finding: ${matchingProc.title}` });
|
|
30
|
+
matchingProc.signals.push({ type: 'suspicious-destination', weight: 0.4, detail: `Same PID as network finding: ${netFinding.title}` });
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
// Baseline diff: tag new items
|
|
34
|
+
let baselineDelta;
|
|
35
|
+
if (baseline) {
|
|
36
|
+
const currentBaseline = {
|
|
37
|
+
capturedAt: new Date().toISOString(),
|
|
38
|
+
processes: allFindings.filter(f => f.category === 'process').map(f => ({ name: f.processName ?? '', command: f.title })),
|
|
39
|
+
connections: allFindings.filter(f => f.category === 'network').map(f => ({ remoteAddress: f.title, processName: f.processName ?? '' })),
|
|
40
|
+
extensions: allFindings.filter(f => f.category === 'browser').map(f => f.id),
|
|
41
|
+
persistence: allFindings.filter(f => f.category === 'persistence').map(f => f.id),
|
|
42
|
+
};
|
|
43
|
+
baselineDelta = diffBaseline(currentBaseline, baseline);
|
|
44
|
+
// Add new-since-baseline signal to relevant findings
|
|
45
|
+
const newIds = new Set([...baselineDelta.newExtensions, ...baselineDelta.newPersistence]);
|
|
46
|
+
for (const finding of allFindings) {
|
|
47
|
+
const isNew = newIds.has(finding.id) ||
|
|
48
|
+
(finding.category === 'process' && baselineDelta.newProcesses.includes(finding.processName ?? '')) ||
|
|
49
|
+
(finding.category === 'network' && baselineDelta.newConnections.includes(finding.title));
|
|
50
|
+
if (isNew) {
|
|
51
|
+
finding.signals.push({ type: 'new-since-baseline', weight: 0.5, detail: 'Not present in baseline' });
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
// Apply correlation scoring
|
|
56
|
+
for (const finding of allFindings) {
|
|
57
|
+
const weight = totalSignalWeight(finding.signals);
|
|
58
|
+
const signalCount = finding.signals.length;
|
|
59
|
+
if (signalCount <= 1 && weight < 0.8) {
|
|
60
|
+
// Cap at low (info-like, hidden by default)
|
|
61
|
+
if (SEVERITY_ORDER[finding.severity] < SEVERITY_ORDER['low']) {
|
|
62
|
+
finding.severity = 'low';
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
else if (signalCount >= 3) {
|
|
66
|
+
// Elevate severity
|
|
67
|
+
finding.severity = elevateSeverity(finding.severity);
|
|
68
|
+
}
|
|
69
|
+
// signalCount === 2: keep as-reported
|
|
70
|
+
}
|
|
71
|
+
// Dedup by PID + category
|
|
72
|
+
const dedupMap = new Map();
|
|
73
|
+
for (const f of allFindings) {
|
|
74
|
+
const key = f.pid ? `${f.pid}:${f.category}:${f.title}` : f.id;
|
|
75
|
+
if (!dedupMap.has(key)) {
|
|
76
|
+
dedupMap.set(key, f);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
const dedupedFindings = Array.from(dedupMap.values());
|
|
80
|
+
// Sort by severity
|
|
81
|
+
dedupedFindings.sort((a, b) => SEVERITY_ORDER[a.severity] - SEVERITY_ORDER[b.severity]);
|
|
82
|
+
// Calculate risk score
|
|
83
|
+
const riskResult = calculateMonitorRiskScore(dedupedFindings);
|
|
84
|
+
return {
|
|
85
|
+
findings: dedupedFindings,
|
|
86
|
+
scannerResults,
|
|
87
|
+
riskScore: riskResult.score,
|
|
88
|
+
riskLabel: riskResult.label,
|
|
89
|
+
durationMs: Date.now() - start,
|
|
90
|
+
baselineDelta,
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
const MONITOR_MULTIPLIER = 2.0;
|
|
94
|
+
const SEVERITY_POINTS = { critical: 3, high: 2, medium: 1, low: 0.5 };
|
|
95
|
+
const MAX_RAW = 30;
|
|
96
|
+
export function calculateMonitorRiskScore(findings) {
|
|
97
|
+
if (findings.length === 0)
|
|
98
|
+
return { score: 0, label: 'CLEAN' };
|
|
99
|
+
let raw = 0;
|
|
100
|
+
for (const f of findings) {
|
|
101
|
+
let points = SEVERITY_POINTS[f.severity] ?? 0;
|
|
102
|
+
points *= MONITOR_MULTIPLIER;
|
|
103
|
+
raw += points;
|
|
104
|
+
}
|
|
105
|
+
const score = Math.min(10, Math.round((raw / MAX_RAW) * 10 * 10) / 10);
|
|
106
|
+
let label = 'CLEAN';
|
|
107
|
+
if (score > 0 && score <= 2)
|
|
108
|
+
label = 'LOW';
|
|
109
|
+
else if (score > 2 && score <= 5)
|
|
110
|
+
label = 'MODERATE';
|
|
111
|
+
else if (score > 5 && score <= 8)
|
|
112
|
+
label = 'HIGH';
|
|
113
|
+
else if (score > 8)
|
|
114
|
+
label = 'CRITICAL';
|
|
115
|
+
return { score, label };
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=correlation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"correlation.js","sourceRoot":"","sources":["../../src/monitor/correlation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export type { MonitorCategory, MonitorFinding, MonitorResult, MonitorConfig, ScannerResult, ProcessInfo, NetworkConnection, CorrelationSignal, SignalType, BaselineState, BaselineDelta, } from './types.js';
|
|
2
|
+
export { SIGNAL_WEIGHTS } from './types.js';
|
|
3
|
+
export { DEFAULT_KNOWN_GOOD, isKnownGoodProcess, isKnownGoodEndpoint, isKnownGoodChain } from './known-good.js';
|
|
4
|
+
export type { KnownGoodList } from './known-good.js';
|
|
5
|
+
export { scanProcesses } from './process-scanner.js';
|
|
6
|
+
export { scanNetwork } from './network-scanner.js';
|
|
7
|
+
export { scanBrowserExtensions } from './browser-scanner.js';
|
|
8
|
+
export { scanShadowAI } from './shadow-ai-scanner.js';
|
|
9
|
+
export { scanClipboard } from './clipboard-scanner.js';
|
|
10
|
+
export { scanPersistence } from './persistence-scanner.js';
|
|
11
|
+
export { correlateFindings } from './correlation.js';
|
|
12
|
+
export { captureBaseline, saveBaseline, loadBaseline, diffBaseline } from './baseline.js';
|
|
13
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/monitor/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,eAAe,EAAE,cAAc,EAAE,aAAa,EAAE,aAAa,EAC7D,aAAa,EAAE,WAAW,EAAE,iBAAiB,EAAE,iBAAiB,EAChE,UAAU,EAAE,aAAa,EAAE,aAAa,GACzC,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAChH,YAAY,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { SIGNAL_WEIGHTS } from './types.js';
|
|
2
|
+
export { DEFAULT_KNOWN_GOOD, isKnownGoodProcess, isKnownGoodEndpoint, isKnownGoodChain } from './known-good.js';
|
|
3
|
+
export { scanProcesses } from './process-scanner.js';
|
|
4
|
+
export { scanNetwork } from './network-scanner.js';
|
|
5
|
+
export { scanBrowserExtensions } from './browser-scanner.js';
|
|
6
|
+
export { scanShadowAI } from './shadow-ai-scanner.js';
|
|
7
|
+
export { scanClipboard } from './clipboard-scanner.js';
|
|
8
|
+
export { scanPersistence } from './persistence-scanner.js';
|
|
9
|
+
export { correlateFindings } from './correlation.js';
|
|
10
|
+
export { captureBaseline, saveBaseline, loadBaseline, diffBaseline } from './baseline.js';
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/monitor/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAEhH,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/** Built-in known-good allowlists for runtime monitor. Items here generate no findings. */
|
|
2
|
+
export interface KnownGoodList {
|
|
3
|
+
/** Process name patterns that are always safe (lowercase). */
|
|
4
|
+
processes: string[];
|
|
5
|
+
/** Process parent-child chains that are always safe. */
|
|
6
|
+
processChains: Array<{
|
|
7
|
+
parent: string;
|
|
8
|
+
child: string;
|
|
9
|
+
}>;
|
|
10
|
+
/** Network destinations that are known AI tool endpoints. */
|
|
11
|
+
networkEndpoints: string[];
|
|
12
|
+
/** Browser extension IDs that are well-known and safe. */
|
|
13
|
+
browserExtensions: string[];
|
|
14
|
+
/** Persistence entries that are expected OS/tool items. */
|
|
15
|
+
persistenceEntries: string[];
|
|
16
|
+
}
|
|
17
|
+
export declare const DEFAULT_KNOWN_GOOD: KnownGoodList;
|
|
18
|
+
/** Check if a process name is in the known-good list (case-insensitive). */
|
|
19
|
+
export declare function isKnownGoodProcess(name: string, list: KnownGoodList): boolean;
|
|
20
|
+
/** Check if a network destination is known-good. */
|
|
21
|
+
export declare function isKnownGoodEndpoint(dest: string, list: KnownGoodList): boolean;
|
|
22
|
+
/** Check if a process chain (parent->child) is known-good. */
|
|
23
|
+
export declare function isKnownGoodChain(parentName: string, childName: string, list: KnownGoodList): boolean;
|
|
24
|
+
//# sourceMappingURL=known-good.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"known-good.d.ts","sourceRoot":"","sources":["../../src/monitor/known-good.ts"],"names":[],"mappings":"AAAA,2FAA2F;AAE3F,MAAM,WAAW,aAAa;IAC5B,8DAA8D;IAC9D,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,wDAAwD;IACxD,aAAa,EAAE,KAAK,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACxD,6DAA6D;IAC7D,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,0DAA0D;IAC1D,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,2DAA2D;IAC3D,kBAAkB,EAAE,MAAM,EAAE,CAAC;CAC9B;AAED,eAAO,MAAM,kBAAkB,EAAE,aA8DhC,CAAC;AAEF,4EAA4E;AAC5E,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,GAAG,OAAO,CAG7E;AAED,oDAAoD;AACpD,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,GAAG,OAAO,CAG9E;AAED,8DAA8D;AAC9D,wBAAgB,gBAAgB,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,GAAG,OAAO,CAOpG"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
/** Built-in known-good allowlists for runtime monitor. Items here generate no findings. */
|
|
2
|
+
export const DEFAULT_KNOWN_GOOD = {
|
|
3
|
+
processes: [
|
|
4
|
+
'node', 'npm', 'npx', 'git', 'tsc', 'esbuild', 'vite',
|
|
5
|
+
'python', 'python3', 'pip', 'pip3',
|
|
6
|
+
'bash', 'zsh', 'sh', 'fish',
|
|
7
|
+
'code', 'code-insiders', 'cursor', 'cursor-helper',
|
|
8
|
+
'electron', 'chrome', 'firefox', 'safari',
|
|
9
|
+
'ls', 'cat', 'grep', 'find', 'sed', 'awk',
|
|
10
|
+
'docker', 'kubectl', 'terraform',
|
|
11
|
+
'vim', 'nvim', 'nano', 'emacs',
|
|
12
|
+
'ssh', 'ssh-agent', 'gpg-agent',
|
|
13
|
+
'launchd', 'loginwindow', 'WindowServer', 'systemd',
|
|
14
|
+
],
|
|
15
|
+
processChains: [
|
|
16
|
+
{ parent: 'node', child: 'git' },
|
|
17
|
+
{ parent: 'node', child: 'npm' },
|
|
18
|
+
{ parent: 'node', child: 'npx' },
|
|
19
|
+
{ parent: 'node', child: 'tsc' },
|
|
20
|
+
{ parent: 'node', child: 'esbuild' },
|
|
21
|
+
{ parent: 'cursor', child: 'cursor-helper' },
|
|
22
|
+
{ parent: 'cursor', child: 'node' },
|
|
23
|
+
{ parent: 'code', child: 'node' },
|
|
24
|
+
{ parent: 'code-insiders', child: 'node' },
|
|
25
|
+
{ parent: 'zsh', child: 'node' },
|
|
26
|
+
{ parent: 'bash', child: 'node' },
|
|
27
|
+
],
|
|
28
|
+
networkEndpoints: [
|
|
29
|
+
// Anthropic
|
|
30
|
+
'api.anthropic.com',
|
|
31
|
+
'claude.ai',
|
|
32
|
+
// OpenAI
|
|
33
|
+
'api.openai.com',
|
|
34
|
+
'chat.openai.com',
|
|
35
|
+
// Google
|
|
36
|
+
'generativelanguage.googleapis.com',
|
|
37
|
+
'aistudio.google.com',
|
|
38
|
+
// GitHub Copilot
|
|
39
|
+
'copilot-proxy.githubusercontent.com',
|
|
40
|
+
'api.github.com',
|
|
41
|
+
'github.com',
|
|
42
|
+
// Cursor
|
|
43
|
+
'api2.cursor.sh',
|
|
44
|
+
'cursor.sh',
|
|
45
|
+
// Common package registries
|
|
46
|
+
'registry.npmjs.org',
|
|
47
|
+
'pypi.org',
|
|
48
|
+
'rubygems.org',
|
|
49
|
+
// CDNs
|
|
50
|
+
'cdn.jsdelivr.net',
|
|
51
|
+
'unpkg.com',
|
|
52
|
+
// Local
|
|
53
|
+
'localhost',
|
|
54
|
+
'127.0.0.1',
|
|
55
|
+
'::1',
|
|
56
|
+
],
|
|
57
|
+
browserExtensions: [],
|
|
58
|
+
persistenceEntries: [
|
|
59
|
+
'com.apple.terminal.plist',
|
|
60
|
+
'com.googlecode.iterm2.plist',
|
|
61
|
+
'com.microsoft.VSCode.plist',
|
|
62
|
+
'homebrew.mxcl.',
|
|
63
|
+
],
|
|
64
|
+
};
|
|
65
|
+
/** Check if a process name is in the known-good list (case-insensitive). */
|
|
66
|
+
export function isKnownGoodProcess(name, list) {
|
|
67
|
+
const lower = name.toLowerCase();
|
|
68
|
+
return list.processes.some((p) => lower === p || lower.endsWith('/' + p));
|
|
69
|
+
}
|
|
70
|
+
/** Check if a network destination is known-good. */
|
|
71
|
+
export function isKnownGoodEndpoint(dest, list) {
|
|
72
|
+
const lower = dest.toLowerCase();
|
|
73
|
+
return list.networkEndpoints.some((e) => lower === e || lower.endsWith('.' + e));
|
|
74
|
+
}
|
|
75
|
+
/** Check if a process chain (parent->child) is known-good. */
|
|
76
|
+
export function isKnownGoodChain(parentName, childName, list) {
|
|
77
|
+
const pLower = parentName.toLowerCase();
|
|
78
|
+
const cLower = childName.toLowerCase();
|
|
79
|
+
return list.processChains.some((c) => (pLower === c.parent || pLower.endsWith('/' + c.parent)) &&
|
|
80
|
+
(cLower === c.child || cLower.endsWith('/' + c.child)));
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=known-good.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"known-good.js","sourceRoot":"","sources":["../../src/monitor/known-good.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { type KnownGoodList } from './known-good.js';
|
|
2
|
+
import type { ScannerResult, ProcessInfo, MonitorConfig } from './types.js';
|
|
3
|
+
export declare function scanNetwork(config: MonitorConfig, knownGood: KnownGoodList, processMap: Map<number, ProcessInfo>): ScannerResult;
|
|
4
|
+
//# sourceMappingURL=network-scanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"network-scanner.d.ts","sourceRoot":"","sources":["../../src/monitor/network-scanner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAuB,KAAK,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC1E,OAAO,KAAK,EAAkB,aAAa,EAAE,WAAW,EAAqB,aAAa,EAAqB,MAAM,YAAY,CAAC;AAoElI,wBAAgB,WAAW,CAAC,MAAM,EAAE,aAAa,EAAE,SAAS,EAAE,aAAa,EAAE,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,GAAG,aAAa,CAsDhI"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { execFileSync } from 'node:child_process';
|
|
2
|
+
import { platform } from 'node:os';
|
|
3
|
+
import { isKnownGoodEndpoint } from './known-good.js';
|
|
4
|
+
import { SIGNAL_WEIGHTS } from './types.js';
|
|
5
|
+
const SUSPICIOUS_DESTINATIONS = [
|
|
6
|
+
/pastebin\.com/i, /hastebin\.com/i, /paste\.ee/i,
|
|
7
|
+
/webhook\.site/i, /requestbin/i, /hookbin\.com/i,
|
|
8
|
+
/ngrok\.io/i, /ngrok-free\.app/i, /localhost\.run/i, /bore\.digital/i,
|
|
9
|
+
/transfer\.sh/i, /file\.io/i,
|
|
10
|
+
/discord(?:app)?\.com\/api\/webhooks/i,
|
|
11
|
+
/api\.telegram\.org\/bot/i,
|
|
12
|
+
/hooks\.slack\.com/i,
|
|
13
|
+
];
|
|
14
|
+
const RAW_IP_PATTERN = /^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/;
|
|
15
|
+
function parseLsofOutput(output) {
|
|
16
|
+
const connections = [];
|
|
17
|
+
let currentPid = 0;
|
|
18
|
+
let currentName = '';
|
|
19
|
+
for (const line of output.split('\n')) {
|
|
20
|
+
if (!line)
|
|
21
|
+
continue;
|
|
22
|
+
const field = line[0];
|
|
23
|
+
const value = line.slice(1);
|
|
24
|
+
if (field === 'p') {
|
|
25
|
+
currentPid = parseInt(value, 10) || 0;
|
|
26
|
+
}
|
|
27
|
+
else if (field === 'c') {
|
|
28
|
+
currentName = value;
|
|
29
|
+
}
|
|
30
|
+
else if (field === 'n') {
|
|
31
|
+
// Format: "host:port->remote:port" or just "host:port"
|
|
32
|
+
const parts = value.split('->');
|
|
33
|
+
const local = parts[0] ?? '';
|
|
34
|
+
const remote = parts[1] ?? '';
|
|
35
|
+
if (remote) {
|
|
36
|
+
const remoteHost = remote.replace(/:\d+$/, '');
|
|
37
|
+
connections.push({
|
|
38
|
+
pid: currentPid,
|
|
39
|
+
protocol: 'tcp',
|
|
40
|
+
localAddress: local,
|
|
41
|
+
remoteAddress: remote,
|
|
42
|
+
state: 'ESTABLISHED',
|
|
43
|
+
processName: currentName,
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return connections;
|
|
49
|
+
}
|
|
50
|
+
function parseSsOutput(output) {
|
|
51
|
+
const connections = [];
|
|
52
|
+
const lines = output.split('\n');
|
|
53
|
+
for (let i = 1; i < lines.length; i++) {
|
|
54
|
+
const parts = lines[i].trim().split(/\s+/);
|
|
55
|
+
if (parts.length < 6)
|
|
56
|
+
continue;
|
|
57
|
+
const proto = parts[0];
|
|
58
|
+
const state = parts[1];
|
|
59
|
+
const local = parts[4];
|
|
60
|
+
const remote = parts[5];
|
|
61
|
+
// Extract PID from users column if present
|
|
62
|
+
const usersMatch = lines[i].match(/pid=(\d+)/);
|
|
63
|
+
const pid = usersMatch ? parseInt(usersMatch[1], 10) : 0;
|
|
64
|
+
if (remote && remote !== '*:*') {
|
|
65
|
+
connections.push({ pid, protocol: proto, localAddress: local, remoteAddress: remote, state, processName: '' });
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return connections;
|
|
69
|
+
}
|
|
70
|
+
export function scanNetwork(config, knownGood, processMap) {
|
|
71
|
+
const start = Date.now();
|
|
72
|
+
const findings = [];
|
|
73
|
+
let connections = [];
|
|
74
|
+
try {
|
|
75
|
+
if (platform() === 'darwin') {
|
|
76
|
+
const output = execFileSync('lsof', ['-i', '-nP', '-F', 'pcn'], {
|
|
77
|
+
timeout: 10000, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'],
|
|
78
|
+
});
|
|
79
|
+
connections = parseLsofOutput(output);
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
const output = execFileSync('ss', ['-tunp'], {
|
|
83
|
+
timeout: 5000, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'],
|
|
84
|
+
});
|
|
85
|
+
connections = parseSsOutput(output);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
catch {
|
|
89
|
+
return { category: 'network', findings: [], durationMs: Date.now() - start };
|
|
90
|
+
}
|
|
91
|
+
const userAllowed = new Set((config.networkAllowlist ?? []).map(s => s.toLowerCase()));
|
|
92
|
+
const seen = new Set();
|
|
93
|
+
for (const conn of connections) {
|
|
94
|
+
const remoteHost = conn.remoteAddress.replace(/:\d+$/, '').replace(/^\[/, '').replace(/\]$/, '');
|
|
95
|
+
const dedupKey = `${conn.pid}:${remoteHost}`;
|
|
96
|
+
if (seen.has(dedupKey))
|
|
97
|
+
continue;
|
|
98
|
+
seen.add(dedupKey);
|
|
99
|
+
if (isKnownGoodEndpoint(remoteHost, knownGood))
|
|
100
|
+
continue;
|
|
101
|
+
if (userAllowed.has(remoteHost.toLowerCase()))
|
|
102
|
+
continue;
|
|
103
|
+
if (remoteHost === '*' || remoteHost === '0.0.0.0' || remoteHost === '::')
|
|
104
|
+
continue;
|
|
105
|
+
const proc = processMap.get(conn.pid);
|
|
106
|
+
const procName = proc?.name ?? conn.processName ?? `PID ${conn.pid}`;
|
|
107
|
+
const signals = [];
|
|
108
|
+
// Check suspicious destinations
|
|
109
|
+
const isSuspicious = SUSPICIOUS_DESTINATIONS.some(p => p.test(conn.remoteAddress));
|
|
110
|
+
if (isSuspicious) {
|
|
111
|
+
signals.push({ type: 'suspicious-destination', weight: SIGNAL_WEIGHTS['suspicious-destination'], detail: `Connection to ${remoteHost}` });
|
|
112
|
+
findings.push({ id: `net-suspicious-${conn.pid}-${remoteHost}`, category: 'network', severity: 'high', title: `Suspicious destination: ${remoteHost}`, description: `${procName} (PID ${conn.pid}) connected to suspicious endpoint`, signals: [...signals], pid: conn.pid, processName: procName, target: conn.remoteAddress });
|
|
113
|
+
continue;
|
|
114
|
+
}
|
|
115
|
+
// Check raw IP connections (non-local)
|
|
116
|
+
if (RAW_IP_PATTERN.test(remoteHost) && !remoteHost.startsWith('127.') && !remoteHost.startsWith('10.') && !remoteHost.startsWith('192.168.') && !remoteHost.startsWith('172.')) {
|
|
117
|
+
signals.push({ type: 'unknown-destination', weight: SIGNAL_WEIGHTS['unknown-destination'], detail: `Raw IP: ${remoteHost}` });
|
|
118
|
+
findings.push({ id: `net-rawip-${conn.pid}-${remoteHost}`, category: 'network', severity: 'low', title: `Connection to raw IP: ${remoteHost}`, description: `${procName} connected to non-local IP address`, signals: [...signals], pid: conn.pid, processName: procName, target: conn.remoteAddress });
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
return { category: 'network', findings, durationMs: Date.now() - start };
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=network-scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"network-scanner.js","sourceRoot":"","sources":["../../src/monitor/network-scanner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { KnownGoodList } from './known-good.js';
|
|
2
|
+
import type { ScannerResult, MonitorConfig } from './types.js';
|
|
3
|
+
export declare function scanPersistence(config: MonitorConfig, knownGood: KnownGoodList): ScannerResult;
|
|
4
|
+
//# sourceMappingURL=persistence-scanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"persistence-scanner.d.ts","sourceRoot":"","sources":["../../src/monitor/persistence-scanner.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,KAAK,EAAkB,aAAa,EAAE,aAAa,EAAqB,MAAM,YAAY,CAAC;AAWlG,wBAAgB,eAAe,CAAC,MAAM,EAAE,aAAa,EAAE,SAAS,EAAE,aAAa,GAAG,aAAa,CA0H9F"}
|