UNPKG

llmverify

Version:

AI Output Verification Toolkit — Local-first LLM safety, hallucination detection, PII redaction, prompt injection defense, and runtime monitoring. Zero telemetry. OWASP LLM Top 10 aligned.

120 lines 13.3 kB
"use strict"; /** * CSM6 Baseline Engine * * Cognitive System Management v6 - Baseline Profile * Implements security, privacy, and safety checks. * * @module csm6/baseline * @author Haiec * @license MIT */ Object.defineProperty(exports, "__esModule", { value: true }); exports.CSM6Baseline = void 0; const security_1 = require("./security"); class CSM6Baseline { constructor(config) { this.config = config; this.LIMITATIONS = [ 'Pattern-based detection (free tier)', 'English language only', 'Cannot detect novel attack patterns', 'Context-dependent false positives possible', 'Requires human validation for production use' ]; this.METHODOLOGY = 'CSM6 Baseline Profile: Implements OWASP LLM Top 10 aligned checks ' + 'for security (prompt injection), privacy (PII detection), and ' + 'safety (harmful content). Pattern-based detection with confidence intervals.'; } async audit(input, output) { const findings = []; const checksPerformed = []; const csm6Config = this.config.engines.csm6; // Security checks if (csm6Config.checks.security) { checksPerformed.push('security:prompt-injection'); const injectionFindings = (0, security_1.checkPromptInjection)(input); findings.push(...injectionFindings); } // Privacy checks if (csm6Config.checks.privacy) { checksPerformed.push('privacy:pii-detection'); const piiFindings = (0, security_1.checkPII)(output); findings.push(...piiFindings); } // Safety checks if (csm6Config.checks.safety) { checksPerformed.push('safety:harmful-content'); const harmFindings = (0, security_1.checkHarmfulContent)(output); findings.push(...harmFindings); } // Transparency (always enabled) checksPerformed.push('transparency:audit-trail'); // Calculate summary const summary = this.calculateSummary(findings); // Calculate risk score const riskScore = this.calculateRiskScore(findings); // Determine if passed const passed = !findings.some(f => f.severity === 'critical' || f.severity === 'high'); return { findings, summary, riskScore, passed, profile: csm6Config.profile, checksPerformed, limitations: this.LIMITATIONS, methodology: this.METHODOLOGY }; } calculateSummary(findings) { const bySeverity = { info: 0, low: 0, medium: 0, high: 0, critical: 0 }; const byCategory = { security: 0, privacy: 0, safety: 0, fairness: 0, reliability: 0, governance: 0 }; for (const finding of findings) { bySeverity[finding.severity]++; byCategory[finding.category]++; } return { total: findings.length, bySeverity, byCategory }; } calculateRiskScore(findings) { if (findings.length === 0) return 0; const severityWeights = { info: 0.1, low: 0.2, medium: 0.4, high: 0.7, critical: 1.0 }; let totalWeight = 0; let maxWeight = 0; for (const finding of findings) { const weight = severityWeights[finding.severity] * finding.confidence.value; totalWeight += weight; maxWeight = Math.max(maxWeight, weight); } // Combine average and max for final score const avgWeight = totalWeight / findings.length; const score = avgWeight * 0.6 + maxWeight * 0.4; return Math.min(1, score); } } exports.CSM6Baseline = CSM6Baseline; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseline.js","sourceRoot":"","sources":["../../src/csm6/baseline.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * CSM6 Baseline Engine\n * \n * Cognitive System Management v6 - Baseline Profile\n * Implements security, privacy, and safety checks.\n * \n * @module csm6/baseline\n * @author Haiec\n * @license MIT\n */\n\nimport { Config } from '../types/config';\nimport { CSM6Result, Finding, Severity, Category } from '../types/results';\nimport { checkPromptInjection, checkPII, checkHarmfulContent } from './security';\n\nexport class CSM6Baseline {\n  private readonly LIMITATIONS = [\n    'Pattern-based detection (free tier)',\n    'English language only',\n    'Cannot detect novel attack patterns',\n    'Context-dependent false positives possible',\n    'Requires human validation for production use'\n  ];\n  \n  private readonly METHODOLOGY = \n    'CSM6 Baseline Profile: Implements OWASP LLM Top 10 aligned checks ' +\n    'for security (prompt injection), privacy (PII detection), and ' +\n    'safety (harmful content). Pattern-based detection with confidence intervals.';\n  \n  constructor(private config: Config) {}\n  \n  async audit(input: string, output: string): Promise<CSM6Result> {\n    const findings: Finding[] = [];\n    const checksPerformed: string[] = [];\n    \n    const csm6Config = this.config.engines.csm6;\n    \n    // Security checks\n    if (csm6Config.checks.security) {\n      checksPerformed.push('security:prompt-injection');\n      const injectionFindings = checkPromptInjection(input);\n      findings.push(...injectionFindings);\n    }\n    \n    // Privacy checks\n    if (csm6Config.checks.privacy) {\n      checksPerformed.push('privacy:pii-detection');\n      const piiFindings = checkPII(output);\n      findings.push(...piiFindings);\n    }\n    \n    // Safety checks\n    if (csm6Config.checks.safety) {\n      checksPerformed.push('safety:harmful-content');\n      const harmFindings = checkHarmfulContent(output);\n      findings.push(...harmFindings);\n    }\n    \n    // Transparency (always enabled)\n    checksPerformed.push('transparency:audit-trail');\n    \n    // Calculate summary\n    const summary = this.calculateSummary(findings);\n    \n    // Calculate risk score\n    const riskScore = this.calculateRiskScore(findings);\n    \n    // Determine if passed\n    const passed = !findings.some(f => \n      f.severity === 'critical' || f.severity === 'high'\n    );\n    \n    return {\n      findings,\n      summary,\n      riskScore,\n      passed,\n      profile: csm6Config.profile,\n      checksPerformed,\n      limitations: this.LIMITATIONS,\n      methodology: this.METHODOLOGY\n    };\n  }\n  \n  private calculateSummary(findings: Finding[]): CSM6Result['summary'] {\n    const bySeverity: Record<Severity, number> = {\n      info: 0,\n      low: 0,\n      medium: 0,\n      high: 0,\n      critical: 0\n    };\n    \n    const byCategory: Record<Category, number> = {\n      security: 0,\n      privacy: 0,\n      safety: 0,\n      fairness: 0,\n      reliability: 0,\n      governance: 0\n    };\n    \n    for (const finding of findings) {\n      bySeverity[finding.severity]++;\n      byCategory[finding.category]++;\n    }\n    \n    return {\n      total: findings.length,\n      bySeverity,\n      byCategory\n    };\n  }\n  \n  private calculateRiskScore(findings: Finding[]): number {\n    if (findings.length === 0) return 0;\n    \n    const severityWeights: Record<Severity, number> = {\n      info: 0.1,\n      low: 0.2,\n      medium: 0.4,\n      high: 0.7,\n      critical: 1.0\n    };\n    \n    let totalWeight = 0;\n    let maxWeight = 0;\n    \n    for (const finding of findings) {\n      const weight = severityWeights[finding.severity] * finding.confidence.value;\n      totalWeight += weight;\n      maxWeight = Math.max(maxWeight, weight);\n    }\n    \n    // Combine average and max for final score\n    const avgWeight = totalWeight / findings.length;\n    const score = avgWeight * 0.6 + maxWeight * 0.4;\n    \n    return Math.min(1, score);\n  }\n}\n"]}