# 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-.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 - [ ] 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