Files
claudetools/wiki/systems/gururmm-build.md
Mike Swanson 7daca57593 wiki: seed all 4 ACG infrastructure system articles
gururmm-build (172.16.3.30), jupiter (172.16.3.20), pluto (172.16.3.36),
uranus (172.16.3.21) — verified IPs/hostnames against credentials.md,
pluto.md, and infra_office_network.md. wiki/index.md Systems table updated
to reflect seeded state; gururmm-build/jupiter/pluto/uranus removed from
compilation queue.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-24 15:49:31 -07:00

149 lines
6.7 KiB
Markdown

---
type: system
name: gururmm-build
display_name: GuruRMM VM (gururmm-build)
last_compiled: 2026-05-24
compiled_by: DESKTOP-0O8A1RL/claude-main
sources:
- credentials.md
- .claude/memory/infra_office_network.md
- .claude/machines/pluto.md
- wiki/projects/gururmm.md
backlinks:
- projects/gururmm
- systems/jupiter
- systems/pluto
---
# GuruRMM VM (gururmm-build)
## Identity
- **Hostname:** gururmm / gururmm-build
- **IP:** 172.16.3.30
- **Role:** Production server — GuruRMM API, ClaudeTools API, Coord API, MariaDB, PostgreSQL, build pipeline
- **Location:** Linux VM on Jupiter (172.16.3.20), virsh domain "GuruRMM"
- **OS:** Ubuntu 22.04 LTS
- **History:** Originally ran as a Docker container on Jupiter; migrated to its own VM at 172.16.3.30
## Specs
Linux VM — resource allocation managed via virsh on Jupiter (172.16.3.20). Exact vCPU/vRAM allocation not documented.
## Services
| Service | Port | Notes |
|---|---|---|
| GuruRMM API | 3001 | Rust/Axum; systemd `gururmm-server`; binary `/usr/local/bin/gururmm-server` |
| ClaudeTools API | 8001 | FastAPI/Python; includes Coord API at `/api/coord` |
| Nginx | 80/443 | Reverse proxy + static file serving |
| MariaDB | 3306 | Database `claudetools`; version 10.6.22 |
| PostgreSQL | 5432 | Database `gururmm`; version 14 |
| Build webhook | 9000 | `webhook-handler.py`; systemd `gururmm-webhook`; receives Gitea push events |
| Gitea (forwarded) | 3000 | SSH port forward from here → Gitea Docker container on Jupiter (.20:3000) |
## Access
- **SSH:** `ssh guru@172.16.3.30` (ed25519 keys: guru@wsl, guru@gururmm-build)
- **Sudo password:** vault `infrastructure/gururmm-server.sops.yaml` (same as SSH)
- **1Password:** `op://Infrastructure/GuruRMM Server/password`
- **Vault path:** `infrastructure/gururmm-server.sops.yaml`
## Key Paths
### GuruRMM
| Path | Purpose |
|---|---|
| `/usr/local/bin/gururmm-server` | Server binary |
| `/usr/local/bin/gururmm-agent` | Local agent binary |
| `/home/guru/gururmm/` | Gitea repo clone |
| `/var/www/gururmm/dashboard/` | Built React dashboard (served by nginx) |
| `/var/www/gururmm/downloads/` | Agent artifact distribution directory |
| `/var/www/gururmm/downloads/windows/amd64/` | Windows x64 MSI + EXE |
| `/var/www/gururmm/downloads/windows/x86/` | Windows x86 EXE |
| `/opt/gururmm/` | Build pipeline scripts and state |
| `/opt/gururmm/webhook-handler.py` | Gitea webhook receiver (port 9000) |
| `/opt/gururmm/build-shared.sh` | Version bump + git sync (runs once per trigger) |
| `/opt/gururmm/build-linux.sh` | Linux cargo build |
| `/opt/gururmm/build-windows.sh` | SSH to Pluto + artifact copy |
| `/opt/gururmm/build-mac.sh` | Stub (no Mac build machine) |
| `/opt/gururmm/build-server.sh` | Server binary rebuild (separate, manual trigger) |
| `/opt/gururmm/.env` | DB URL + secrets (GuruRMM build context) |
| `/opt/gururmm/pluto_known_hosts` | Pinned SSH keys for Pluto (172.16.3.36) |
| `/opt/gururmm/last-built-commit-linux` | SHA tracking for Linux build gate |
| `/opt/gururmm/last-built-commit-windows` | SHA tracking for Windows build gate |
| `/opt/gururmm/last-built-commit-mac` | SHA tracking for Mac build gate (stub) |
| `/var/log/gururmm-build-linux.log` | Linux build log |
| `/var/log/gururmm-build-windows.log` | Windows build log (includes [PLUTO] prefixed SSH output) |
**[WARNING] Do NOT use `/opt/gururmm/updates/` for freshness checks** — legacy path from before the pipeline split (~Feb 2026). Active distribution is `/var/www/gururmm/downloads/`.
### ClaudeTools
| Path | Purpose |
|---|---|
| `/home/guru/claudetools/` | ClaudeTools repo clone (if present) |
| ClaudeTools API port 8001 | Docs at http://172.16.3.30:8001/api/docs |
## Databases
### MariaDB (claudetools)
- **DB:** claudetools
- **User:** `op://Infrastructure/GuruRMM Server/Databases.MariaDB User`
- **Password:** `op://Infrastructure/GuruRMM Server/Databases.MariaDB Password`
- **Vault:** `bash D:/vault/scripts/vault.sh get-field projects/claudetools/database.sops.yaml credentials.password`
### PostgreSQL (gururmm)
- **DB:** gururmm
- **User:** `op://Infrastructure/GuruRMM Server/Databases.PostgreSQL User`
- **Password:** `op://Infrastructure/GuruRMM Server/Databases.PostgreSQL Password`
- **Connection string:** `postgres://gururmm:43617ebf7eb242e814ca9988cc4df5ad@localhost:5432/gururmm`
- **DB URL also in:** `/opt/gururmm/.env` and `/home/guru/.cargo/env`
## systemd Services
| Unit | Binary | Purpose |
|---|---|---|
| `gururmm-server` | `/usr/local/bin/gururmm-server` | GuruRMM Rust/Axum API |
| `gururmm-agent` | `/usr/local/bin/gururmm-agent` | Local GuruRMM agent (enrolled as ACG internal) |
| `gururmm-webhook` | `/opt/gururmm/webhook-handler.py` | Build pipeline webhook receiver |
## Build Pipeline Role
This machine is the **build orchestrator** for GuruRMM. It receives Gitea webhooks, runs the Linux build directly, and SSHes to Pluto for Windows builds.
```
Gitea push to main → webhook-handler.py (port 9000)
→ build-shared.sh (version bump, one-shot)
→ build-linux.sh (cargo build on this machine)
→ build-windows.sh (SSH → Pluto at 172.16.3.36)
→ build-mac.sh (stub)
→ artifacts → /var/www/gururmm/downloads/
→ systemctl restart gururmm-agent
```
Server and dashboard are NOT rebuilt by the agent pipeline — separate manual steps:
```bash
sudo /opt/gururmm/build-server.sh # Rebuild server binary
cd /home/guru/gururmm/dashboard && sudo -u guru npm run build
sudo rsync -av --delete /home/guru/gururmm/dashboard/dist/ /var/www/gururmm/dashboard/
```
SSH to Pluto from this machine:
```bash
ssh -o StrictHostKeyChecking=yes \
-o UserKnownHostsFile=/opt/gururmm/pluto_known_hosts \
Administrator@172.16.3.36
```
## Known Issues & Quirks
- **DATABASE_URL required at build time** — sqlx compile-time macros need it. Located in `/home/guru/.cargo/env`. Builds fail silently if not sourced.
- **Pre-commit hook lacks execute bit** (noted 2026-05-23) — likely still unfixed.
- **`sudo -u guru git` required in systemd build context** — git rejects the repo as dubious ownership when running as root against guru-owned `/home/guru/gururmm`. Use `git config --system --add safe.directory /home/guru/gururmm` or always prefix with `sudo -u guru`.
- **NPM proxy stale entry** — credentials.md and Jupiter NPM still proxy `rmm-api.azcomputerguru.com → 172.16.3.20:3001`. Should be `172.16.3.30:3001`. Fix in NPM admin at http://172.16.3.20:7818.
- **Gitea at :3000** — accessible via SSH port forward from this machine; authoritative Gitea container is on Jupiter (.20). Internal direct URL: http://172.16.3.20:3000.
## Backlinks
- [[projects/gururmm]] — GuruRMM API, build pipeline, ClaudeTools API all run here
- [[systems/jupiter]] — this machine is a virsh VM hosted on Jupiter
- [[systems/pluto]] — Windows builds SSH from here to Pluto