Files
net-kingdom/sso-mfa/k8s/network-policies/netpol-databases.yaml
Bernd Worsch 6d25d088d7 feat(sso-mfa): T02/T03 live apply — age-encrypted secrets, CNPG cluster (NK-WP-0001-T02/T03)
- Add encrypt-secrets.sh / decrypt-secrets.sh: age-based secrets workflow
  replaces KeePassXC dependency; encrypted .env.age files committed to repo
- Add bootstrap/secrets.enc/: all component secrets encrypted to age pubkey
- Fix .gitignore: allow secrets.enc/**/*.age while blocking plaintext
- Fix verify-t02.sh: update netpol names for Authelia+LLDAP+KeyCape stack
- Fix verify-t03.sh: remove keycloak_db/role checks; fix ((PASS++)) set-e bug
- Update postgresql/cluster.yaml: drop keycloak_db, bootstrap privacyidea_db only
- Update postgresql/create-secrets.sh: remove keycloak secret
- Fix netpol-databases.yaml: add port 8000 for CNPG instance manager HTTP API
- T02 COMPLETE: namespaces, network policies, cert-manager issuers applied
- T03 COMPLETE: CNPG operator installed, net-kingdom-pg cluster healthy

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-20 02:57:41 +00:00

139 lines
4.2 KiB
YAML

# NetworkPolicies for the databases namespace (PostgreSQL via CloudNativePG)
#
# Allowed paths:
# INGRESS: sso (Keycloak) → PostgreSQL :5432
# INGRESS: mfa (privacyIDEA) → PostgreSQL :5432
# EGRESS: all pods → kube-dns :53 (needed by CloudNativePG operator probes)
#
# Everything else is denied — in particular, no direct internet egress.
# CloudNativePG operator itself runs in its own namespace (cnpg-system) and
# needs access to the cluster API, not to the database port from here.
# ── Default deny all ingress and egress ──────────────────────────────────────
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
name: default-deny-all
namespace: databases
spec:
podSelector: {}
policyTypes:
- Ingress
- Egress
---
# ── Allow ingress from Keycloak ──────────────────────────────────────────────
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
name: allow-ingress-from-keycloak
namespace: databases
spec:
podSelector:
matchLabels:
# CloudNativePG sets cnpg.io/cluster=<cluster-name> on postgres pods.
# Adjust the cluster name to match your CloudNativePG Cluster CR name.
cnpg.io/cluster: net-kingdom-pg
policyTypes:
- Ingress
ingress:
- from:
- namespaceSelector:
matchLabels:
net-kingdom/component: sso
podSelector:
matchLabels:
app.kubernetes.io/name: keycloak
ports:
- port: 5432
protocol: TCP
---
# ── Allow ingress from privacyIDEA ───────────────────────────────────────────
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
name: allow-ingress-from-privacyidea
namespace: databases
spec:
podSelector:
matchLabels:
cnpg.io/cluster: net-kingdom-pg
policyTypes:
- Ingress
ingress:
- from:
- namespaceSelector:
matchLabels:
net-kingdom/component: mfa
podSelector:
matchLabels:
app.kubernetes.io/name: privacyidea
ports:
- port: 5432
protocol: TCP
---
# ── Allow ingress from CloudNativePG operator ────────────────────────────────
# The CNPG operator (in cnpg-system) manages the cluster and performs health
# probes. Without this, operator reconciliation fails.
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
name: allow-ingress-from-cnpg-operator
namespace: databases
spec:
podSelector:
matchLabels:
cnpg.io/cluster: net-kingdom-pg
policyTypes:
- Ingress
ingress:
- from:
- namespaceSelector:
matchLabels:
kubernetes.io/metadata.name: cnpg-system
ports:
- port: 5432
protocol: TCP
- port: 8000 # CloudNativePG instance manager HTTP API (used for status extraction)
protocol: TCP
- port: 9187 # CloudNativePG metrics exporter
protocol: TCP
---
# ── Allow egress DNS (all pods) ──────────────────────────────────────────────
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
name: allow-egress-dns
namespace: databases
spec:
podSelector: {}
policyTypes:
- Egress
egress:
- to:
- namespaceSelector:
matchLabels:
kubernetes.io/metadata.name: kube-system
ports:
- port: 53
protocol: UDP
- port: 53
protocol: TCP
---
# ── Allow egress to K8s API (CNPG operator needs it from the pods) ───────────
# CloudNativePG instance pods post status updates to the API server.
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
name: allow-egress-kube-api
namespace: databases
spec:
podSelector:
matchLabels:
cnpg.io/cluster: net-kingdom-pg
policyTypes:
- Egress
egress:
- ports:
- port: 6443
protocol: TCP