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.

372 lines 39.1 kB
"use strict"; /** * llmverify Core Module * * Pre-configured verification pipelines for different use cases. * Run all engines with a single command using preset configurations. * * @module core * @author KingCaliber Labs * @license MIT */ Object.defineProperty(exports, "__esModule", { value: true }); exports.presets = exports.PRESETS = void 0; exports.run = run; exports.devVerify = devVerify; exports.prodVerify = prodVerify; exports.strictVerify = strictVerify; exports.fastVerify = fastVerify; exports.ciVerify = ciVerify; exports.createPipeline = createPipeline; const verify_1 = require("../verify"); const classification_1 = require("../engines/classification"); const security_1 = require("../csm6/security"); /** * Preset configurations for quick setup */ /** * Full checks configuration helper */ const fullChecks = { security: true, privacy: true, safety: true, fairness: false, reliability: false, transparency: true }; const minimalChecks = { security: true, privacy: false, safety: false, fairness: false, reliability: false, transparency: false }; exports.PRESETS = { /** * Development mode - balanced, informative output * Good for local development and testing */ dev: { tier: 'free', engines: { hallucination: { enabled: true }, consistency: { enabled: true }, jsonValidator: { enabled: true }, csm6: { enabled: true, profile: 'baseline', checks: fullChecks } }, output: { verbose: true, includeEvidence: true, includeMethodology: true, includeLimitations: true } }, /** * Production mode - optimized for speed, essential checks only * Good for production APIs with latency requirements */ prod: { tier: 'free', engines: { hallucination: { enabled: false }, consistency: { enabled: false }, jsonValidator: { enabled: true }, csm6: { enabled: true, profile: 'baseline', checks: fullChecks } }, output: { verbose: false, includeEvidence: false, includeMethodology: false, includeLimitations: false } }, /** * Strict mode - all engines, maximum scrutiny * Good for high-stakes content, compliance requirements */ strict: { tier: 'free', engines: { hallucination: { enabled: true }, consistency: { enabled: true }, jsonValidator: { enabled: true }, csm6: { enabled: true, profile: 'high_risk', checks: { ...fullChecks, fairness: true, reliability: true } } }, output: { verbose: true, includeEvidence: true, includeMethodology: true, includeLimitations: true } }, /** * Fast mode - minimal checks, maximum speed * Good for high-throughput scenarios */ fast: { tier: 'free', engines: { hallucination: { enabled: false }, consistency: { enabled: false }, jsonValidator: { enabled: false }, csm6: { enabled: true, profile: 'baseline', checks: minimalChecks } }, output: { verbose: false, includeEvidence: false, includeMethodology: false, includeLimitations: false } }, /** * CI mode - optimized for CI/CD pipelines * Returns structured output, fails on high risk */ ci: { tier: 'free', engines: { hallucination: { enabled: true }, consistency: { enabled: true }, jsonValidator: { enabled: true }, csm6: { enabled: true, profile: 'baseline', checks: fullChecks } }, output: { verbose: false, includeEvidence: true, includeMethodology: false, includeLimitations: false } } }; exports.presets = exports.PRESETS; /** * Run all verification engines with a single command * * This is the master function that developers can use to run * comprehensive verification with preset configurations. * * @example * ```typescript * import { run } from 'llmverify/core'; * * // Quick dev mode * const result = await run({ content: aiOutput, preset: 'dev' }); * * // Production mode with input check * const result = await run({ * content: aiOutput, * userInput: userMessage, * preset: 'prod' * }); * * // Strict mode with classification * const result = await run({ * content: aiOutput, * prompt: originalPrompt, * preset: 'strict' * }); * ``` */ async function run(options) { const startTime = Date.now(); const preset = options.preset || 'dev'; const config = { ...exports.PRESETS[preset], ...options.config }; const enginesRun = []; // Prepare parallel tasks const tasks = []; // 1. Main verification (always runs) enginesRun.push('verify'); const verifyTask = (0, verify_1.verify)({ content: options.content, config }); tasks.push(verifyTask); // 2. Classification (if prompt provided) let classificationTask = null; if (options.prompt) { enginesRun.push('classification'); classificationTask = Promise.resolve((0, classification_1.classify)(options.prompt, options.content)); tasks.push(classificationTask); } // 3. Input safety check (if userInput provided) let inputSafetyTask = null; if (options.userInput) { enginesRun.push('input-safety'); inputSafetyTask = Promise.resolve({ safe: (0, security_1.isInputSafe)(options.userInput), injectionFindings: (0, security_1.checkPromptInjection)(options.userInput), riskScore: 0 // Will be calculated }); tasks.push(inputSafetyTask); } // 4. PII check if (config.engines?.csm6?.checks?.privacy !== false) { enginesRun.push('pii-detection'); const piiFindings = (0, security_1.checkPII)(options.content); const { redacted, piiCount } = (0, security_1.redactPII)(options.content); const piiTask = Promise.resolve({ hasPII: piiFindings.length > 0, findings: piiFindings, redacted, piiCount }); tasks.push(piiTask); } // 5. Harmful content check if (config.engines?.csm6?.checks?.safety !== false) { enginesRun.push('harmful-content'); const harmfulFindings = (0, security_1.checkHarmfulContent)(options.content); const harmfulTask = Promise.resolve({ hasHarmful: harmfulFindings.length > 0, findings: harmfulFindings }); tasks.push(harmfulTask); } // Execute all tasks (parallel or sequential based on option) let results; if (options.parallel !== false) { results = await Promise.all(tasks); } else { results = []; for (const task of tasks) { results.push(await task); } } // Extract results const verification = results[0]; let resultIndex = 1; const classification = options.prompt ? results[resultIndex++] : null; const inputSafety = options.userInput ? results[resultIndex++] : null; let piiCheck = null; if (config.engines?.csm6?.checks?.privacy !== false) { piiCheck = results[resultIndex++]; } let harmfulCheck = null; if (config.engines?.csm6?.checks?.safety !== false) { harmfulCheck = results[resultIndex++]; } const totalLatencyMs = Date.now() - startTime; return { verification, classification, inputSafety, piiCheck, harmfulCheck, meta: { preset, enginesRun, totalLatencyMs, timestamp: new Date().toISOString() } }; } // ============================================================================ // QUICK FUNCTIONS // ============================================================================ /** * Quick verification with dev preset */ async function devVerify(content, prompt) { return run({ content, prompt, preset: 'dev' }); } /** * Quick verification with prod preset */ async function prodVerify(content) { return run({ content, preset: 'prod' }); } /** * Quick verification with strict preset */ async function strictVerify(content, prompt) { return run({ content, prompt, preset: 'strict' }); } /** * Quick verification with fast preset */ async function fastVerify(content) { return run({ content, preset: 'fast' }); } /** * Quick verification for CI/CD */ async function ciVerify(content) { return run({ content, preset: 'ci' }); } /** * Build a custom verification pipeline * * @example * ```typescript * const pipeline = createPipeline() * .addStep('pii', async (content) => checkPII(content)) * .addStep('injection', async (content) => checkPromptInjection(content)) * .build(); * * const results = await pipeline.run(content); * ``` */ function createPipeline() { const steps = []; return { addStep(name, run) { steps.push({ name, enabled: true, run }); return this; }, disableStep(name) { const step = steps.find(s => s.name === name); if (step) step.enabled = false; return this; }, enableStep(name) { const step = steps.find(s => s.name === name); if (step) step.enabled = true; return this; }, build() { return { async run(content, context = {}) { const results = {}; const enabledSteps = steps.filter(s => s.enabled); // Run all enabled steps in parallel const promises = enabledSteps.map(async (step) => { const result = await step.run(content, context); return { name: step.name, result }; }); const stepResults = await Promise.all(promises); stepResults.forEach(({ name, result }) => { results[name] = result; }); return results; }, getSteps() { return steps.map(s => ({ name: s.name, enabled: s.enabled })); } }; } }; } exports.default = { run, devVerify, prodVerify, strictVerify, fastVerify, ciVerify, createPipeline, PRESETS: exports.PRESETS }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * llmverify Core Module\n * \n * Pre-configured verification pipelines for different use cases.\n * Run all engines with a single command using preset configurations.\n * \n * @module core\n * @author KingCaliber Labs\n * @license MIT\n */\n\nimport { verify, VerifyOptions } from '../verify';\nimport { classify, ClassificationResult } from '../engines/classification';\nimport { checkPromptInjection, checkPII, checkHarmfulContent, isInputSafe, redactPII } from '../csm6/security';\nimport { VerifyResult, Finding } from '../types/results';\nimport { Config } from '../types/config';\n\n// ============================================================================\n// PRESET CONFIGURATIONS\n// ============================================================================\n\n/**\n * Preset configuration modes for different environments\n */\nexport type PresetMode = 'dev' | 'prod' | 'strict' | 'fast' | 'ci';\n\n/**\n * Preset configurations for quick setup\n */\n/**\n * Full checks configuration helper\n */\nconst fullChecks = {\n  security: true,\n  privacy: true,\n  safety: true,\n  fairness: false,\n  reliability: false,\n  transparency: true\n};\n\nconst minimalChecks = {\n  security: true,\n  privacy: false,\n  safety: false,\n  fairness: false,\n  reliability: false,\n  transparency: false\n};\n\nexport const PRESETS: Record<PresetMode, Partial<Config>> = {\n  /**\n   * Development mode - balanced, informative output\n   * Good for local development and testing\n   */\n  dev: {\n    tier: 'free',\n    engines: {\n      hallucination: { enabled: true },\n      consistency: { enabled: true },\n      jsonValidator: { enabled: true },\n      csm6: { \n        enabled: true,\n        profile: 'baseline',\n        checks: fullChecks\n      }\n    },\n    output: {\n      verbose: true,\n      includeEvidence: true,\n      includeMethodology: true,\n      includeLimitations: true\n    }\n  },\n\n  /**\n   * Production mode - optimized for speed, essential checks only\n   * Good for production APIs with latency requirements\n   */\n  prod: {\n    tier: 'free',\n    engines: {\n      hallucination: { enabled: false },\n      consistency: { enabled: false },\n      jsonValidator: { enabled: true },\n      csm6: { \n        enabled: true,\n        profile: 'baseline',\n        checks: fullChecks\n      }\n    },\n    output: {\n      verbose: false,\n      includeEvidence: false,\n      includeMethodology: false,\n      includeLimitations: false\n    }\n  },\n\n  /**\n   * Strict mode - all engines, maximum scrutiny\n   * Good for high-stakes content, compliance requirements\n   */\n  strict: {\n    tier: 'free',\n    engines: {\n      hallucination: { enabled: true },\n      consistency: { enabled: true },\n      jsonValidator: { enabled: true },\n      csm6: { \n        enabled: true,\n        profile: 'high_risk',\n        checks: { ...fullChecks, fairness: true, reliability: true }\n      }\n    },\n    output: {\n      verbose: true,\n      includeEvidence: true,\n      includeMethodology: true,\n      includeLimitations: true\n    }\n  },\n\n  /**\n   * Fast mode - minimal checks, maximum speed\n   * Good for high-throughput scenarios\n   */\n  fast: {\n    tier: 'free',\n    engines: {\n      hallucination: { enabled: false },\n      consistency: { enabled: false },\n      jsonValidator: { enabled: false },\n      csm6: { \n        enabled: true,\n        profile: 'baseline',\n        checks: minimalChecks\n      }\n    },\n    output: {\n      verbose: false,\n      includeEvidence: false,\n      includeMethodology: false,\n      includeLimitations: false\n    }\n  },\n\n  /**\n   * CI mode - optimized for CI/CD pipelines\n   * Returns structured output, fails on high risk\n   */\n  ci: {\n    tier: 'free',\n    engines: {\n      hallucination: { enabled: true },\n      consistency: { enabled: true },\n      jsonValidator: { enabled: true },\n      csm6: { \n        enabled: true,\n        profile: 'baseline',\n        checks: fullChecks\n      }\n    },\n    output: {\n      verbose: false,\n      includeEvidence: true,\n      includeMethodology: false,\n      includeLimitations: false\n    }\n  }\n};\n\n// ============================================================================\n// CORE RUN FUNCTION\n// ============================================================================\n\n/**\n * Result from running all engines\n */\nexport interface CoreRunResult {\n  /** Overall verification result */\n  verification: VerifyResult;\n  /** Classification result (intent, hallucination, etc.) */\n  classification: ClassificationResult | null;\n  /** Input safety check result */\n  inputSafety: {\n    safe: boolean;\n    injectionFindings: Finding[];\n    riskScore: number;\n  } | null;\n  /** PII detection result */\n  piiCheck: {\n    hasPII: boolean;\n    findings: Finding[];\n    redacted: string;\n    piiCount: number;\n  } | null;\n  /** Harmful content check result */\n  harmfulCheck: {\n    hasHarmful: boolean;\n    findings: Finding[];\n  } | null;\n  /** Execution metadata */\n  meta: {\n    preset: PresetMode;\n    enginesRun: string[];\n    totalLatencyMs: number;\n    timestamp: string;\n  };\n}\n\n/**\n * Options for core run\n */\nexport interface CoreRunOptions {\n  /** Content to verify (AI output) */\n  content: string;\n  /** Original prompt (optional, for classification) */\n  prompt?: string;\n  /** User input to check (optional, for input safety) */\n  userInput?: string;\n  /** Preset mode */\n  preset?: PresetMode;\n  /** Custom config (overrides preset) */\n  config?: Partial<Config>;\n  /** Run engines in parallel */\n  parallel?: boolean;\n}\n\n/**\n * Run all verification engines with a single command\n * \n * This is the master function that developers can use to run\n * comprehensive verification with preset configurations.\n * \n * @example\n * ```typescript\n * import { run } from 'llmverify/core';\n * \n * // Quick dev mode\n * const result = await run({ content: aiOutput, preset: 'dev' });\n * \n * // Production mode with input check\n * const result = await run({ \n *   content: aiOutput, \n *   userInput: userMessage,\n *   preset: 'prod' \n * });\n * \n * // Strict mode with classification\n * const result = await run({ \n *   content: aiOutput, \n *   prompt: originalPrompt,\n *   preset: 'strict' \n * });\n * ```\n */\nexport async function run(options: CoreRunOptions): Promise<CoreRunResult> {\n  const startTime = Date.now();\n  const preset = options.preset || 'dev';\n  const config = { ...PRESETS[preset], ...options.config };\n  const enginesRun: string[] = [];\n\n  // Prepare parallel tasks\n  const tasks: Promise<any>[] = [];\n\n  // 1. Main verification (always runs)\n  enginesRun.push('verify');\n  const verifyTask = verify({ content: options.content, config });\n  tasks.push(verifyTask);\n\n  // 2. Classification (if prompt provided)\n  let classificationTask: Promise<ClassificationResult> | null = null;\n  if (options.prompt) {\n    enginesRun.push('classification');\n    classificationTask = Promise.resolve(classify(options.prompt, options.content));\n    tasks.push(classificationTask);\n  }\n\n  // 3. Input safety check (if userInput provided)\n  let inputSafetyTask: Promise<any> | null = null;\n  if (options.userInput) {\n    enginesRun.push('input-safety');\n    inputSafetyTask = Promise.resolve({\n      safe: isInputSafe(options.userInput),\n      injectionFindings: checkPromptInjection(options.userInput),\n      riskScore: 0 // Will be calculated\n    });\n    tasks.push(inputSafetyTask);\n  }\n\n  // 4. PII check\n  if (config.engines?.csm6?.checks?.privacy !== false) {\n    enginesRun.push('pii-detection');\n    const piiFindings = checkPII(options.content);\n    const { redacted, piiCount } = redactPII(options.content);\n    const piiTask = Promise.resolve({\n      hasPII: piiFindings.length > 0,\n      findings: piiFindings,\n      redacted,\n      piiCount\n    });\n    tasks.push(piiTask);\n  }\n\n  // 5. Harmful content check\n  if (config.engines?.csm6?.checks?.safety !== false) {\n    enginesRun.push('harmful-content');\n    const harmfulFindings = checkHarmfulContent(options.content);\n    const harmfulTask = Promise.resolve({\n      hasHarmful: harmfulFindings.length > 0,\n      findings: harmfulFindings\n    });\n    tasks.push(harmfulTask);\n  }\n\n  // Execute all tasks (parallel or sequential based on option)\n  let results: any[];\n  if (options.parallel !== false) {\n    results = await Promise.all(tasks);\n  } else {\n    results = [];\n    for (const task of tasks) {\n      results.push(await task);\n    }\n  }\n\n  // Extract results\n  const verification = results[0] as VerifyResult;\n  let resultIndex = 1;\n\n  const classification = options.prompt ? results[resultIndex++] as ClassificationResult : null;\n  const inputSafety = options.userInput ? results[resultIndex++] : null;\n  \n  let piiCheck = null;\n  if (config.engines?.csm6?.checks?.privacy !== false) {\n    piiCheck = results[resultIndex++];\n  }\n\n  let harmfulCheck = null;\n  if (config.engines?.csm6?.checks?.safety !== false) {\n    harmfulCheck = results[resultIndex++];\n  }\n\n  const totalLatencyMs = Date.now() - startTime;\n\n  return {\n    verification,\n    classification,\n    inputSafety,\n    piiCheck,\n    harmfulCheck,\n    meta: {\n      preset,\n      enginesRun,\n      totalLatencyMs,\n      timestamp: new Date().toISOString()\n    }\n  };\n}\n\n// ============================================================================\n// QUICK FUNCTIONS\n// ============================================================================\n\n/**\n * Quick verification with dev preset\n */\nexport async function devVerify(content: string, prompt?: string): Promise<CoreRunResult> {\n  return run({ content, prompt, preset: 'dev' });\n}\n\n/**\n * Quick verification with prod preset\n */\nexport async function prodVerify(content: string): Promise<CoreRunResult> {\n  return run({ content, preset: 'prod' });\n}\n\n/**\n * Quick verification with strict preset\n */\nexport async function strictVerify(content: string, prompt?: string): Promise<CoreRunResult> {\n  return run({ content, prompt, preset: 'strict' });\n}\n\n/**\n * Quick verification with fast preset\n */\nexport async function fastVerify(content: string): Promise<CoreRunResult> {\n  return run({ content, preset: 'fast' });\n}\n\n/**\n * Quick verification for CI/CD\n */\nexport async function ciVerify(content: string): Promise<CoreRunResult> {\n  return run({ content, preset: 'ci' });\n}\n\n// ============================================================================\n// PIPELINE BUILDER\n// ============================================================================\n\n/**\n * Pipeline step definition\n */\nexport interface PipelineStep {\n  name: string;\n  enabled: boolean;\n  run: (content: string, context: any) => Promise<any>;\n}\n\n/**\n * Build a custom verification pipeline\n * \n * @example\n * ```typescript\n * const pipeline = createPipeline()\n *   .addStep('pii', async (content) => checkPII(content))\n *   .addStep('injection', async (content) => checkPromptInjection(content))\n *   .build();\n * \n * const results = await pipeline.run(content);\n * ```\n */\nexport function createPipeline() {\n  const steps: PipelineStep[] = [];\n\n  return {\n    addStep(name: string, run: (content: string, context: any) => Promise<any>) {\n      steps.push({ name, enabled: true, run });\n      return this;\n    },\n\n    disableStep(name: string) {\n      const step = steps.find(s => s.name === name);\n      if (step) step.enabled = false;\n      return this;\n    },\n\n    enableStep(name: string) {\n      const step = steps.find(s => s.name === name);\n      if (step) step.enabled = true;\n      return this;\n    },\n\n    build() {\n      return {\n        async run(content: string, context: any = {}) {\n          const results: Record<string, any> = {};\n          const enabledSteps = steps.filter(s => s.enabled);\n\n          // Run all enabled steps in parallel\n          const promises = enabledSteps.map(async step => {\n            const result = await step.run(content, context);\n            return { name: step.name, result };\n          });\n\n          const stepResults = await Promise.all(promises);\n          stepResults.forEach(({ name, result }) => {\n            results[name] = result;\n          });\n\n          return results;\n        },\n\n        getSteps() {\n          return steps.map(s => ({ name: s.name, enabled: s.enabled }));\n        }\n      };\n    }\n  };\n}\n\n// ============================================================================\n// EXPORTS\n// ============================================================================\n\nexport { PRESETS as presets };\nexport default { run, devVerify, prodVerify, strictVerify, fastVerify, ciVerify, createPipeline, PRESETS };\n"]}