sync: auto-sync from GURU-KALI at 2026-05-31 20:07:50
Author: Mike Swanson Machine: GURU-KALI Timestamp: 2026-05-31 20:07:50
This commit is contained in:
184
session-logs/2026-05-31-mike-rednour-and-claudetools-infra.md
Normal file
184
session-logs/2026-05-31-mike-rednour-and-claudetools-infra.md
Normal file
@@ -0,0 +1,184 @@
|
|||||||
|
# Rednour Onboarding + ClaudeTools Infra Hardening + youtube-sync-docker Pickup
|
||||||
|
|
||||||
|
## User
|
||||||
|
- **User:** Mike Swanson (mike)
|
||||||
|
- **Machine:** GURU-KALI
|
||||||
|
- **Role:** admin
|
||||||
|
|
||||||
|
## Session Summary
|
||||||
|
|
||||||
|
Three substantive threads across this session on GURU-KALI.
|
||||||
|
|
||||||
|
**Thread 1 — Rednour Law tenant onboarded + email changes shipped (Syncro #32343).** The session opened on the existing remediation ticket: "Remove emma@, add carla@ (Carla Skinner), add nick@ (Nick Pafford) with shared drive access." First attempt at the Graph PATCH for the Emma rename failed because `proxyAddresses` is read-only on Graph — Exchange address management has to go through Exchange REST. Then Exchange REST returned 403 because the ComputerGuru Exchange Operator SP didn't have Exchange Administrator role in the rednourlaw.com tenant. That uncovered the deeper issue: the tenant was never fully onboarded. Walked back, had Mike click the Tenant Admin admin-consent URL as Global Admin, then ran `onboard-tenant.sh rednourlaw.com` which consented the remaining four SPs (Security Investigator, Exchange Operator, User Manager, Defender Add-on) and assigned their directory roles (Exchange Administrator x2, User Administrator + Authentication Administrator, Conditional Access Administrator). Defender Add-on consented but unusable — no MDE license in this tenant. After ~60s for Exchange role propagation, ran the full rename: `Set-Mailbox` for EmailAddresses (carla@ as primary, emma@ + legacy dgarcia@/alee@ preserved as aliases, kept SPO routing entry), Graph PATCH for UPN + displayName + mailNickname + givenName + surname, then `revokeSignInSessions` to invalidate active tokens. Nick already existed as `npafford@`, so Mike's call was to just add `smtp:nick@rednourlaw.com` as an alias on his existing mailbox — no UPN change, no session revoke. Closed out by adding 30 min remote labor on the ticket and setting it to Resolved (no invoice yet; shared-drive piece deferred). `references/tenants.md` flipped from NO to YES for rednourlaw.com with the per-SP role summary. Full audit report written to `clients/rednour/reports/2026-05-31-onboard-and-rename-emma-to-carla.md`.
|
||||||
|
|
||||||
|
**Thread 2 — ClaudeTools sync.sh hardening, three rounds.** First round was triggered by a sync failure during a routine /save earlier: the parent repo's `git fetch` recursed into submodules and hit a transient dead ref in guru-connect's history (a commit referenced by a parent gitlink had been force-pushed out of the submodule remote between the two commits that wrapped it). Fix: add `--no-recurse-submodules` to the parent fetch + pull, then run `git submodule update --init --recursive` separately as a tolerant post-step that warns rather than aborts. Code Review clean. Second round, Mike pointed out that any OS/platform-specific knob in sync.sh should live in `identity.json` per the established pattern — that surfaced the hardcoded `COORD_API="http://172.16.3.30:8001"` LAN IP across three scripts (sync.sh, check-messages.sh, check-ksteen-smartbadge.sh) which silently breaks off-network workstations. Lifted `coord_api` into identity.json with the existing IP as fallback default; updated `migrate-identity.sh` to populate it for any machine missing the field; deleted dead Windows-path repo-root fallbacks at sync.sh:102 that had been superseded by identity.json + git rev-parse. Broadcast coord message to the team telling them to run `migrate-identity.sh` to pick up the new field. Third round, after committing two youtube-sync-docker commits as `ComputerGuru <guru@GURU-KALI.lan>` instead of Mike (sync.sh's `reconcile_git_identity` only runs on the parent repo, not submodules) — wrote a spec at `docs/specifications/SUBMODULE-IDENTITY-RECONCILE-SPEC.md` and then implemented it. Phase 1a's existing init loop now invokes `reconcile_git_identity` inside each submodule via a `(cd ...)` subshell. Tested empirically: caught real drift on guru-connect's unset identity on the first run, idempotent on subsequent runs, forced-drift test passed. Coord todo `a176100c` opened and closed in the same session.
|
||||||
|
|
||||||
|
**Thread 3 — youtube-sync-docker pickup and bug fix.** Mike asked to pull up the YouTube downloader project. After a broad sweep of the repo (no `projects/*youtube*`, no `yt-dlp` references in code, no session logs mentioning it), located it as `youtube-sync-docker` under Mike's Gitea personal repos. Cloned it as a submodule at `projects/youtube-sync-docker/` to match the guru-rmm / guru-connect pattern. Read the codebase (~600 lines across Flask app + sync.sh + Dockerfile + Unraid template). Spotted a real bug: the Web UI's Settings page wrote to `/config/settings.json` but nothing downstream read that file — `entrypoint.sh` and `sync.sh` both read only env vars, and cron was never reloaded when the user changed the schedule. The "Settings saved successfully" flash was a lie. Fixed across four files: `sync.sh` reads max_quality + sleep_interval from settings.json at start of each run (jq + env-var fallback); `entrypoint.sh` reads sync_schedule from settings.json and writes crond's PID to `/var/run/crond.pid` so Flask can SIGHUP it; new `apply_schedule()` in app.py rewrites `/etc/crontabs/root`, SIGHUPs crond, restarts crond if PID is stale, drops the crontab on manual mode; `save_settings_route` calls it only when schedule actually changed and flashes a warning on failure rather than crashing the save. Also: `Dockerfile` adds `jq`; `set -e` in sync.sh no longer kills the whole loop on one bad channel (`|| echo "[WARNING]"` per-channel); bare `except: pass` in `get_settings()` replaced with explicit exception types + stderr warning; README's stale `github.com/azcomputerguru/...` URLs swapped to Gitea. Three pytest cases for `get_settings()`, then six more for `apply_schedule()` covering all five state combinations (manual+live PID, manual+no-state, real+live, real+dead-PID, real+no-PID, real+garbage-PID). All 9 tests pass. .gitignore got Python/pytest exclusions. Code Reviewed both rounds. Shipped as `ef903c8` (fix + initial tests) and `fdff0a7` (apply_schedule tests + gitignore) to youtube-sync-docker's main.
|
||||||
|
|
||||||
|
## Key Decisions
|
||||||
|
|
||||||
|
- **Rednour onboarding strategy**: bootstrapped the full MSP suite (not just Exchange Operator) since onboarding was already incomplete. Future operations against this tenant have the full toolset available rather than needing another consent click later.
|
||||||
|
- **Nick interpretation**: Mike's call to add `smtp:nick@` as an alias on `npafford@` instead of renaming the account or creating a new one. Nick already existed; the ticket text "Add: Nick@" was informal shorthand for "make nick@ work for him." Shared-drive access deferred separately.
|
||||||
|
- **Carla rename: keep both legacy aliases (dgarcia@, alee@)**, revoke sessions, do not reset password. Mike's call — name change, not personnel handoff.
|
||||||
|
- **No invoice on ticket #32343 yet**: Mike said "set as Resolved", not "invoice". 30 min remote labor sits on the ticket pending final close-out (after shared-drive piece). Labor type/qty/rate explicitly chosen by Mike — no defaults assumed.
|
||||||
|
- **sync.sh dead-ref fix scope**: targeted `--no-recurse-submodules` on parent fetch/pull + a tolerant post-rebase `git submodule update`. Specifically did NOT add a CLI flag, env var, or any user-facing knob. The fix is unconditional.
|
||||||
|
- **coord_api lift uses fallback to the hardcoded LAN IP rather than failing hard** when identity.json doesn't define it. Existing machines stay working without an identity.json edit; off-network machines get a knob to override.
|
||||||
|
- **Dead Windows-path repo-root fallbacks in sync.sh:102 deleted, not "moved to identity.json"**. They were superseded by identity.json + git rev-parse and never fired in practice. Cleanup, not lift.
|
||||||
|
- **Submodule identity reconcile picked Option A from the spec** (extend the existing init while-loop with `(cd ... && reconcile_git_identity ...)`) over Option B (inline duplicate logic in `submodule foreach`) and Option C (factor into a sourceable library). Spec called Option A and the implementation matched.
|
||||||
|
- **youtube-sync-docker submodule registration** in ClaudeTools rather than standalone clone. Matches the guru-rmm / guru-connect pattern. Future workstations get it via the normal submodule init on /sync.
|
||||||
|
- **youtube-sync-docker fix scope**: only the settings-not-applied bug + the one-bad-channel-kills-loop hardening. Explicitly out of scope: gunicorn, security hardening on cookie upload, per-channel sync triggers, SSE live progress, CI workflows. Mike picked the recommended "fix the bug first" option from a four-way trade-off.
|
||||||
|
- **TZ deliberately not made live-applicable**: tzdata resolves at process start, so timezone changes require container restart. Settings page still saves the value; sync.sh and entrypoint don't read it from settings.json. Matched prior behavior; not silently lying about it.
|
||||||
|
- **Submodule identity reconcile shipped pre-Code-Review** because the Coding Agent ran `bash sync.sh` for verification and sync.sh auto-commits/pushes its own diff during Phase 1. Disclosed up front. Code Review on the committed state came back CLEAN; no rollback needed.
|
||||||
|
- **Two prior youtube-sync-docker commits with wrong author** (ef903c8, fdff0a7 as `ComputerGuru`) left as-is — rewriting history would need a force-push to shared remote. Going forward, the new sync.sh reconcile prevents recurrence on this and every other machine.
|
||||||
|
|
||||||
|
## Problems Encountered
|
||||||
|
|
||||||
|
- **Graph PATCH 400 "Property 'proxyAddresses' is read-only"** on the initial Emma rename attempt. Graph User write permissions don't include `proxyAddresses` even with `Directory.ReadWrite.All` — Exchange manages mail aliases. Split the rename into two API tiers: identity fields via Graph, mail addresses via Exchange REST.
|
||||||
|
- **Exchange REST HTTP 403** on Get-Mailbox after acquiring an exchange-op token. Token came back successfully (so the SP was consented) but the SP lacked Exchange Administrator role in the rednourlaw tenant. Same hazard for the other SPs — the tenant was never fully onboarded. Resolved by running the bootstrap flow (Tenant Admin consent click + `onboard-tenant.sh`).
|
||||||
|
- **Stale read-after-write on Exchange Set-Mailbox and Graph PATCH**. Both writes returned success codes immediately, but the verification reads still showed old data for ~45s. Switched to polling for UPN convergence on the carla rename and a per-attempt poll for the nick alias add. Both converged within the first or second poll once the wait started.
|
||||||
|
- **First sync.sh recursive-submodule fetch failure**: parent fetch couldn't resolve a guru-connect commit (`d1b35f4a...`) that had been force-pushed out of the submodule remote between two parent gitlinks. Manual workaround was `git -c submodule.recurse=false pull --rebase origin main && git push && git submodule update --init --recursive`. Fix in sync.sh makes that the default behavior.
|
||||||
|
- **Coding Agent ran `sync.sh` for verification** during the submodule reconcile implementation. sync.sh by design auto-commits + pushes uncommitted changes in Phase 1 — including the agent's own dirty edit. Result: change shipped pre-Code-Review as commit `4c49b85`. Disclosed honestly by the agent. Code Review on the committed state was CLEAN, so accepted as-is. Note for future: don't run sync.sh as a verification step against a dirty tree.
|
||||||
|
- **Initial Gitea push of youtube-sync-docker fix prompted for username** because the submodule's local .git/config had no embedded credentials. Gitea Agent reused the parent repo's `azcomputerguru:<token>` embedded URL — only changed the submodule's local .git/config (not committed anywhere). Worth flagging for future submodule auth setup.
|
||||||
|
- **Two submodule commits attributed to `ComputerGuru <guru@GURU-KALI.lan>`** (the system default) instead of Mike, because sync.sh's reconcile only ran on the parent repo. Spotted by the Gitea Agent's post-commit report. Fixed forward via `git config user.name/user.email` in the submodule + the broader sync.sh fix that prevents recurrence.
|
||||||
|
|
||||||
|
## Configuration Changes
|
||||||
|
|
||||||
|
**ClaudeTools repo (committed):**
|
||||||
|
- `.claude/scripts/sync.sh` — dead-ref tolerance (`--no-recurse-submodules` on parent fetch + pull, tolerant post-rebase submodule update); deleted dead Windows-path repo-root fallback loop at line 102; submodule identity reconcile in Phase 1a; coord_api read from identity.json with hardcoded fallback. Commits: `2afec8f`, `4c49b85`, parts of `973e9db`.
|
||||||
|
- `.claude/scripts/migrate-identity.sh` — populates `coord_api` for any machine missing the field. Commit `973e9db`.
|
||||||
|
- `.claude/scripts/check-messages.sh` — reads `coord_api` from identity.json with fallback. Commit `973e9db`.
|
||||||
|
- `.claude/scripts/check-ksteen-smartbadge.sh` — same pattern. Commit `973e9db`.
|
||||||
|
- `.claude/skills/remediation-tool/references/tenants.md` — rednourlaw.com row flipped NO → YES with role summary. Commit `14341d1` (latest sync auto-commit).
|
||||||
|
- `clients/rednour/reports/2026-05-31-onboard-and-rename-emma-to-carla.md` — full remediation audit report. New. Commit `14341d1`.
|
||||||
|
- `docs/specifications/SUBMODULE-IDENTITY-RECONCILE-SPEC.md` — the planning artifact for the reconcile change. Commit `14341d1`.
|
||||||
|
- `.gitmodules` — registered new submodule `projects/youtube-sync-docker` → `https://git.azcomputerguru.com/azcomputerguru/youtube-sync-docker.git` on branch `main`. Commit `14341d1`.
|
||||||
|
- Submodule pointer `projects/youtube-sync-docker` → `fdff0a7`. Commit `14341d1`.
|
||||||
|
|
||||||
|
**ClaudeTools machine-local (not committed; gitignored):**
|
||||||
|
- `.claude/identity.json` — added `coord_api: "http://172.16.3.30:8001"` field, bumped `last_updated`. Per-machine, won't sync to other workstations until each runs `migrate-identity.sh`.
|
||||||
|
- `.claude/current-mode` — set to `dev` during youtube-sync-docker work.
|
||||||
|
- All three submodules (`projects/msp-tools/guru-rmm`, `projects/msp-tools/guru-connect`, `projects/youtube-sync-docker`) had their local `.git/config` user.name/user.email reconciled to `Mike Swanson / mike@azcomputerguru.com`. guru-connect was previously unset (real drift case); the other two were already correct.
|
||||||
|
|
||||||
|
**youtube-sync-docker repo (committed + pushed to origin/main on Gitea):**
|
||||||
|
- `app.py` — new `apply_schedule()` helper; `save_settings_route` applies schedule changes live; bare except replaced; `signal` + `sys` imports added. Commit `ef903c8`.
|
||||||
|
- `entrypoint.sh` — reads `sync_schedule` from settings.json before cron setup; writes crond PID to `/var/run/crond.pid`. Commit `ef903c8`.
|
||||||
|
- `sync.sh` — reads `max_quality` + `sleep_interval` from settings.json; per-channel yt-dlp failure no longer aborts the loop. Commit `ef903c8`.
|
||||||
|
- `Dockerfile` — added `jq` to apk install. Commit `ef903c8`.
|
||||||
|
- `README.md` — fixed two stale `github.com/azcomputerguru/...` URLs to Gitea; new "Running Tests" subsection. Commit `ef903c8`.
|
||||||
|
- `tests/__init__.py`, `tests/test_settings.py`, `requirements-dev.txt` — new. Commit `ef903c8`.
|
||||||
|
- `tests/test_apply_schedule.py` — new. 118 lines, 6 cases covering apply_schedule()'s state combinations. Commit `fdff0a7`.
|
||||||
|
- `.gitignore` — added `__pycache__/`, `*.pyc`, `.pytest_cache/`. Commit `fdff0a7`.
|
||||||
|
|
||||||
|
## Credentials & Secrets
|
||||||
|
|
||||||
|
**M365 rednourlaw.com tenant (4a4ca18a-f516-478b-99da-2e0722c5dc18):**
|
||||||
|
- All five ComputerGuru MSP SPs now consented:
|
||||||
|
- Tenant Admin (`709e6eed-0711-4875-9c44-2d3518c47063`) — SP `671a2ace-be9e-440c-a7d6-5ff982e4500c`, role: Conditional Access Administrator
|
||||||
|
- Security Investigator (`bfbc12a4-f0dd-4e12-b06d-997e7271e10c`) — SP `704da463-7f4e-484c-b1da-40e447615d52`, role: Exchange Administrator
|
||||||
|
- Exchange Operator (`b43e7342-5b4b-492f-890f-bb5a4f7f40e9`) — SP `59a68ba9-5e1e-4a56-92ae-507a9a669a79`, role: Exchange Administrator
|
||||||
|
- User Manager (`64fac46b-8b44-41ad-93ee-7da03927576c`) — SP `dc3b79a2-638b-42fe-8ecb-51592db7d40f`, roles: User Administrator + Authentication Administrator
|
||||||
|
- Defender Add-on (`dbf8ad1a-54f4-4bb8-8a9e-ea5b9634635b`) — SP `052da8aa-1ca5-4f60-b9c5-7aafcb74264b`, no roles assigned (tenant has no MDE license — Defender ATP calls would 650052)
|
||||||
|
|
||||||
|
**rednourlaw.com users renamed/touched:**
|
||||||
|
- `93074d1a-6db2-4794-8f7d-c84a619e4494`: emma@ → carla@rednourlaw.com (Carla Skinner). Password unchanged. Sessions revoked.
|
||||||
|
- `fe859088-bcbc-49dc-aaea-4c6e68f7d5bb`: npafford@ kept as UPN, `smtp:nick@rednourlaw.com` alias added. Password unchanged. Sessions NOT revoked.
|
||||||
|
|
||||||
|
**Syncro:**
|
||||||
|
- Comment `415513323` (hidden, internal) and `415514647` (customer-visible) on ticket #32343
|
||||||
|
- Line item `42654682` (0.5h remote labor, $75.00, attributed to Mike user_id 1735)
|
||||||
|
- Bot alerts `1510790887653773403` (M365 update) and `1510791784270270674` (resolve + bill)
|
||||||
|
|
||||||
|
**No new credentials created or discovered in vault during this session** beyond what came in via `/sync` pulls (`projects/guruconnect/portal.sops.yaml` from Mike on a different machine — admin + howard logins for GuruConnect portal/dashboard).
|
||||||
|
|
||||||
|
## Infrastructure & Servers
|
||||||
|
|
||||||
|
- Coord API: `http://172.16.3.30:8001/api/coord` — now configurable per-machine via `identity.json` `coord_api` field
|
||||||
|
- rednourlaw.com Global Admin: Carrie Rednour (sysadmin@rednourlaw.com display name "Carrie Rednour" — same person on the regular crednour@ account)
|
||||||
|
- youtube-sync-docker target deploy host: not explicitly set; intended for Unraid Community Applications template. Mike's running container "youtube-sync-test" exists on some other host (this box has no docker installed). README docker-compose references image `azcomputerguru/youtube-sync:latest`.
|
||||||
|
- No GuruRMM, GuruConnect, or Dataforth infrastructure touched in this session.
|
||||||
|
|
||||||
|
## Commands & Outputs
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Resolve tenant + onboard
|
||||||
|
bash .claude/skills/remediation-tool/scripts/resolve-tenant.sh rednourlaw.com
|
||||||
|
# → 4a4ca18a-f516-478b-99da-2e0722c5dc18
|
||||||
|
|
||||||
|
bash .claude/skills/remediation-tool/scripts/onboard-tenant.sh rednourlaw.com
|
||||||
|
# → consented Sec Inv / Exch Op / User Mgr / Defender Add-on; assigned all required roles
|
||||||
|
|
||||||
|
# Emma rename — three calls in order
|
||||||
|
curl -X POST .../adminapi/beta/$TENANT/InvokeCommand # Set-Mailbox: EmailAddresses, WindowsEmailAddress
|
||||||
|
curl -X PATCH https://graph.microsoft.com/v1.0/users/93074d1a-... # UPN, displayName, mailNickname, givenName, surname
|
||||||
|
curl -X POST https://graph.microsoft.com/v1.0/users/93074d1a-.../revokeSignInSessions
|
||||||
|
# → all 200/204. Polled UPN until convergence to carla@rednourlaw.com.
|
||||||
|
|
||||||
|
# Nick alias add — one call
|
||||||
|
curl -X POST .../adminapi/beta/$TENANT/InvokeCommand # Set-Mailbox EmailAddresses with smtp:nick@ added
|
||||||
|
# → 200, converged first poll
|
||||||
|
|
||||||
|
# Syncro ticket update
|
||||||
|
POST /tickets/111409967/comment # internal note id 415513323
|
||||||
|
POST /tickets/111409967/comment # customer resolution id 415514647
|
||||||
|
POST /tickets/111409967/add_line_item # line id 42654682, 0.5h × $150
|
||||||
|
PUT /tickets/111409967 # status -> Resolved
|
||||||
|
|
||||||
|
# Sync.sh verification (post-reconcile-implementation)
|
||||||
|
bash .claude/scripts/sync.sh # Run 1: caught real drift on guru-connect (unset identity)
|
||||||
|
bash .claude/scripts/sync.sh # Run 2: silent (idempotent)
|
||||||
|
(cd projects/youtube-sync-docker && git config user.name "Wrong Name")
|
||||||
|
bash .claude/scripts/sync.sh # Run 3: caught drift, rewrote
|
||||||
|
bash .claude/scripts/sync.sh # Run 4: silent again
|
||||||
|
|
||||||
|
# Youtube-sync-docker test runs
|
||||||
|
cd projects/youtube-sync-docker
|
||||||
|
python3 -m pytest tests/ -v # 9 passed in 0.05s (3 settings + 6 apply_schedule)
|
||||||
|
```
|
||||||
|
|
||||||
|
## Pending / Incomplete Tasks
|
||||||
|
|
||||||
|
- **Shared-drive access for Nick Pafford** on the Rednour ticket (#32343) — deferred to a separate workflow per Mike's instruction. Not actioned in this session. The Syncro ticket is Resolved with this explicitly called out in both the internal and customer-visible comments.
|
||||||
|
- **Other workstations need to run `migrate-identity.sh`** to pick up the new `coord_api` field in their identity.json. Coord broadcast `1d93052f-aa79-4ac3-a0e9-99f04a4695c9` (sent 2026-05-31 16:38 UTC) covers this. On-LAN machines work without it (fallback kicks in); off-LAN/VPN machines need it to talk to coord API.
|
||||||
|
- **Other workstations' submodule git identities** will auto-correct on their next `/sync` (one-time `[WARNING]` per drifted submodule, then silent). No manual action needed.
|
||||||
|
- **youtube-sync-docker invoice** is not created yet. 30 min remote labor sits on Syncro #32343; bill at final close-out when shared-drive piece also done.
|
||||||
|
- **Two youtube-sync-docker commits remain authored as `ComputerGuru`** (`ef903c8`, `fdff0a7`). Not being rewritten — force-push to shared remote is the only option and Mike chose to leave history alone.
|
||||||
|
- **TZ change via UI still requires container restart** on youtube-sync-docker (tzdata locked in at process start). Documented in the commit message; not silently lying about it. Could be plumbed through to a live tzdata reload if it ever matters.
|
||||||
|
|
||||||
|
## Reference Information
|
||||||
|
|
||||||
|
**Tenant + user IDs:**
|
||||||
|
- rednourlaw.com tenant: `4a4ca18a-f516-478b-99da-2e0722c5dc18`
|
||||||
|
- Carla (was Emma): user object `93074d1a-6db2-4794-8f7d-c84a619e4494`, UPN `carla@rednourlaw.com`
|
||||||
|
- Nick Pafford: user object `fe859088-bcbc-49dc-aaea-4c6e68f7d5bb`, UPN `npafford@rednourlaw.com`, alias `nick@rednourlaw.com`
|
||||||
|
|
||||||
|
**Syncro:**
|
||||||
|
- Customer: Rednour Law, id `1224246`
|
||||||
|
- Ticket: #32343, id `111409967`, status `Resolved`
|
||||||
|
- URL: https://computerguru.syncromsp.com/tickets/111409967
|
||||||
|
|
||||||
|
**ClaudeTools repo commits (parent):**
|
||||||
|
- `c89f22c` — sync.sh dead-submodule-ref tolerance
|
||||||
|
- `973e9db` — coord_api lift + identity.json + migrate-identity + Windows-path cleanup
|
||||||
|
- `4c49b85` — submodule identity reconcile in sync.sh Phase 1a
|
||||||
|
- `14341d1` (pre-final sync), then auto-advanced via the most recent /sync — see HEAD
|
||||||
|
|
||||||
|
**youtube-sync-docker repo (azcomputerguru/youtube-sync-docker on Gitea):**
|
||||||
|
- Before: `71ba63f`
|
||||||
|
- `ef903c8` — settings-not-applied fix + first 3 tests (note: authored as `ComputerGuru`)
|
||||||
|
- `fdff0a7` — apply_schedule tests + gitignore (note: authored as `ComputerGuru`)
|
||||||
|
- Clone URL: `https://git.azcomputerguru.com/azcomputerguru/youtube-sync-docker.git`
|
||||||
|
- Description: "Automatically download and organize YouTube channel videos for Emby/Plex/Jellyfin"
|
||||||
|
|
||||||
|
**Vault touched (pulled this session from other machines):**
|
||||||
|
- `projects/guruconnect/portal.sops.yaml` — Mike's earlier work on GURU-5070, GuruConnect portal admin logins
|
||||||
|
|
||||||
|
**Coord API objects created this session:**
|
||||||
|
- Broadcast `1d93052f-aa79-4ac3-a0e9-99f04a4695c9` — alert routing change (initial broadcast was from GURU-5070; same routing now lives in `post-bot-alert.sh`)
|
||||||
|
- Broadcast `<the migrate-identity.sh one I sent earlier>` — todo migration heads-up
|
||||||
|
- Todo `a176100c-6de5-4e3b-8c1c-8291a2aa6ff0` — Implement submodule identity reconcile in sync.sh. Status: done.
|
||||||
|
|
||||||
|
**Key file paths:**
|
||||||
|
- Spec: `docs/specifications/SUBMODULE-IDENTITY-RECONCILE-SPEC.md`
|
||||||
|
- Audit report: `clients/rednour/reports/2026-05-31-onboard-and-rename-emma-to-carla.md`
|
||||||
|
- Submodule: `projects/youtube-sync-docker/`
|
||||||
|
- Raw API artifacts: `/tmp/remediation-tool/4a4ca18a-f516-478b-99da-2e0722c5dc18/rednour-rename/` (get-mailbox-before.json, set-mailbox-resp.json, get-mailbox-after2.json, get-mailbox-final.json, nick-mailbox-before.json, nick-set-mailbox-resp.json, nick-mailbox-after.json, nick-mailbox-poll.json)
|
||||||
Reference in New Issue
Block a user