Mark SPEC-003..009 as work-items inside the SPEC-002 v2 phases (not standalone v1 backlog): banner records the v2-reset decision + the Sprint-0 relay-auth CRITICAL hotfix, a phase-mapping table (004->P1, 008->P0/1, 003/005/006/007->P2, 009->P3), inline [-> v2 Phase N] tags per spec, and a note to bake SPEC-003 inventory cols + SPEC-004 machine_uid + connect_agent_keys into the Phase-0 fresh schema. Sprint planning 2026-05-30 (Mike: v2 reset first). Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
8.8 KiB
GuruConnect — Feature Roadmap
Living roadmap for the GuruConnect product. Status markers:
[ ]planned ·[~]in consideration ·[x]shipped. Priorities: P1 (blocking/MVP) · P2 (important) · P3 (nice-to-have). Specs live indocs/specs/SPEC-NNN-<slug>.md. Decisions indocs/ARCHITECTURE_DECISIONS.md.
GuruConnect is a standalone remote-support product (ScreenConnect/Splashtop-class) on our own Rust
stack. It ships independently of GuruRMM and integrates with it via a versioned contract (see
specs/native-remote-control/ and ADR-001).
Active direction (2026-05-30): v2 reset. Per SPEC-002, GuruConnect is being rebuilt above the salvaged Windows-internals cores. The feature specs below (SPEC-003–009) are work-items inside the v2 phases, not independent v1 backlog — see the mapping. Sprint 0 (do first): surgical v1 hotfix closing the 3 relay-auth CRITICALs (delete the JWT-as-agent-key branch; enforce blacklist + session-claim checks on the viewer WS) — the bypasses are live and the full v2 rebuild is multi-month.
v2 phase mapping of current specs
| Spec | v2 Phase | Note |
|---|---|---|
| SPEC-004 (identity / per-agent keys / session reaping / removal) | Phase 1 — secure session core | per-agent keys + session lifecycle are Phase 1's heart |
| SPEC-008 (structured errors + correlation IDs) | Phase 0/1 conventions | adopted as the cross-cutting error standard |
| SPEC-003 (machine inventory) | Phase 2 — dashboard/data | bake columns into the Phase-0 fresh schema |
| SPEC-005 (list view) · SPEC-006 (search) · SPEC-007 (installer) | Phase 2 — dashboard | built on the v2 dashboard + Phase-1 keys |
| SPEC-009 (documented API + tokens) | Phase 3 — integration contract | alongside /api/integration/v1/ |
Schema note: SPEC-002 Phase 0's "fresh v2 schema" should already carry SPEC-003's inventory columns, SPEC-004's
machine_uid, andconnect_agent_keys— born into v2, not retrofitted as later migrations.
Operational Tooling & Release Engineering
Bringing GC to parity with GuruRMM's release engineering. Full plan: SPEC-001.
- Code signing — Azure Trusted Signing in CI — P1 — sign the Windows agent
.exeviajsign(TRUSTEDSIGNING) in Gitea Actions, reusing the shared ACG cert profile. (SPEC-001 §2) - Automatic versioning — P1 — conventional-commit-driven version bump across agent/server/dashboard, embedded via
build.rs. (SPEC-001 §3) - Changelog generation & API — P2 —
CHANGELOG.md+ per-version changelogs from conventional commits, served at/api/changelog/.... (SPEC-001 §4) - Feature-request workflow — P2 —
/gc-feature-requestskill producingdocs/specs/SPEC-NNN-*.mdand updating this roadmap. (SPEC-001 §1) - Roadmap / ADR / spec tracking — P1 — this file +
ARCHITECTURE_DECISIONS.md+docs/specs/. (SPEC-001 §5) — bootstrapped - Coord-API registration — P3 — register
guruconnectproject_key + components (server,agent,dashboard) in the coordination API. (SPEC-001 §6) - [~] Release distribution / update channels — P3 — beta→stable rollout with health metrics (mirrors RMM
updates.rs). Deferred — larger subsystem, post-parity.
Core Remote Control
- Screen capture (DXGI primary, GDI fallback)
- Input injection (mouse/keyboard)
- Native viewer +
guruconnect://protocol handler - Support-code (attended) and persistent (unattended) agent modes
- Protobuf-over-WSS transport, Zstd frame compression
- [~] React/TS web viewer (
dashboard/src/components/RemoteViewer.tsx) — embeddable session viewer - Multi-monitor switching — P2
- File transfer — P3 (out of scope for native-remote-control v1)
- Session recording — P3 (out of scope for native-remote-control v1)
GuruRMM Integration
- Native remote control via broker — P2 — versioned integration contract so GuruRMM can launch/embed GC sessions on managed endpoints. Full spec:
specs/native-remote-control/. (Contract owned by GC; RMM consumes it.) /api/integration/v1/namespace + capability discovery — P2 (part of native-remote-control)- Per-machine agent keys (replace shared
AGENT_API_KEY) — P2 - Embedded-viewer framing allowlist (scoped
frame-ancestors) — P2
Server / API
- JWT auth, Argon2id passwords, rate limiting, security headers
- Sessions / machines / support-codes / events
- Full machine inventory in the connection DB — P2 — persist per-machine device inventory (OS+locale+install, CPU/RAM, mfr/model/serial, external WAN IP captured server-side + private LAN IP + MAC, logged-on user, idle, time zone, uptime, local-admin) on
connect_machines, refreshed eachAgentStatus, shown in the dashboard machine detail (ScreenConnect "Guest Info" parity). Data layer for SPEC-002 Phase 2; closes GC side of agent-IP gap (todo 7459428e). [→ v2 Phase 2] (SPEC-003) - Stable machine identity + session lifecycle reaping + operator removal — P1 — give the agent a deterministic machine-derived
machine_uid(WindowsMachineGuid-based) so the same box can't register duplicates (root cause:agent_idis a config-file random UUID that a portable/misconfigured run regenerates each launch); key registration on it; add TTL reaping + same-machine supersede as defense-in-depth; and admin-gated per-row + multi-select bulk removal of stale sessions/units. Identity must be bound to the per-machine agent key (spoof guard). Fixes ghost-session accumulation seen on the live console (15 sessions / 0 live, ~10 orphans for one machine). [→ v2 Phase 1] (SPEC-004) - Machines list view — dual connection indicators + rich rows — P2 — ScreenConnect "Access"-list parity: per-row Host/Guest two-segment connection bar (Guest=agent online, Host=viewer connected, with names + durations) and rich inline metadata (company, site, device type, tags, logged-on user + idle, client version in red when outdated). Server-enriches
/api/machineswith live session state + SPEC-003 inventory. [→ v2 Phase 2] (SPEC-005) - Machines "by Company" tree nav with per-company counts — P3 — left-nav grouping sidebar (screenshot parity). Follow-up sub-item of SPEC-005.
- Universal machine search ("everything is searchable") — P2 — server-side
?q=on/api/machinesmatching case-insensitive substring across ALL attributes (OS, logged-on user, external/private IP, company, site, tag, serial, MAC, version, …), pg_trgm GIN-indexed; multi-term AND + optional field-scoped syntax (os:,user:,ip:). Replaces the hostname-only client filter. Depends on SPEC-003 (attrs must be persisted). [→ v2 Phase 2] (SPEC-006) - Managed-agent installer builder ("Build Installer") — P2 — dashboard wizard to build a pre-labeled persistent-agent installer (Name/Company/Site/Department/Device Type/Tag/Type) with Download / Copy URL / Send Link, reusing the existing embed-config download path; adds department + device_type to EmbeddedConfig/AgentStatus so labels persist at install time. Pairs with revocable per-machine keys; signature-vs-appended-config is the key open question. [→ v2 Phase 2] (SPEC-007)
- Valuable error messages (structured errors + no silent swallows) — P2 — one structured API error envelope with stable codes + a correlation id that also lands in the logs; contextual tracing on server/agent; sweep the 37
let _ =swallows (the pattern that hid the migration-005 bug); dashboard surfaces the real cause + id instead of a generic line. [→ v2 Phase 0/1 conventions] (SPEC-008) - Feature-rich, fully-documented management API — P2 — everything the console can do, callable by API: OpenAPI 3.x generated from code (utoipa) + browsable docs at
/api/docs, long-lived revocable scoped API tokens (PAT-style, distinct from the 24h JWT + agent keys), an API-completeness gap audit, and consistent pagination/error conventions. Distinct from the ADR-001 RMM integration contract. [→ v2 Phase 3] (SPEC-009) - Programmatic session pre-create + viewer-token (integration contract) — P2
Security & Infrastructure
- Phase-1 security hardening (SEC-1..5), systemd units, backups
- CI security audit gate (
cargo audit) wired to release — P2
Future Considerations
- macOS / Linux remote-control agents — P3
- Auto-update for the agent — P3