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>
104 lines
2.9 KiB
JavaScript
104 lines
2.9 KiB
JavaScript
import { getSafeTimers } from '@vitest/utils';
|
|
import { c as createBirpc } from './index.68735LiX.js';
|
|
import { g as getWorkerState } from './utils.C8RiOc4B.js';
|
|
|
|
const { get } = Reflect;
|
|
function withSafeTimers(fn) {
|
|
const { setTimeout, clearTimeout, nextTick, setImmediate, clearImmediate } = getSafeTimers();
|
|
const currentSetTimeout = globalThis.setTimeout;
|
|
const currentClearTimeout = globalThis.clearTimeout;
|
|
const currentSetImmediate = globalThis.setImmediate;
|
|
const currentClearImmediate = globalThis.clearImmediate;
|
|
const currentNextTick = globalThis.process?.nextTick;
|
|
try {
|
|
globalThis.setTimeout = setTimeout;
|
|
globalThis.clearTimeout = clearTimeout;
|
|
globalThis.setImmediate = setImmediate;
|
|
globalThis.clearImmediate = clearImmediate;
|
|
if (globalThis.process) {
|
|
globalThis.process.nextTick = nextTick;
|
|
}
|
|
const result = fn();
|
|
return result;
|
|
} finally {
|
|
globalThis.setTimeout = currentSetTimeout;
|
|
globalThis.clearTimeout = currentClearTimeout;
|
|
globalThis.setImmediate = currentSetImmediate;
|
|
globalThis.clearImmediate = currentClearImmediate;
|
|
if (globalThis.process) {
|
|
nextTick(() => {
|
|
globalThis.process.nextTick = currentNextTick;
|
|
});
|
|
}
|
|
}
|
|
}
|
|
const promises = /* @__PURE__ */ new Set();
|
|
async function rpcDone() {
|
|
if (!promises.size) {
|
|
return;
|
|
}
|
|
const awaitable = Array.from(promises);
|
|
return Promise.all(awaitable);
|
|
}
|
|
function createRuntimeRpc(options) {
|
|
let setCancel = (_reason) => {
|
|
};
|
|
const onCancel = new Promise((resolve) => {
|
|
setCancel = resolve;
|
|
});
|
|
const rpc2 = createSafeRpc(
|
|
createBirpc(
|
|
{
|
|
onCancel: setCancel
|
|
},
|
|
{
|
|
eventNames: [
|
|
"onUserConsoleLog",
|
|
"onFinished",
|
|
"onCollected",
|
|
"onCancel"
|
|
],
|
|
onTimeoutError(functionName, args) {
|
|
let message = `[vitest-worker]: Timeout calling "${functionName}"`;
|
|
if (functionName === "fetch" || functionName === "transform" || functionName === "resolveId") {
|
|
message += ` with "${JSON.stringify(args)}"`;
|
|
}
|
|
if (functionName === "onUnhandledError") {
|
|
message += ` with "${args[0]?.message || args[0]}"`;
|
|
}
|
|
throw new Error(message);
|
|
},
|
|
...options
|
|
}
|
|
)
|
|
);
|
|
return {
|
|
rpc: rpc2,
|
|
onCancel
|
|
};
|
|
}
|
|
function createSafeRpc(rpc2) {
|
|
return new Proxy(rpc2, {
|
|
get(target, p, handler) {
|
|
const sendCall = get(target, p, handler);
|
|
const safeSendCall = (...args) => withSafeTimers(async () => {
|
|
const result = sendCall(...args);
|
|
promises.add(result);
|
|
try {
|
|
return await result;
|
|
} finally {
|
|
promises.delete(result);
|
|
}
|
|
});
|
|
safeSendCall.asEvent = sendCall.asEvent;
|
|
return safeSendCall;
|
|
}
|
|
});
|
|
}
|
|
function rpc() {
|
|
const { rpc: rpc2 } = getWorkerState();
|
|
return rpc2;
|
|
}
|
|
|
|
export { rpcDone as a, createRuntimeRpc as c, rpc as r };
|