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>
87 lines
3.0 KiB
JavaScript
87 lines
3.0 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = void 0;
|
|
var _genMapping = require("@jridgewell/gen-mapping");
|
|
var _traceMapping = require("@jridgewell/trace-mapping");
|
|
class SourceMap {
|
|
constructor(opts, code) {
|
|
var _opts$sourceFileName;
|
|
this._map = void 0;
|
|
this._rawMappings = void 0;
|
|
this._sourceFileName = void 0;
|
|
this._lastGenLine = 0;
|
|
this._lastSourceLine = 0;
|
|
this._lastSourceColumn = 0;
|
|
this._inputMap = null;
|
|
const map = this._map = new _genMapping.GenMapping({
|
|
sourceRoot: opts.sourceRoot
|
|
});
|
|
this._sourceFileName = (_opts$sourceFileName = opts.sourceFileName) == null ? void 0 : _opts$sourceFileName.replace(/\\/g, "/");
|
|
this._rawMappings = undefined;
|
|
if (opts.inputSourceMap) {
|
|
this._inputMap = new _traceMapping.TraceMap(opts.inputSourceMap);
|
|
const resolvedSources = this._inputMap.resolvedSources;
|
|
if (resolvedSources.length) {
|
|
for (let i = 0; i < resolvedSources.length; i++) {
|
|
var _this$_inputMap$sourc;
|
|
(0, _genMapping.setSourceContent)(map, resolvedSources[i], (_this$_inputMap$sourc = this._inputMap.sourcesContent) == null ? void 0 : _this$_inputMap$sourc[i]);
|
|
}
|
|
}
|
|
}
|
|
if (typeof code === "string" && !opts.inputSourceMap) {
|
|
(0, _genMapping.setSourceContent)(map, this._sourceFileName, code);
|
|
} else if (typeof code === "object") {
|
|
for (const sourceFileName of Object.keys(code)) {
|
|
(0, _genMapping.setSourceContent)(map, sourceFileName.replace(/\\/g, "/"), code[sourceFileName]);
|
|
}
|
|
}
|
|
}
|
|
get() {
|
|
return (0, _genMapping.toEncodedMap)(this._map);
|
|
}
|
|
getDecoded() {
|
|
return (0, _genMapping.toDecodedMap)(this._map);
|
|
}
|
|
getRawMappings() {
|
|
return this._rawMappings || (this._rawMappings = (0, _genMapping.allMappings)(this._map));
|
|
}
|
|
mark(generated, line, column, identifierName, identifierNamePos, filename) {
|
|
var _originalMapping;
|
|
this._rawMappings = undefined;
|
|
let originalMapping;
|
|
if (line != null) {
|
|
if (this._inputMap) {
|
|
originalMapping = (0, _traceMapping.originalPositionFor)(this._inputMap, {
|
|
line,
|
|
column: column
|
|
});
|
|
if (!originalMapping.name && identifierNamePos) {
|
|
const originalIdentifierMapping = (0, _traceMapping.originalPositionFor)(this._inputMap, identifierNamePos);
|
|
if (originalIdentifierMapping.name) {
|
|
identifierName = originalIdentifierMapping.name;
|
|
}
|
|
}
|
|
} else {
|
|
originalMapping = {
|
|
name: null,
|
|
source: (filename == null ? void 0 : filename.replace(/\\/g, "/")) || this._sourceFileName,
|
|
line: line,
|
|
column: column
|
|
};
|
|
}
|
|
}
|
|
(0, _genMapping.maybeAddMapping)(this._map, {
|
|
name: identifierName,
|
|
generated,
|
|
source: (_originalMapping = originalMapping) == null ? void 0 : _originalMapping.source,
|
|
original: originalMapping
|
|
});
|
|
}
|
|
}
|
|
exports.default = SourceMap;
|
|
|
|
//# sourceMappingURL=source-map.js.map
|