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>
128 lines
3.5 KiB
JavaScript
128 lines
3.5 KiB
JavaScript
/**
|
|
* @author Toru Nagashima <https://github.com/mysticatea>
|
|
* See LICENSE file in root directory for full license.
|
|
*/
|
|
'use strict';
|
|
|
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
|
var eventTargetShim = require('event-target-shim');
|
|
|
|
/**
|
|
* The signal class.
|
|
* @see https://dom.spec.whatwg.org/#abortsignal
|
|
*/
|
|
class AbortSignal extends eventTargetShim.EventTarget {
|
|
/**
|
|
* AbortSignal cannot be constructed directly.
|
|
*/
|
|
constructor() {
|
|
super();
|
|
throw new TypeError("AbortSignal cannot be constructed directly");
|
|
}
|
|
/**
|
|
* Returns `true` if this `AbortSignal`'s `AbortController` has signaled to abort, and `false` otherwise.
|
|
*/
|
|
get aborted() {
|
|
const aborted = abortedFlags.get(this);
|
|
if (typeof aborted !== "boolean") {
|
|
throw new TypeError(`Expected 'this' to be an 'AbortSignal' object, but got ${this === null ? "null" : typeof this}`);
|
|
}
|
|
return aborted;
|
|
}
|
|
}
|
|
eventTargetShim.defineEventAttribute(AbortSignal.prototype, "abort");
|
|
/**
|
|
* Create an AbortSignal object.
|
|
*/
|
|
function createAbortSignal() {
|
|
const signal = Object.create(AbortSignal.prototype);
|
|
eventTargetShim.EventTarget.call(signal);
|
|
abortedFlags.set(signal, false);
|
|
return signal;
|
|
}
|
|
/**
|
|
* Abort a given signal.
|
|
*/
|
|
function abortSignal(signal) {
|
|
if (abortedFlags.get(signal) !== false) {
|
|
return;
|
|
}
|
|
abortedFlags.set(signal, true);
|
|
signal.dispatchEvent({ type: "abort" });
|
|
}
|
|
/**
|
|
* Aborted flag for each instances.
|
|
*/
|
|
const abortedFlags = new WeakMap();
|
|
// Properties should be enumerable.
|
|
Object.defineProperties(AbortSignal.prototype, {
|
|
aborted: { enumerable: true },
|
|
});
|
|
// `toString()` should return `"[object AbortSignal]"`
|
|
if (typeof Symbol === "function" && typeof Symbol.toStringTag === "symbol") {
|
|
Object.defineProperty(AbortSignal.prototype, Symbol.toStringTag, {
|
|
configurable: true,
|
|
value: "AbortSignal",
|
|
});
|
|
}
|
|
|
|
/**
|
|
* The AbortController.
|
|
* @see https://dom.spec.whatwg.org/#abortcontroller
|
|
*/
|
|
class AbortController {
|
|
/**
|
|
* Initialize this controller.
|
|
*/
|
|
constructor() {
|
|
signals.set(this, createAbortSignal());
|
|
}
|
|
/**
|
|
* Returns the `AbortSignal` object associated with this object.
|
|
*/
|
|
get signal() {
|
|
return getSignal(this);
|
|
}
|
|
/**
|
|
* Abort and signal to any observers that the associated activity is to be aborted.
|
|
*/
|
|
abort() {
|
|
abortSignal(getSignal(this));
|
|
}
|
|
}
|
|
/**
|
|
* Associated signals.
|
|
*/
|
|
const signals = new WeakMap();
|
|
/**
|
|
* Get the associated signal of a given controller.
|
|
*/
|
|
function getSignal(controller) {
|
|
const signal = signals.get(controller);
|
|
if (signal == null) {
|
|
throw new TypeError(`Expected 'this' to be an 'AbortController' object, but got ${controller === null ? "null" : typeof controller}`);
|
|
}
|
|
return signal;
|
|
}
|
|
// Properties should be enumerable.
|
|
Object.defineProperties(AbortController.prototype, {
|
|
signal: { enumerable: true },
|
|
abort: { enumerable: true },
|
|
});
|
|
if (typeof Symbol === "function" && typeof Symbol.toStringTag === "symbol") {
|
|
Object.defineProperty(AbortController.prototype, Symbol.toStringTag, {
|
|
configurable: true,
|
|
value: "AbortController",
|
|
});
|
|
}
|
|
|
|
exports.AbortController = AbortController;
|
|
exports.AbortSignal = AbortSignal;
|
|
exports.default = AbortController;
|
|
|
|
module.exports = AbortController
|
|
module.exports.AbortController = module.exports["default"] = AbortController
|
|
module.exports.AbortSignal = AbortSignal
|
|
//# sourceMappingURL=abort-controller.js.map
|