cli: add homelab edges — who-talks-to-whom investigation helper (v0.9.0)
Makes the goldmane_edges east-west trail (ADR-0014) reachable during incident investigations without remembering the DB/creds/SQL. New top-level verb: homelab edges --ns <ns> edges touching <ns> (either direction) homelab edges --src/--dst <ns> directional egress / ingress peers homelab edges --peers-of <ns> distinct peer namespaces of <ns> homelab edges --new-since 24h first seen since a duration or date (YYYY-MM-DD) homelab edges --denied only action='deny' (blocked / lateral movement) homelab edges --json --limit N machine-readable / row cap (default 200) Filters render to a single read-only SELECT against the `edge` table, run via the dbaas CNPG primary pod (same exec path as `k8s db`). Namespace values are validated to the k8s name charset (injection guard) before they reach SQL. TDD: edges_test.go covers flag parsing, query building (each filter, AND combination, peers-of shape, JSON wrapper), the new-since duration/date parser, and namespace-validation / injection rejection. Smoke-tested live: --peers-of, --new-since 24h, --denied, and --json all return correct rows. Docs: runbook query section now leads with the CLI; cli/README gains a v0.9 section. VERSION v0.8.2 -> v0.9.0. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
parent
0fa5852ec6
commit
9a1ab6247b
7 changed files with 429 additions and 3 deletions
|
|
@ -153,8 +153,22 @@ on Goldmane's live serving cert, so no `GOLDMANE_SERVER_NAME` /
|
|||
|
||||
## How to query who-talks-to-whom
|
||||
|
||||
`psql` into the DB (creds: Vault static role `static-creds/pg-goldmane-edges`, or
|
||||
exec a CNPG pod). All queries are against the single `edge` table.
|
||||
**Quickest — the `homelab edges` CLI** (the investigation helper; read-only
|
||||
SELECT against the DB via the dbaas primary pod, no creds/SQL to remember):
|
||||
|
||||
```
|
||||
homelab edges --ns <ns> # edges touching <ns> (either direction)
|
||||
homelab edges --peers-of <ns> # <ns>'s distinct peer namespaces
|
||||
homelab edges --src <ns> # <ns>'s egress peers (--dst <ns> for ingress)
|
||||
homelab edges --new-since 24h # edges first seen in the last day (or a date)
|
||||
homelab edges --denied # blocked / lateral-movement attempts
|
||||
homelab edges --json [...] # machine-readable, for agents/pipelines
|
||||
homelab edges --help # full flag list
|
||||
```
|
||||
|
||||
For ad-hoc SQL, `psql` into the DB (creds: Vault static role
|
||||
`static-creds/pg-goldmane-edges`, or exec a CNPG pod). All queries are against
|
||||
the single `edge` table.
|
||||
|
||||
```sql
|
||||
-- Everything talking to a namespace (inbound), most-active first
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue