chore: backfill 12 recovered session logs (reviewed)
Reconstructed from local transcripts via the new recovery engine. These were substantive sessions never saved with /save. All banner-marked RECOVERED-UNVERIFIED. Notable recoveries: Peaceful Spirit RADIUS/VPN buildout (full command trail), RMM agent check-in comparison, Kristen Datto Workplace sync, Intune+Apple. guru-rmm/guru-connect-scoped logs routed to root session-logs (submodule convention). Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,419 @@
|
||||
# [RECOVERED] Review fix/audit-2-remediation branch status
|
||||
|
||||
> **[RECOVERED -- UNVERIFIED]** Auto-reconstructed from transcript f54e5508-523e-4cac-bed8-a239fdfb8f32 (2026-05-25T22:47:45.229Z .. 2026-05-26T12:54:39.436Z) on 2026-06-01. Prose sections are Ollama-drafted from the transcript and may be imprecise; the Commands/Config/Reference sections are extracted verbatim. Review and correct, then remove this banner.
|
||||
|
||||
## User
|
||||
- **User:** Mike Swanson (mike)
|
||||
- **Machine:** GURU-5070
|
||||
- **Role:** admin
|
||||
|
||||
## Session Summary
|
||||
|
||||
The session began with a sync operation to pull updates from GURU-BEAST-ROG, which revealed critical issues preventing Phase 6 testing. The team identified three hazards: an already applied migration causing a crash loop, dead crash detection code, and an insecure build script. A branch containing fixes for these issues was reviewed and merged into main. The merge included enhancements to crash detection, build rollback, and update channel functionality. Additionally, a feature branch was created to address remaining type annotations in the dashboard code. The session concluded with the successful merge of several bug fixes and updates to the session log, ensuring all changes were committed and synced.
|
||||
|
||||
## Key Decisions
|
||||
|
||||
- Merge `fix/audit-2-remediation` into main to address critical crash detection and build issues.
|
||||
- Commit in-progress changes in `Logs.tsx` to a new feature branch to preserve work while updating the submodule pointer.
|
||||
- Address remaining type annotations in dashboard components to resolve BUG-011.
|
||||
- Advance submodule pointer to the new main HEAD to reflect the merged changes.
|
||||
|
||||
## Problems Encountered
|
||||
|
||||
- Uncommitted changes in `Logs.tsx` required a decision on whether to commit, stash, or leave them.
|
||||
- The hardened `build-server.sh` in the branch diverged from the live script, necessitating a note on the merge impact.
|
||||
- The server returned plain text error bodies, preventing proper error handling in the UI.
|
||||
|
||||
## Configuration Changes
|
||||
|
||||
_Machine-extracted verbatim from the transcript (file targets of Write/Edit/NotebookEdit)._
|
||||
|
||||
- [modified] `/d/claudetools/projects/msp-tools/guru-rmm/dashboard/src/pages/Logs.tsx`
|
||||
- [modified] `/d/claudetools/projects/msp-tools/guru-rmm/server/src/api/metrics.rs`
|
||||
|
||||
## Credentials & Secrets
|
||||
|
||||
_Machine-extracted; review carefully -- secrets are not auto-harvested from transcripts._
|
||||
|
||||
- none detected (verify against the Commands & Outputs section)
|
||||
|
||||
## Infrastructure & Servers
|
||||
|
||||
_Machine-extracted verbatim (IP / hostname regex hits across the whole transcript)._
|
||||
|
||||
- **IPs:** `172.16.3.30`, `172.16.3.20`
|
||||
- **Hosts:** `verify-rollout-system.sh`, `sync.sh`, `json.load`, `sys.stdin`, `build-mac.sh`, `build-shared.sh`, `gururmm-build-mac.log`, `cargo.toml`, `2026-05-25-session.md`, `standards.md`, `health.rs`, `build-server.sh`, `2026-05-25-rmm-audit-2.md`, `63d1a29ce4982f83cc8c4c32bf7a75f3f52e76a66e.json`, `6bf72fa28174dd62dd6136b82afa5e33bc37023916.json`, `agents.rs`, `updates.rs`, `state.db`, `metrics.rs`, `logs.tsx`, `commandsapi.send`, `git.azcomputerguru.com`, `azcomputerguru.com`, `index.ts`, `gururmm.local`, `client.ts`, `toast.ts`, `utils.ts`, `import.meta.env`, `rmm-api.azcomputerguru.com`, `axios.create`, `api.post`, `api.get`, `api.delete`, `select.tsx`, `toast.tsx`, `toaster.tsx`, `updatechannelselector.tsx`, `usetoast.tsx`, `selectprimitive.root`
|
||||
|
||||
## Commands & Outputs
|
||||
|
||||
_Machine-extracted verbatim: mutating Bash/PowerShell commands with truncated output._
|
||||
|
||||
```
|
||||
curl -s "http://172.16.3.30:8001/api/coord/messages?to_session=GURU-5070/claude-main&unread_only=true" | python -c "import sys,json; msgs=json.load(sys.stdin); [print(m['id'], m['subject'][:60]) for m in msgs]" 2>&1
|
||||
```
|
||||
Output: Exit code 1
|
||||
Traceback (most recent call last):
|
||||
|
||||
File "<string>", line 1, in <module>
|
||||
|
||||
import sys,json; msgs=json.load(sys.stdin); [print(m['id'], m['subject'][:60]) for m in msgs]
|
||||
|
||||
~^^^^^^
|
||||
|
||||
TypeError: string indices must be integers, not ' ... [truncated]
|
||||
|
||||
```
|
||||
curl -s "http://172.16.3.30:8001/api/coord/messages?to_session=GURU-5070/claude-main&unread_only=true" 2>&1
|
||||
```
|
||||
Output: {"total":0,"skip":0,"limit":100,"messages":[]}
|
||||
|
||||
```
|
||||
curl -s "http://172.16.3.30:8001/api/coord/messages?unread_only=true" 2>&1
|
||||
```
|
||||
Output: {"total":15,"skip":0,"limit":100,"messages":[{"id":"9846eb32-2b2b-4ba0-a1b9-98b2c3cd68f1","from_session":"GURU-BEAST-ROG/claude-main","to_session":"GURU-KALI/claude-main","project_key":"gururmm","subject":"BUG-005 corrected: mac trigger NOT broken — builds are an unimplemented stub","body":"Followed ... [truncated]
|
||||
|
||||
```
|
||||
curl -s -X PUT "http://172.16.3.30:8001/api/coord/components/gururmm/server" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"state":"building","version":"post-audit-2-remediation","notes":"fix/audit-2-remediation merged to main (BUG-002/003/006). Webhook build firing. feature/log-finding-dispatch branched from submodule local changes.","updated_by":"GURU-5070/claude-main"}' 2>&1
|
||||
```
|
||||
Output: {"project_key":"gururmm","component":"server","state":"building","version":"post-audit-2-remediation","notes":"fix/audit-2-remediation merged to main (BUG-002/003/006). Webhook build firing. feature/log-finding-dispatch branched from submodule local changes.","updated_by":"GURU-5070/claude-main","cr ... [truncated]
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/index.ts 2>&1 | grep -n "commandsApi\|commands" | head -20
|
||||
```
|
||||
Output: (Bash completed with no output)
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/index.ts 2>&1 | head -60
|
||||
```
|
||||
Output: fatal: path 'dashboard/src/api/index.ts' does not exist in 'origin/main'
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/client.ts 2>&1 | grep -n "commandsApi\|commands\|export" | head -30
|
||||
```
|
||||
Output: 4:export const API_BASE_URL = import.meta.env.VITE_API_URL || "https://rmm-api.azcomputerguru.com";
|
||||
7:export const api = axios.create({
|
||||
36:export type UpdateChannel = "stable" | "beta" | null;
|
||||
38:export interface Agent {
|
||||
58:export interface Metrics {
|
||||
86:export interface SensorReading {
|
||||
98:export int ... [truncated]
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/client.ts 2>&1 | sed -n '294,330p'
|
||||
```
|
||||
Output: export const commandsApi = {
|
||||
send: (agentId: string, command: { command_type: string; command: string; context?: CommandContext }) =>
|
||||
api.post<Command>(`/api/agents/${agentId}/command`, command),
|
||||
list: () => api.get<Command[]>("/api/commands"),
|
||||
/**
|
||||
* List commands for a specific agent. ... [truncated]
|
||||
|
||||
```
|
||||
git ls-tree -r origin/main --name-only 2>&1 | grep -E "Select|Toast|useToast" && git show origin/main:dashboard/src/api/client.ts 2>&1 | grep "LogFinding" | head -5
|
||||
```
|
||||
Output: dashboard/src/components/Select.tsx
|
||||
dashboard/src/components/Toast.tsx
|
||||
dashboard/src/components/Toaster.tsx
|
||||
dashboard/src/components/UpdateChannelSelector.tsx
|
||||
dashboard/src/hooks/useToast.tsx
|
||||
export interface LogFinding {
|
||||
findings: LogFinding[];
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/client.ts 2>&1 | grep -A 8 "LogFinding"
|
||||
```
|
||||
Output: export interface LogFinding {
|
||||
severity: string;
|
||||
pattern: string;
|
||||
count: number;
|
||||
sample: string;
|
||||
affected_agents?: string[];
|
||||
suggested_action?: string;
|
||||
}
|
||||
|
||||
--
|
||||
findings: LogFinding[];
|
||||
summary: string | null;
|
||||
}
|
||||
|
||||
export interface AgentEvent {
|
||||
id: number;
|
||||
agent_id: string;
|
||||
event_ts: ... [truncated]
|
||||
|
||||
```
|
||||
curl -s -X PUT "http://172.16.3.30:8001/api/coord/components/gururmm/dashboard" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"state":"building","version":"post-log-dispatch","notes":"feature/log-finding-dispatch merged (PR #23) — collapsible FindingCards + agent command dispatch in log analysis. Webhook build firing.","updated_by":"GURU-5070/claude-main"}' 2>&1
|
||||
```
|
||||
Output: {"detail":"There was an error parsing the body"}
|
||||
|
||||
```
|
||||
curl -s -X PUT "http://172.16.3.30:8001/api/coord/components/gururmm/dashboard" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d "{\"state\":\"building\",\"version\":\"post-log-dispatch\",\"notes\":\"feature/log-finding-dispatch merged (PR #23) — collapsible FindingCards + agent command dispatch in log analysis. Webhook build firing.\",\"updated_by\":\"GURU-5070/claude-main\"}" 2>&1
|
||||
```
|
||||
Output: {"detail":"There was an error parsing the body"}
|
||||
|
||||
```
|
||||
curl -s -X PUT "http://172.16.3.30:8001/api/coord/components/gururmm/dashboard" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"state":"building","version":"post-log-dispatch","notes":"PR #23 merged log dispatch feature","updated_by":"GURU-5070/claude-main"}' 2>&1
|
||||
```
|
||||
Output: {"project_key":"gururmm","component":"dashboard","state":"building","version":"post-log-dispatch","notes":"PR #23 merged log dispatch feature","updated_by":"GURU-5070/claude-main","created_at":"2026-05-12T15:45:57","updated_at":"2026-05-26T00:50:29"}
|
||||
|
||||
```
|
||||
curl -s -X PUT "http://172.16.3.30:8001/api/coord/components/gururmm/server" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"state":"building","version":"post-bug-007","notes":"BUG-007 merged (PR #24) — zero sqlx macros remain in health.rs, 5 orphaned .sqlx files removed. Webhook build firing.","updated_by":"GURU-5070/claude-main"}' 2>&1
|
||||
```
|
||||
Output: {"detail":"There was an error parsing the body"}
|
||||
|
||||
```
|
||||
curl -s -X PUT "http://172.16.3.30:8001/api/coord/components/gururmm/server" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"state":"building","version":"post-bug-007","notes":"BUG-007 merged PR #24 - zero macros remain in health.rs","updated_by":"GURU-5070/claude-main"}' 2>&1
|
||||
```
|
||||
Output: {"project_key":"gururmm","component":"server","state":"building","version":"post-bug-007","notes":"BUG-007 merged PR #24 - zero macros remain in health.rs","updated_by":"GURU-5070/claude-main","created_at":"2026-05-12T15:45:57","updated_at":"2026-05-26T01:03:36"}
|
||||
|
||||
```
|
||||
git show origin/main:server/src/api/metrics.rs 2>&1
|
||||
```
|
||||
Output: //! Metrics API endpoints
|
||||
|
||||
use axum::{
|
||||
extract::{Path, Query, State},
|
||||
http::StatusCode,
|
||||
Json,
|
||||
};
|
||||
use chrono::{DateTime, Duration, Utc};
|
||||
use serde::Deserialize;
|
||||
use uuid::Uuid;
|
||||
|
||||
use crate::auth::AuthUser;
|
||||
use crate::db::{self, Metrics, MetricsSummary};
|
||||
use crate::AppState;
|
||||
|
||||
/// Query para ... [truncated]
|
||||
|
||||
```
|
||||
git show origin/main:server/src/api/mod.rs 2>&1 | grep -n "internal_err\|fn internal" | head -10
|
||||
```
|
||||
Output: 55:pub fn internal_err(e: impl std::fmt::Display) -> (StatusCode, String) {
|
||||
|
||||
```
|
||||
git show origin/main:server/src/api/mod.rs 2>&1 | sed -n '50,65p'
|
||||
```
|
||||
Output: use crate::AppState;
|
||||
|
||||
/// Shared error helper: logs the underlying error and returns a generic
|
||||
/// 500 response so internal details are not leaked to the client.
|
||||
pub fn internal_err(e: impl std::fmt::Display) -> (StatusCode, String) {
|
||||
tracing::error!("Internal error: {}", e);
|
||||
(StatusCode::IN ... [truncated]
|
||||
|
||||
```
|
||||
git show origin/main:server/src/api/logs.rs 2>&1 | grep -n "internal_err\|use super\|use crate::api" | head -10
|
||||
```
|
||||
Output: (Bash completed with no output)
|
||||
|
||||
```
|
||||
git show origin/main:server/src/api/logs.rs 2>&1 | head -20
|
||||
```
|
||||
Output: use axum::{
|
||||
extract::{Path, Query, State},
|
||||
http::StatusCode,
|
||||
response::{IntoResponse, Json},
|
||||
};
|
||||
use chrono::{DateTime, Duration, Utc};
|
||||
use serde::{Deserialize, Serialize};
|
||||
use uuid::Uuid;
|
||||
|
||||
use crate::auth::AuthUser;
|
||||
use crate::db;
|
||||
use crate::db::logs::{AnalysisRun, LogRecord};
|
||||
use crate: ... [truncated]
|
||||
|
||||
```
|
||||
git show origin/main:server/src/api/logs.rs 2>&1 | grep -n "internal_err" | head -10
|
||||
```
|
||||
Output: (Bash completed with no output)
|
||||
|
||||
```
|
||||
git show origin/main:server/src/api/agents.rs 2>&1 | grep -n "internal_err\|use super\|use crate::api" | head -10
|
||||
```
|
||||
Output: 18:use crate::api::internal_err;
|
||||
61: .map_err(internal_err)?;
|
||||
81: .map_err(internal_err)?,
|
||||
88: .map_err(internal_err)?
|
||||
103: .map_err(internal_err)?
|
||||
112: .map_err(internal_err)?;
|
||||
145: .map_err(internal_err)?;
|
||||
161: .map_err(internal_ ... [truncated]
|
||||
|
||||
```
|
||||
grep -n "StatusCode" /d/claudetools/projects/msp-tools/guru-rmm/server/src/api/metrics.rs
|
||||
```
|
||||
Output: 5: http::StatusCode,
|
||||
36:) -> Result<Json<Vec<Metrics>>, (StatusCode, String)> {
|
||||
41: .ok_or((StatusCode::NOT_FOUND, "Agent not found".to_string()))?;
|
||||
51: return Err((StatusCode::FORBIDDEN, "Access denied".to_string()));
|
||||
56: return Err((StatusCode::FORBIDDEN, "A ... [truncated]
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/client.ts 2>&1 | grep -n "AgentInventory\|DiskInfo\|NetworkInterface\|SoftwareEntry\|ServiceEntry\|Inventory\|inventory" | head -20
|
||||
```
|
||||
Output: 106:export interface NetworkInterface {
|
||||
115: network_interfaces?: NetworkInterface[];
|
||||
418: user_inventory?: {
|
||||
1072:export interface HardwareNetworkInterface {
|
||||
1087:export interface ServiceEntry {
|
||||
1106: network_interfaces: HardwareNetworkInterface[];
|
||||
1108: services: ServiceEntry[];
|
||||
1127:export in ... [truncated]
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/client.ts 2>&1 | sed -n '1072,1140p'
|
||||
```
|
||||
Output: export interface HardwareNetworkInterface {
|
||||
name: string;
|
||||
ip?: string;
|
||||
mac?: string;
|
||||
ip_addresses?: string[];
|
||||
is_up?: boolean;
|
||||
}
|
||||
|
||||
export interface InstalledSoftware {
|
||||
name: string;
|
||||
version?: string;
|
||||
publisher?: string;
|
||||
install_date?: string;
|
||||
}
|
||||
|
||||
export interface ServiceEntry {
|
||||
nam ... [truncated]
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/client.ts 2>&1 | grep -n "DiskEntry" | head -5
|
||||
```
|
||||
Output: 1061:export interface DiskEntry {
|
||||
1105: disks: DiskEntry[];
|
||||
|
||||
```
|
||||
git show origin/main:dashboard/src/api/client.ts 2>&1 | sed -n '1061,1072p'
|
||||
```
|
||||
Output: export interface DiskEntry {
|
||||
name?: string;
|
||||
mount?: string;
|
||||
total_gb?: number;
|
||||
fs_type?: string;
|
||||
model?: string;
|
||||
serial?: string;
|
||||
size_bytes?: number;
|
||||
disk_type?: string;
|
||||
}
|
||||
|
||||
export interface HardwareNetworkInterface {
|
||||
|
||||
```
|
||||
cat >> /d/claudetools/session-logs/2026-05-25-session.md << 'SESSIONEOF'
|
||||
|
||||
---
|
||||
|
||||
## Update: 20:24 PT — GuruRMM Audit-2 Remediation + Bug Fix Sprint (GURU-5070)
|
||||
|
||||
## User
|
||||
- **User:** Mike Swanson (mike)
|
||||
- **Machine:** GURU-5070
|
||||
- **Role:** admin
|
||||
- **Session:** ~15:45 - 20:24 MST
|
||||
|
||||
## Session Summary
|
||||
|
||||
Picked up a coord message from Mikes-MacBook-Air indicating the Safe Agent Rollout System (Phases 1-6) was code-complete and ready for testing. Before executing the test plan, reviewed active coord messages from GURU-BEAST-ROG which revealed three blocking hazards: migration 046 was already applied in production (causing a 28-restart crash loop earlier in the day), crash detection in `health.rs` was dead code keyed on an event type that was never emitted, and `build-server.sh` had no rollback capability on deploy failure. The MacBook's "ready to test" signal was premature.
|
||||
|
||||
Addressed the blockers by merging `fix/audit-2-remediation` (PR #22) which had been prepared by GURU-BEAST-ROG. That branch fixed crash detection (re-keyed to `update_success`), hardened `build-server.sh` with a build lock and binary auto-rollback, and added `Agent.update_channel` to all agent API responses. Also recovered uncommitted work from the submodule — a feature branch (`feature/log-finding-dispatch`) with collapsible FindingCards and an agent command dispatch panel in the log analysis view. That was committed to its own branch, reviewed, and merged as PR #23.
|
||||
|
||||
With the critical fixes landed, worked through the remaining MEDIUM bugs from the audit-2 report. BUG-007 converted the 5 remaining `sqlx::query!` compile-time macros in `health.rs` to runtime sqlx, adding a `HealthMetricsRow` struct and deleting 5 orphaned `.sqlx/` cache files (PR #24). BUG-008 fixed 5 sites in `metrics.rs` where raw DB error text leaked to API clients via `e.to_string()` — replaced with the project's `internal_err()` helper (PR #25). BUG-009/010 added `isError` error banner handling to 8 dashboard pages (Logs, Alerts, AlertTemplates, Commands, Dashboard, Settings, Sites, Users) using the pattern established in `Clients.tsx` (PR #26). BUG-011 eliminated all 14 `: any` annotations across 6 files, using `unknown` + `axios.isAxiosError()` guards for error handlers and proper typed interfaces for JSONB array locals (PR #27).
|
||||
|
||||
Each fix followed the full workflow: branch from main, code change, code review agent approval, Gitea Agent merge, submodule pointer advance in claudetools. All 6 PRs merged cleanly with CI auto-bump firing after each merge. The audit-2 MEDIUM bug backlog is now clear.
|
||||
|
||||
## Key Decisions
|
||||
|
||||
- **Blocked Phase 6 testing despite MacBook's "ready" signal** — GURU-BEAST-ROG coord messages revealed migration 046 was already applied in prod and crash detection was inert; proceeding with testing on a broken foundation would have produced false results.
|
||||
- **Recovered Logs.tsx uncommitted work as a feature branch rather than discarding** — the collapsible FindingCard + dispatch panel was real, useful work. Committed to `feature/log-finding-dispatch` before advancing the submodule pointer rather than stashing and losing it.
|
||||
- **Used `axios.isAxiosError()` for all error type narrowing** (BUG-011) — project had no established pattern for this; chose the official Axios type guard over intersection types or `as` casts to remain type-safe without adding overhead.
|
||||
- **BUG-004 (update_rollouts wiring) left as scaffolding** — Mike's earlier decision to label it Phase-2 inert rather than wire automation stood; crash detection (BUG-002) must be verified live before gating promotions on health signals.
|
||||
- **Kept `??` over `||` in Login/Register catch handlers** — reviewer noted server actually returns plain text errors, not `{ error: "..." }` JSON, so the `.error` field access never worked in either case. Pre-existing issue logged; not in scope for BUG-011.
|
||||
|
||||
## Problems Encountered
|
||||
|
||||
- **coord API rejecting notes with special characters** — `curl` payloads with em-dashes in the notes field triggered HTTP 422 parse errors. Resolved by simplifying the notes string to ASCII before the PUT call.
|
||||
- **Submodule checkout blocked by uncommitted Logs.tsx** — `git submodule update --remote` failed because the working tree had the in-progress FindingCard dispatch feature uncommitted. Resolved by branching, committing, and pushing before advancing the pointer.
|
||||
- **Bash working directory persistence** — Bash tool retains `cd` across calls in a session; after entering the gururmm submodule directory early in the session, subsequent bare git commands ran against the submodule repo rather than claudetools. Worked around by using explicit `cd /d/claudetools` prefixes for claudetools-level operations.
|
||||
|
||||
## Configuration Changes
|
||||
|
||||
- `projects/msp-tools/guru-rmm` submodule pointer advanced 5 times (PRs #22-#27)
|
||||
- `session-logs/2026-05-25-session.md` — appended this update
|
||||
|
||||
## Credentials & Secrets
|
||||
|
||||
None discovered or created this session.
|
||||
|
||||
## Infrastructure & Servers
|
||||
|
||||
- **gururmm-build / 172.16.3.30** — GuruRMM server + build host. Webhook builds fired after each merge to main. Service restarted automatically via build-server.sh.
|
||||
- **Coord API** — `http://172.16.3.30:8001/api/coord` — used for component state updates (server, dashboard both set to `building`) and message reads.
|
||||
- **Gitea** — `http://172.16.3.20:3000` — PRs #22-#27 all merged via API.
|
||||
|
||||
## Commands & Outputs
|
||||
|
||||
```bash
|
||||
# Merge fix/audit-2-remediation (PR #22) — merge SHA e6d1e9c
|
||||
# Merge feature/log-finding-dispatch (PR #23) — merge SHA 2650d5ce
|
||||
# Merge fix/bug-007-runtime-sqlx (PR #24) — merge SHA 940ced14
|
||||
# Merge fix/bug-008-internal-err (PR #25) — merge SHA e5426b4d
|
||||
# Merge fix/bug-009-010-iserror (PR #26) — merge SHA 3c09f9bc
|
||||
# Merge fix/bug-011-no-any (PR #27) — merge SHA 3aa9ea4f
|
||||
|
||||
# Verify no sqlx macros remain in health.rs
|
||||
grep -n "sqlx::query!" server/src/updates/health.rs
|
||||
# (no output — clean)
|
||||
|
||||
# Verify no :any remains in 6 files
|
||||
grep -rn ": any" dashboard/src/components/InventoryTab.tsx ...
|
||||
# (no output — clean)
|
||||
```
|
||||
|
||||
## Pending / Incomplete Tasks
|
||||
|
||||
- **Phase 6 test plan** (`PHASE_6_TEST_PLAN.md`) — not yet executed. Blockers cleared (BUG-002/003/006 merged). Can now proceed: SSH to 172.16.3.30, run `verify-rollout-system.sh`, confirm webhook build from today's merges completed, then execute test plan systematically.
|
||||
- **Auth error display bug** — Login/Register catch handlers read `err.response?.data?.error` but server returns plain text, not JSON. The fallback message always shows. Low priority; separate follow-up needed.
|
||||
- **BUG-004 (update_rollouts wiring)** — deferred by Mike; requires re-spec before implementation. Depends on BUG-002 (crash detection) being verified live first.
|
||||
- **BUG-005 (mac build stub)** — product decision needed: provision Apple hardware + implement build-mac.sh, or mark platform as N/A in audit pipeline.
|
||||
- **feature/log-finding-dispatch** — merged. No open items.
|
||||
|
||||
## Reference Information
|
||||
|
||||
- GuruRMM Gitea repo: `http://172.16.3.20:3000/azcomputerguru/gururmm`
|
||||
- PRs merged today: #22 (audit-2-remediation), #23 (log dispatch), #24 (BUG-007), #25 (BUG-008), #26 (BUG-009/010), #27 (BUG-011)
|
||||
- Phase 6 test plan: `ClaudeTools/PHASE_6_TEST_PLAN.md`
|
||||
- Verification script: `ClaudeTools/verify-rollout-system.sh`
|
||||
- Audit-2 report: `projects/msp-tools/guru-rmm/reports/2026-05-25-rmm-audit-2.md`
|
||||
- Bug tracking: `projects/msp-tools/guru-rmm/docs/FEATURE_ROADMAP.md` (BUG-002 through BUG-012)
|
||||
- Coord API component state: server=building, dashboard=building (as of end of session)
|
||||
SESSIONEOF
|
||||
```
|
||||
Output: (Bash completed with no output)
|
||||
|
||||
## Pending / Incomplete Tasks
|
||||
|
||||
- Follow-up ticket to address hardcoded fallback errors in Login and Register pages.
|
||||
- Execute Phase 6 test plan from GURU-5070 or GURU-KALI via SSH to 172.16.3.30.
|
||||
|
||||
## Reference Information
|
||||
|
||||
_Machine-extracted verbatim from the whole transcript via regex. Treat as leads, not gospel; deduped._
|
||||
Reference in New Issue
Block a user