Persist a complete per-machine device inventory on connect_machines (OS+locale+install, CPU/RAM, mfr/model/serial, external WAN IP captured server-side via trusted-proxy client_ip + private LAN IP + MAC, logged-on user, idle, time zone, uptime, local-admin-present), refreshed each AgentStatus and surfaced in the dashboard machine detail — ScreenConnect "Guest Info" parity. Data layer for SPEC-002 Phase 2; closes the GC side of the agent-IP gap (coord todo 7459428e). Requested by Mike 2026-05-30. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
62 lines
3.9 KiB
Markdown
62 lines
3.9 KiB
Markdown
# 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 in `docs/specs/SPEC-NNN-<slug>.md`. Decisions in `docs/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).
|
|
|
|
---
|
|
|
|
## Operational Tooling & Release Engineering
|
|
|
|
Bringing GC to parity with GuruRMM's release engineering. Full plan: [SPEC-001](specs/SPEC-001-operational-tooling-parity.md).
|
|
|
|
- [ ] **Code signing — Azure Trusted Signing in CI** — P1 — sign the Windows agent `.exe` via `jsign` (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-request` skill producing `docs/specs/SPEC-NNN-*.md` and 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 `guruconnect` project_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
|
|
|
|
- [x] Screen capture (DXGI primary, GDI fallback)
|
|
- [x] Input injection (mouse/keyboard)
|
|
- [x] Native viewer + `guruconnect://` protocol handler
|
|
- [x] Support-code (attended) and persistent (unattended) agent modes
|
|
- [x] 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/`](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
|
|
|
|
- [x] JWT auth, Argon2id passwords, rate limiting, security headers
|
|
- [x] 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 each `AgentStatus`, 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). ([SPEC-003](specs/SPEC-003-machine-inventory.md))
|
|
- [ ] Programmatic session pre-create + viewer-token (integration contract) — P2
|
|
|
|
## Security & Infrastructure
|
|
|
|
- [x] 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
|