keycloak: apply realm smtp via api

This commit is contained in:
Brad Stein 2026-01-02 04:03:27 -03:00
parent 9fa081ca36
commit 46d4ab6dc8

View File

@ -2,7 +2,7 @@
apiVersion: batch/v1 apiVersion: batch/v1
kind: Job kind: Job
metadata: metadata:
name: keycloak-realm-settings-5 name: keycloak-realm-settings-6
namespace: sso namespace: sso
spec: spec:
backoffLimit: 2 backoffLimit: 2
@ -21,7 +21,7 @@ spec:
restartPolicy: OnFailure restartPolicy: OnFailure
containers: containers:
- name: configure - name: configure
image: quay.io/keycloak/keycloak:26.0.7 image: python:3.11-alpine
env: env:
- name: KEYCLOAK_SERVER - name: KEYCLOAK_SERVER
value: http://keycloak.sso.svc.cluster.local value: http://keycloak.sso.svc.cluster.local
@ -53,15 +53,60 @@ spec:
args: args:
- | - |
set -euo pipefail set -euo pipefail
/opt/keycloak/bin/kcadm.sh config credentials \ python - <<'PY'
--server "${KEYCLOAK_SERVER}" \ import json
--realm master \ import os
--user "${KEYCLOAK_ADMIN_USER}" \ import urllib.parse
--password "${KEYCLOAK_ADMIN_PASSWORD}" import urllib.request
smtp_json="$(cat <<EOF
{"host":"${KEYCLOAK_SMTP_HOST}","port":"${KEYCLOAK_SMTP_PORT}","from":"${KEYCLOAK_SMTP_FROM}","fromDisplayName":"${KEYCLOAK_SMTP_FROM_NAME}","replyTo":"${KEYCLOAK_SMTP_REPLY_TO}","replyToDisplayName":"${KEYCLOAK_SMTP_REPLY_TO_NAME}","auth":"false","starttls":"false","ssl":"false"} base_url = os.environ["KEYCLOAK_SERVER"].rstrip("/")
EOF realm = os.environ["KEYCLOAK_REALM"]
)" admin_user = os.environ["KEYCLOAK_ADMIN_USER"]
/opt/keycloak/bin/kcadm.sh update "realms/${KEYCLOAK_REALM}" \ admin_password = os.environ["KEYCLOAK_ADMIN_PASSWORD"]
-s resetPasswordAllowed=true \
-s "smtpServer=${smtp_json}" token_data = urllib.parse.urlencode(
{
"grant_type": "password",
"client_id": "admin-cli",
"username": admin_user,
"password": admin_password,
}
).encode()
token_req = urllib.request.Request(
f"{base_url}/realms/master/protocol/openid-connect/token",
data=token_data,
headers={"Content-Type": "application/x-www-form-urlencoded"},
method="POST",
)
with urllib.request.urlopen(token_req, timeout=10) as resp:
token_body = json.loads(resp.read().decode())
access_token = token_body["access_token"]
payload = {
"resetPasswordAllowed": True,
"smtpServer": {
"host": os.environ["KEYCLOAK_SMTP_HOST"],
"port": os.environ["KEYCLOAK_SMTP_PORT"],
"from": os.environ["KEYCLOAK_SMTP_FROM"],
"fromDisplayName": os.environ["KEYCLOAK_SMTP_FROM_NAME"],
"replyTo": os.environ["KEYCLOAK_SMTP_REPLY_TO"],
"replyToDisplayName": os.environ["KEYCLOAK_SMTP_REPLY_TO_NAME"],
"auth": "false",
"starttls": "false",
"ssl": "false",
},
}
update_req = urllib.request.Request(
f"{base_url}/admin/realms/{realm}",
data=json.dumps(payload).encode(),
headers={
"Authorization": f"Bearer {access_token}",
"Content-Type": "application/json",
},
method="PUT",
)
with urllib.request.urlopen(update_req, timeout=10) as resp:
if resp.status not in (200, 204):
raise SystemExit(f"Unexpected response: {resp.status}")
PY