Implements Phases 1-8 of the TFTSR implementation plan. Rust backend (Tauri 2.x, src-tauri/): - Multi-provider AI: OpenAI-compatible, Anthropic, Gemini, Mistral, Ollama - PII detection engine: 11 regex patterns with overlap resolution - SQLCipher AES-256 encrypted database with 10 versioned migrations - 28 Tauri IPC commands for triage, analysis, document, and system ops - Ollama: hardware probe, model recommendations, pull/delete with events - RCA and blameless post-mortem Markdown document generators - PDF export via printpdf - Audit log: SHA-256 hash of every external data send - Integration stubs for Confluence, ServiceNow, Azure DevOps (v0.2) Frontend (React 18 + TypeScript + Vite, src/): - 9 pages: full triage workflow NewIssue→LogUpload→Triage→Resolution→RCA→Postmortem→History+Settings - 7 components: ChatWindow, TriageProgress, PiiDiffViewer, DocEditor, HardwareReport, ModelSelector, UI primitives - 3 Zustand stores: session, settings (persisted), history - Type-safe tauriCommands.ts matching Rust backend types exactly - 8 IT domain system prompts (Linux, Windows, Network, K8s, DB, Virt, HW, Obs) DevOps: - .woodpecker/test.yml: rustfmt, clippy, cargo test, tsc, vitest on every push - .woodpecker/release.yml: linux/amd64 + linux/arm64 builds, Gogs release upload Verified: - cargo check: zero errors - tsc --noEmit: zero errors - vitest run: 13/13 unit tests passing Co-Authored-By: Claude Sonnet 4.6 (1M context) <noreply@anthropic.com>
55 lines
2.5 KiB
TypeScript
55 lines
2.5 KiB
TypeScript
import { HMRPayload, Plugin } from 'vite';
|
|
import { EventEmitter } from 'node:events';
|
|
import { C as CustomEventMap, a as ViteNodeRunner, H as HMRPayload$1, b as HotContext } from './index-z0R8hVRu.js';
|
|
import './trace-mapping.d-DLVdEqOp.js';
|
|
|
|
type EventType = string | symbol;
|
|
type Handler<T = unknown> = (event: T) => void;
|
|
interface Emitter<Events extends Record<EventType, unknown>> {
|
|
on: <Key extends keyof Events>(type: Key, handler: Handler<Events[Key]>) => void;
|
|
off: <Key extends keyof Events>(type: Key, handler?: Handler<Events[Key]>) => void;
|
|
emit: (<Key extends keyof Events>(type: Key, event: Events[Key]) => void) & (<Key extends keyof Events>(type: undefined extends Events[Key] ? Key : never) => void);
|
|
}
|
|
type HMREmitter = Emitter<{
|
|
message: HMRPayload;
|
|
}> & EventEmitter;
|
|
declare module 'vite' {
|
|
interface ViteDevServer {
|
|
emitter: HMREmitter;
|
|
}
|
|
}
|
|
declare function createHmrEmitter(): HMREmitter;
|
|
declare function viteNodeHmrPlugin(): Plugin;
|
|
|
|
type ModuleNamespace = Record<string, any> & {
|
|
[Symbol.toStringTag]: 'Module';
|
|
};
|
|
type InferCustomEventPayload<T extends string> = T extends keyof CustomEventMap ? CustomEventMap[T] : any;
|
|
interface HotModule {
|
|
id: string;
|
|
callbacks: HotCallback[];
|
|
}
|
|
interface HotCallback {
|
|
deps: string[];
|
|
fn: (modules: (ModuleNamespace | undefined)[]) => void;
|
|
}
|
|
interface CacheData {
|
|
hotModulesMap: Map<string, HotModule>;
|
|
dataMap: Map<string, any>;
|
|
disposeMap: Map<string, (data: any) => void | Promise<void>>;
|
|
pruneMap: Map<string, (data: any) => void | Promise<void>>;
|
|
customListenersMap: Map<string, ((data: any) => void)[]>;
|
|
ctxToListenersMap: Map<string, Map<string, ((data: any) => void)[]>>;
|
|
messageBuffer: string[];
|
|
isFirstUpdate: boolean;
|
|
pending: boolean;
|
|
queued: Promise<(() => void) | undefined>[];
|
|
}
|
|
declare function getCache(runner: ViteNodeRunner): CacheData;
|
|
declare function sendMessageBuffer(runner: ViteNodeRunner, emitter: HMREmitter): void;
|
|
declare function reload(runner: ViteNodeRunner, files: string[]): Promise<any[]>;
|
|
declare function handleMessage(runner: ViteNodeRunner, emitter: HMREmitter, files: string[], payload: HMRPayload$1): Promise<void>;
|
|
declare function createHotContext(runner: ViteNodeRunner, emitter: HMREmitter, files: string[], ownerPath: string): HotContext;
|
|
|
|
export { type Emitter, type EventType, type HMREmitter, type Handler, type HotCallback, type HotModule, type InferCustomEventPayload, type ModuleNamespace, createHmrEmitter, createHotContext, getCache, handleMessage, reload, sendMessageBuffer, viteNodeHmrPlugin };
|