blumeops/argocd/apps
Erich Blume 13895bb04a Localize external-secrets on ringtail (amd64 nix build) (#368)
Follow-up to #367. That PR localized external-secrets but the Dagger build (on indri's Apple Silicon runner) only produces an **arm64** image — and external-secrets also runs on **ringtail (amd64)** via the same shared manifest. This completes the localization so both clusters run the local binary on their native arch.

## Approach (matches the kube-state-metrics dual-build pattern)
- **`containers/external-secrets/default.nix`** (new) — builds the **amd64** image on ringtail's nix-container-builder. `buildGoModule` with Go 1.26 (v2.2.0 requires ≥1.26.1; nixpkgs default is 1.25.x) and `-tags all_providers`, faithful to upstream. Same v2.2.0 source from the forge mirror.
- **`argocd/manifests/external-secrets-ringtail/`** (new) — thin kustomize overlay that reuses the shared indri manifest as a base and overrides **only** the image to the `-nix` (amd64) tag. No manifest duplication.
- **`argocd/apps/external-secrets-ringtail.yaml`** — repointed at the new overlay.

Result: indri → `v2.2.0-…` (arm64, Dagger), ringtail → `v2.2.0-…-nix` (amd64, nix).

## Build
Run #581 built both arches at the branch commit. Verified the nix image is `linux/amd64`, entrypoint = the binary, user 65534.

## Deployed from branch & verified on ringtail (k3s, amd64)
- All 3 pods rolled to the nix amd64 image, `1/1 Running` (no exec-format error → arch correct)
- Controller logs clean
- **Live secret fetch proven:** force-synced `homepage/homepage-grafana` → `refreshTime` advanced, `Ready=True`
- **All 20** ringtail ExternalSecrets remain `SecretSynced=True`

## Post-merge
The `external-secrets-ringtail` app is temporarily pointed at this branch + overlay path (apps app left on `main`, manual-sync, untouched). After merge:
```
argocd app sync apps                       # picks up the new Application path on main
argocd app set external-secrets-ringtail --revision main && argocd app sync external-secrets-ringtail
```
I'll also rebuild off `main` so both clusters land on stable main-sha tags (as done for indri in #367).

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Reviewed-on: #368
2026-06-04 15:37:42 -07:00
..
1password-connect-ringtail.yaml
1password-connect.yaml
alloy-k8s.yaml
alloy-ringtail.yaml
alloy-tracing-ringtail.yaml
apps.yaml
argocd.yaml
authentik.yaml
blumeops-pg.yaml
cloudnative-pg-ringtail.yaml C2: migrate immich from minikube to ringtail (mikado chain) (#356) 2026-05-13 16:46:17 -07:00
cloudnative-pg.yaml
databases-ringtail.yaml C2: migrate immich from minikube to ringtail (mikado chain) (#356) 2026-05-13 16:46:17 -07:00
external-secrets-crds-ringtail.yaml
external-secrets-crds.yaml
external-secrets-ringtail.yaml Localize external-secrets on ringtail (amd64 nix build) (#368) 2026-06-04 15:37:42 -07:00
external-secrets.yaml
forgejo-runner.yaml
frigate.yaml
grafana-config.yaml
grafana.yaml
homepage.yaml C1: migrate homepage dashboard to ringtail k3s 2026-05-10 20:37:03 -07:00
immich-ringtail.yaml C2: migrate immich from minikube to ringtail (mikado chain) (#356) 2026-05-13 16:46:17 -07:00
kingfisher.yaml
kiwix.yaml
kube-state-metrics-ringtail.yaml
kube-state-metrics.yaml
loki.yaml
mealie-ringtail.yaml Wave 1 indri→ringtail migration: paperless, teslamate, mealie (#363) 2026-06-03 10:34:00 -07:00
miniflux.yaml
navidrome.yaml
ntfy.yaml
nvidia-device-plugin.yaml
ollama.yaml
paperless-ringtail.yaml Wave 1 indri→ringtail migration: paperless, teslamate, mealie (#363) 2026-06-03 10:34:00 -07:00
prometheus.yaml
prowler.yaml
shower.yaml C1: deploy adelaide-baby-shower-app to ringtail k3s (#349) 2026-05-11 13:47:18 -07:00
tailscale-operator-ringtail.yaml
tailscale-operator.yaml
tempo.yaml
teslamate-ringtail.yaml Wave 1 indri→ringtail migration: paperless, teslamate, mealie (#363) 2026-06-03 10:34:00 -07:00
torrent.yaml
unpoller.yaml