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>
89 lines
2.5 KiB
JavaScript
89 lines
2.5 KiB
JavaScript
var fs = require('fs');
|
|
var path = require('path');
|
|
var execSync = require('child_process').execSync;
|
|
var exec = function (cmd) {
|
|
execSync(cmd, {stdio: 'inherit'});
|
|
};
|
|
|
|
/* global jake, task, desc, publishTask */
|
|
|
|
task('build', ['lint', 'clean', 'browserify', 'minify'], function () {
|
|
console.log('Build completed.');
|
|
});
|
|
|
|
desc('Cleans browerified/minified files and package files');
|
|
task('clean', ['clobber'], function () {
|
|
jake.rmRf('./ejs.js');
|
|
jake.rmRf('./ejs.min.js');
|
|
console.log('Cleaned up compiled files.');
|
|
});
|
|
|
|
desc('Lints the source code');
|
|
task('lint', ['clean'], function () {
|
|
var epath = path.join('./node_modules/.bin/eslint');
|
|
exec(epath+' "**/*.js"');
|
|
console.log('Linting completed.');
|
|
});
|
|
|
|
task('browserify', function () {
|
|
var epath = path.join('./node_modules/browserify/bin/cmd.js');
|
|
exec(epath+' --standalone ejs lib/ejs.js > ejs.js');
|
|
console.log('Browserification completed.');
|
|
});
|
|
|
|
task('minify', function () {
|
|
var epath = path.join('./node_modules/uglify-js/bin/uglifyjs');
|
|
exec(epath+' ejs.js > ejs.min.js');
|
|
console.log('Minification completed.');
|
|
});
|
|
|
|
desc('Generates the EJS API docs for the public API');
|
|
task('doc', function () {
|
|
jake.rmRf('out');
|
|
var epath = path.join('./node_modules/.bin/jsdoc');
|
|
exec(epath+' --verbose -c jsdoc.json lib/* docs/jsdoc/*');
|
|
console.log('Documentation generated in ./out.');
|
|
});
|
|
|
|
desc('Generates the EJS API docs for the public and private API');
|
|
task('devdoc', function () {
|
|
jake.rmRf('out');
|
|
var epath = path.join('./node_modules/.bin/jsdoc');
|
|
exec(epath+' --verbose -p -c jsdoc.json lib/* docs/jsdoc/*');
|
|
console.log('Documentation generated in ./out.');
|
|
});
|
|
|
|
desc('Publishes the EJS API docs');
|
|
task('docPublish', ['doc'], function () {
|
|
fs.writeFileSync('out/CNAME', 'api.ejs.co');
|
|
console.log('Pushing docs to gh-pages...');
|
|
var epath = path.join('./node_modules/.bin/git-directory-deploy');
|
|
exec(epath+' --directory out/');
|
|
console.log('Docs published to gh-pages.');
|
|
});
|
|
|
|
desc('Runs the EJS test suite');
|
|
task('test', ['lint'], function () {
|
|
exec(path.join('./node_modules/.bin/mocha --u tdd'));
|
|
});
|
|
|
|
publishTask('ejs', ['build'], function () {
|
|
this.packageFiles.include([
|
|
'jakefile.js',
|
|
'README.md',
|
|
'LICENSE',
|
|
'package.json',
|
|
'ejs.js',
|
|
'ejs.min.js',
|
|
'lib/**',
|
|
'bin/**',
|
|
'usage.txt'
|
|
]);
|
|
});
|
|
|
|
jake.Task.publish.on('complete', function () {
|
|
console.log('Updating hosted docs...');
|
|
console.log('If this fails, run jake docPublish to re-try.');
|
|
jake.Task.docPublish.invoke();
|
|
});
|