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>
105 lines
2.5 KiB
Markdown
105 lines
2.5 KiB
Markdown
# why-is-node-running
|
|
|
|
Node is running but you don't know why? `why-is-node-running` is here to help you.
|
|
|
|
## Installation
|
|
|
|
Node 8 and above:
|
|
|
|
```bash
|
|
npm i why-is-node-running -g
|
|
```
|
|
|
|
Earlier Node versions (no longer supported):
|
|
|
|
```bash
|
|
npm i why-is-node-running@v1.x -g
|
|
```
|
|
|
|
## Usage
|
|
|
|
```js
|
|
const log = require('why-is-node-running') // should be your first require
|
|
const net = require('net')
|
|
|
|
function createServer () {
|
|
const server = net.createServer()
|
|
setInterval(function () {}, 1000)
|
|
server.listen(0)
|
|
}
|
|
|
|
createServer()
|
|
createServer()
|
|
|
|
setTimeout(function () {
|
|
log() // logs out active handles that are keeping node running
|
|
}, 100)
|
|
```
|
|
|
|
Save the file as `example.js`, then execute:
|
|
|
|
```bash
|
|
node ./example.js
|
|
```
|
|
|
|
Here's the output:
|
|
|
|
```
|
|
There are 5 handle(s) keeping the process running
|
|
|
|
# Timeout
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:6 - setInterval(function () {}, 1000)
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:10 - createServer()
|
|
|
|
# TCPSERVERWRAP
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:7 - server.listen(0)
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:10 - createServer()
|
|
|
|
# Timeout
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:6 - setInterval(function () {}, 1000)
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:11 - createServer()
|
|
|
|
# TCPSERVERWRAP
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:7 - server.listen(0)
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:11 - createServer()
|
|
|
|
# Timeout
|
|
/home/maf/dev/node_modules/why-is-node-running/example.js:13 - setTimeout(function () {
|
|
```
|
|
|
|
**Important Note!**
|
|
`unref`ed timers do not prevent the Node process from exiting. If you are running with Node v11.0.0 and above, `unref`ed timers will not be listed in the above list. Unfortunately, this is not supported in node versions below v11.0.0.
|
|
|
|
## CLI
|
|
|
|
You can also run `why-is-node-running` as a standalone if you don't want to include it inside your code. Sending `SIGUSR1`/`SIGINFO` signal to the process will produce the log. (`Ctrl + T` on macOS and BSD systems)
|
|
|
|
```bash
|
|
why-is-node-running /path/to/some/file.js
|
|
```
|
|
|
|
```
|
|
probing module /path/to/some/file.js
|
|
kill -SIGUSR1 31115 for logging
|
|
```
|
|
|
|
To trigger the log:
|
|
|
|
```
|
|
kill -SIGUSR1 31115
|
|
```
|
|
|
|
## Require CLI Option
|
|
|
|
You can also use the node `-r` option to include `why-is-node-running`:
|
|
|
|
```bash
|
|
node -r why-is-node-running/include /path/to/some/file.js
|
|
```
|
|
|
|
The steps are otherwise the same as the above CLI section
|
|
|
|
## License
|
|
|
|
MIT
|