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>
71 lines
2.7 KiB
JavaScript
71 lines
2.7 KiB
JavaScript
/*
|
|
Copyright (C) 2014 Yusuke Suzuki <utatane.tea@gmail.com>
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
notice, this list of conditions and the following disclaimer.
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
notice, this list of conditions and the following disclaimer in the
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS'
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
|
|
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
var gulp = require('gulp'),
|
|
git = require('gulp-git'),
|
|
bump = require('gulp-bump'),
|
|
filter = require('gulp-filter'),
|
|
tagVersion = require('gulp-tag-version');
|
|
|
|
var TEST = [ 'test/*.js' ];
|
|
var POWERED = [ 'powered-test/*.js' ];
|
|
var SOURCE = [ 'src/**/*.js' ];
|
|
|
|
/**
|
|
* Bumping version number and tagging the repository with it.
|
|
* Please read http://semver.org/
|
|
*
|
|
* You can use the commands
|
|
*
|
|
* gulp patch # makes v0.1.0 -> v0.1.1
|
|
* gulp feature # makes v0.1.1 -> v0.2.0
|
|
* gulp release # makes v0.2.1 -> v1.0.0
|
|
*
|
|
* To bump the version numbers accordingly after you did a patch,
|
|
* introduced a feature or made a backwards-incompatible release.
|
|
*/
|
|
|
|
function inc(importance) {
|
|
// get all the files to bump version in
|
|
return gulp.src(['./package.json'])
|
|
// bump the version number in those files
|
|
.pipe(bump({type: importance}))
|
|
// save it back to filesystem
|
|
.pipe(gulp.dest('./'))
|
|
// commit the changed version number
|
|
.pipe(git.commit('Bumps package version'))
|
|
// read only one file to get the version number
|
|
.pipe(filter('package.json'))
|
|
// **tag it in the repository**
|
|
.pipe(tagVersion({
|
|
prefix: ''
|
|
}));
|
|
}
|
|
|
|
gulp.task('patch', [ ], function () { return inc('patch'); })
|
|
gulp.task('minor', [ ], function () { return inc('minor'); })
|
|
gulp.task('major', [ ], function () { return inc('major'); })
|