mirror of
https://github.com/auricom/home-cluster.git
synced 2025-09-17 18:24:14 +02:00
feat: windmill
This commit is contained in:
@@ -1,6 +1,4 @@
|
|||||||
---
|
---
|
||||||
# Genereate client_secret
|
|
||||||
# https://www.authelia.com/integration/openid-connect/frequently-asked-questions/#how-do-i-generate-a-client-identifier-or-client-secret
|
|
||||||
authentication_backend:
|
authentication_backend:
|
||||||
ldap:
|
ldap:
|
||||||
address: ldap://lldap.default.svc.cluster.local:5389
|
address: ldap://lldap.default.svc.cluster.local:5389
|
||||||
@@ -82,6 +80,8 @@ identity_providers:
|
|||||||
endpoints: [authorization, token, revocation, introspection]
|
endpoints: [authorization, token, revocation, introspection]
|
||||||
allowed_origins_from_client_redirect_uris: true
|
allowed_origins_from_client_redirect_uris: true
|
||||||
clients:
|
clients:
|
||||||
|
# Genereate client_secret
|
||||||
|
# https://www.authelia.com/integration/openid-connect/frequently-asked-questions/#how-do-i-generate-a-client-identifier-or-client-secret
|
||||||
- client_id: freshrss
|
- client_id: freshrss
|
||||||
client_name: freshrss
|
client_name: freshrss
|
||||||
client_secret: "$${FRESHRSS_OAUTH_DIGEST}"
|
client_secret: "$${FRESHRSS_OAUTH_DIGEST}"
|
||||||
@@ -151,3 +151,10 @@ identity_providers:
|
|||||||
redirect_uris: ['https://pgadmin.${SECRET_EXTERNAL_DOMAIN}/oauth2/authorize']
|
redirect_uris: ['https://pgadmin.${SECRET_EXTERNAL_DOMAIN}/oauth2/authorize']
|
||||||
userinfo_signed_response_alg: none
|
userinfo_signed_response_alg: none
|
||||||
token_endpoint_auth_method: client_secret_basic
|
token_endpoint_auth_method: client_secret_basic
|
||||||
|
- client_id: windmill
|
||||||
|
client_name: Windmill
|
||||||
|
client_secret: '$${WINDMILL_OAUTH_CLIENT_SECRET}'
|
||||||
|
authorization_policy: 'two_factor'
|
||||||
|
redirect_uris: ['https://windmill.${SECRET_EXTERNAL_DOMAIN}/user/login_callback/authelia']
|
||||||
|
scopes: [openid, profile, groups, email]
|
||||||
|
userinfo_signed_response_alg: none
|
||||||
|
@@ -43,6 +43,8 @@ spec:
|
|||||||
PAPERLESS_OAUTH_DIGEST: "{{ .OUTLINE_OAUTH_DIGEST }}"
|
PAPERLESS_OAUTH_DIGEST: "{{ .OUTLINE_OAUTH_DIGEST }}"
|
||||||
KOMGA_OAUTH_CLIENT_SECRET: "{{ .OUTLINE_OAUTH_CLIENT_SECRET }}"
|
KOMGA_OAUTH_CLIENT_SECRET: "{{ .OUTLINE_OAUTH_CLIENT_SECRET }}"
|
||||||
KOMGA_OAUTH_DIGEST: "{{ .OUTLINE_OAUTH_DIGEST }}"
|
KOMGA_OAUTH_DIGEST: "{{ .OUTLINE_OAUTH_DIGEST }}"
|
||||||
|
WINDMILL_OAUTH_CLIENT_SECRET: "{{ .WINDMILL_OAUTH_CLIENT_SECRET }}"
|
||||||
|
WINDMILL_OAUTH_DIGEST: "{{ .WINDMILL_OAUTH_DIGEST }}"
|
||||||
SECRET_PUBLIC_DOMAIN: "{{ .SECRET_PUBLIC_DOMAIN }}"
|
SECRET_PUBLIC_DOMAIN: "{{ .SECRET_PUBLIC_DOMAIN }}"
|
||||||
# Postgres Init
|
# Postgres Init
|
||||||
INIT_POSTGRES_DBNAME: *dbName
|
INIT_POSTGRES_DBNAME: *dbName
|
||||||
|
@@ -56,6 +56,7 @@ resources:
|
|||||||
- ./unifi/ks.yaml
|
- ./unifi/ks.yaml
|
||||||
- ./vaultwarden/ks.yaml
|
- ./vaultwarden/ks.yaml
|
||||||
- ./vikunja/ks.yaml
|
- ./vikunja/ks.yaml
|
||||||
|
- ./windmill/ks.yaml
|
||||||
- ./zigbee2mqtt/ks.yaml
|
- ./zigbee2mqtt/ks.yaml
|
||||||
- ./zwave-js-ui/ks.yaml
|
- ./zwave-js-ui/ks.yaml
|
||||||
# Default resources
|
# Default resources
|
||||||
|
@@ -10,3 +10,8 @@ configs:
|
|||||||
title_template: "KRESUS"
|
title_template: "KRESUS"
|
||||||
urls:
|
urls:
|
||||||
- !env_var PUSHOVER_KRESUS
|
- !env_var PUSHOVER_KRESUS
|
||||||
|
windmill@mailrise.home.arpa:
|
||||||
|
mailrise:
|
||||||
|
title_template: "WINDMILL"
|
||||||
|
urls:
|
||||||
|
- !env_var PUSHOVER_WINDMILL
|
||||||
|
29
kubernetes/apps/default/windmill/app/externalsecret.yaml
Normal file
29
kubernetes/apps/default/windmill/app/externalsecret.yaml
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://kubernetes-schemas.devbu.io/external-secrets.io/externalsecret_v1beta1.json
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ExternalSecret
|
||||||
|
metadata:
|
||||||
|
name: windmill
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
secretStoreRef:
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
name: onepassword-connect
|
||||||
|
target:
|
||||||
|
name: windmill-secret
|
||||||
|
template:
|
||||||
|
engineVersion: v2
|
||||||
|
data:
|
||||||
|
# App
|
||||||
|
WINDMILL_POSTGRES_URL: "postgres://{{ .WINDMILL__POSTGRES_USER }}:{{ .WINDMILL__POSTGRES_PASS }}@postgres16-rw.database.svc.cluster.local/windmill"
|
||||||
|
# Postgres Init
|
||||||
|
INIT_POSTGRES_DBNAME: windmill
|
||||||
|
INIT_POSTGRES_HOST: postgres16-rw.database.svc.cluster.local
|
||||||
|
INIT_POSTGRES_USER: "{{ .WINDMILL__POSTGRES_USER }}"
|
||||||
|
INIT_POSTGRES_PASS: "{{ .WINDMILL__POSTGRES_PASS }}"
|
||||||
|
INIT_POSTGRES_SUPER_PASS: "{{ .POSTGRES_SUPER_PASS }}"
|
||||||
|
dataFrom:
|
||||||
|
- extract:
|
||||||
|
key: cloudnative-pg
|
||||||
|
- extract:
|
||||||
|
key: windmill
|
97
kubernetes/apps/default/windmill/app/helmrelease.yaml
Normal file
97
kubernetes/apps/default/windmill/app/helmrelease.yaml
Normal file
@@ -0,0 +1,97 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://kubernetes-schemas.pages.dev/helm.toolkit.fluxcd.io/helmrelease_v2beta2.json
|
||||||
|
apiVersion: helm.toolkit.fluxcd.io/v2
|
||||||
|
kind: HelmRelease
|
||||||
|
metadata:
|
||||||
|
name: &app windmill
|
||||||
|
spec:
|
||||||
|
interval: 30m
|
||||||
|
chart:
|
||||||
|
spec:
|
||||||
|
chart: windmill
|
||||||
|
version: 2.0.234
|
||||||
|
sourceRef:
|
||||||
|
kind: HelmRepository
|
||||||
|
name: windmill
|
||||||
|
namespace: flux-system
|
||||||
|
install:
|
||||||
|
remediation:
|
||||||
|
retries: 3
|
||||||
|
upgrade:
|
||||||
|
cleanupOnFail: true
|
||||||
|
remediation:
|
||||||
|
strategy: rollback
|
||||||
|
retries: 3
|
||||||
|
uninstall:
|
||||||
|
keepHistory: false
|
||||||
|
values:
|
||||||
|
windmill:
|
||||||
|
app:
|
||||||
|
annotations:
|
||||||
|
reloader.stakater.com/auto: "true"
|
||||||
|
initContainers:
|
||||||
|
- name: init-db
|
||||||
|
image: ghcr.io/onedr0p/postgres-init:16
|
||||||
|
envFrom:
|
||||||
|
- secretRef:
|
||||||
|
name: &secret windmill-secret
|
||||||
|
- name: init-grants
|
||||||
|
image: ghcr.io/onedr0p/postgres-init:16
|
||||||
|
command:
|
||||||
|
- /bin/bash
|
||||||
|
- -c
|
||||||
|
- |
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -o errexit
|
||||||
|
set -o nounset
|
||||||
|
|
||||||
|
/var/run/grants.sh
|
||||||
|
envFrom:
|
||||||
|
- secretRef:
|
||||||
|
name: *secret
|
||||||
|
volumeMounts:
|
||||||
|
- name: grants
|
||||||
|
readOnly: true
|
||||||
|
subPath: grants.sh
|
||||||
|
mountPath: /var/run/grants.sh
|
||||||
|
volumes:
|
||||||
|
- name: grants
|
||||||
|
configMap:
|
||||||
|
name: windmill-grants
|
||||||
|
defaultMode: 509
|
||||||
|
baseDomain: &host "windmill.${SECRET_EXTERNAL_DOMAIN}"
|
||||||
|
baseProtocol: https
|
||||||
|
appReplicas: 1
|
||||||
|
lspReplicas: 1
|
||||||
|
multiplayerReplicas: 1
|
||||||
|
workerGroups:
|
||||||
|
- name: default
|
||||||
|
replicas: 2
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
memory: 1028Mi
|
||||||
|
cpu: 500m
|
||||||
|
limits:
|
||||||
|
memory: 2048Mi
|
||||||
|
- name: native
|
||||||
|
replicas: 1
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
memory: 128Mi
|
||||||
|
cpu: 100m
|
||||||
|
limits:
|
||||||
|
memory: 256Mi
|
||||||
|
ingress:
|
||||||
|
enabled: true
|
||||||
|
className: nginx
|
||||||
|
tls:
|
||||||
|
- hosts:
|
||||||
|
- *host
|
||||||
|
postgresql:
|
||||||
|
enabled: false
|
||||||
|
valuesFrom:
|
||||||
|
- kind: Secret
|
||||||
|
name: *secret
|
||||||
|
valuesKey: WINDMILL_POSTGRES_URL
|
||||||
|
targetPath: windmill.databaseUrl
|
17
kubernetes/apps/default/windmill/app/kustomization.yaml
Normal file
17
kubernetes/apps/default/windmill/app/kustomization.yaml
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://json.schemastore.org/kustomization
|
||||||
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
|
kind: Kustomization
|
||||||
|
namespace: default
|
||||||
|
resources:
|
||||||
|
- ./externalsecret.yaml
|
||||||
|
- ./helmrelease.yaml
|
||||||
|
- ../../../../templates/gatus/guarded
|
||||||
|
configMapGenerator:
|
||||||
|
- name: windmill-grants
|
||||||
|
files:
|
||||||
|
- ./scripts/grants.sh
|
||||||
|
generatorOptions:
|
||||||
|
disableNameSuffixHash: true
|
||||||
|
annotations:
|
||||||
|
kustomize.toolkit.fluxcd.io/substitute: disabled
|
60
kubernetes/apps/default/windmill/app/scripts/grants.sh
Normal file
60
kubernetes/apps/default/windmill/app/scripts/grants.sh
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
export INIT_POSTGRES_SUPER_USER=${INIT_POSTGRES_SUPER_USER:-postgres}
|
||||||
|
export INIT_POSTGRES_PORT=${INIT_POSTGRES_PORT:-5432}
|
||||||
|
|
||||||
|
if [[ -z "${INIT_POSTGRES_HOST}" ||
|
||||||
|
-z "${INIT_POSTGRES_SUPER_PASS}" ||
|
||||||
|
-z "${INIT_POSTGRES_USER}" ||
|
||||||
|
-z "${INIT_POSTGRES_PASS}" ||
|
||||||
|
-z "${INIT_POSTGRES_DBNAME}"
|
||||||
|
]]; then
|
||||||
|
printf "\e[1;32m%-6s\e[m\n" "Invalid configuration - missing a required environment variable"
|
||||||
|
[[ -z "${INIT_POSTGRES_HOST}" ]] && printf "\e[1;32m%-6s\e[m\n" "INIT_POSTGRES_HOST: unset"
|
||||||
|
[[ -z "${INIT_POSTGRES_SUPER_PASS}" ]] && printf "\e[1;32m%-6s\e[m\n" "INIT_POSTGRES_SUPER_PASS: unset"
|
||||||
|
[[ -z "${INIT_POSTGRES_USER}" ]] && printf "\e[1;32m%-6s\e[m\n" "INIT_POSTGRES_USER: unset"
|
||||||
|
[[ -z "${INIT_POSTGRES_PASS}" ]] && printf "\e[1;32m%-6s\e[m\n" "INIT_POSTGRES_PASS: unset"
|
||||||
|
[[ -z "${INIT_POSTGRES_DBNAME}" ]] && printf "\e[1;32m%-6s\e[m\n" "INIT_POSTGRES_DBNAME: unset"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# These env are for the psql CLI
|
||||||
|
export PGHOST="${INIT_POSTGRES_HOST}"
|
||||||
|
export PGUSER="${INIT_POSTGRES_SUPER_USER}"
|
||||||
|
export PGPASSWORD="${INIT_POSTGRES_SUPER_PASS}"
|
||||||
|
export PGPORT="${INIT_POSTGRES_PORT}"
|
||||||
|
|
||||||
|
until pg_isready; do
|
||||||
|
printf "\e[1;32m%-6s\e[m\n" "Waiting for Host '${PGHOST}' on port '${PGPORT}' ..."
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
|
||||||
|
for dbname in ${INIT_POSTGRES_DBNAME}; do
|
||||||
|
printf "\e[1;32m%-6s\e[m\n" "Update User Privileges on Database ..."
|
||||||
|
psql --dbname ${dbname} -c "
|
||||||
|
DO \$\$
|
||||||
|
BEGIN
|
||||||
|
IF NOT EXISTS (SELECT 1 FROM pg_roles WHERE rolname = 'windmill_user') THEN
|
||||||
|
CREATE ROLE windmill_user;
|
||||||
|
END IF;
|
||||||
|
END
|
||||||
|
\$\$;
|
||||||
|
|
||||||
|
DO \$\$
|
||||||
|
BEGIN
|
||||||
|
IF NOT EXISTS (SELECT 1 FROM pg_roles WHERE rolname = 'windmill_admin') THEN
|
||||||
|
CREATE ROLE windmill_admin WITH BYPASSRLS;
|
||||||
|
END IF;
|
||||||
|
END
|
||||||
|
\$\$;
|
||||||
|
|
||||||
|
GRANT ALL ON ALL TABLES IN SCHEMA public TO windmill_user;
|
||||||
|
GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO windmill_user;
|
||||||
|
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON TABLES TO windmill_user;
|
||||||
|
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON SEQUENCES TO windmill_user;
|
||||||
|
GRANT windmill_user TO windmill_admin;
|
||||||
|
GRANT windmill_admin TO ${INIT_POSTGRES_USER};
|
||||||
|
GRANT windmill_user TO ${INIT_POSTGRES_USER};
|
||||||
|
GRANT USAGE ON SCHEMA public TO windmill_admin;
|
||||||
|
GRANT USAGE ON SCHEMA public TO windmill_user;"
|
||||||
|
done
|
27
kubernetes/apps/default/windmill/ks.yaml
Normal file
27
kubernetes/apps/default/windmill/ks.yaml
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://kubernetes-schemas.devbu.io/kustomize.toolkit.fluxcd.io/kustomization_v1.json
|
||||||
|
apiVersion: kustomize.toolkit.fluxcd.io/v1
|
||||||
|
kind: Kustomization
|
||||||
|
metadata:
|
||||||
|
name: &app windmill
|
||||||
|
namespace: flux-system
|
||||||
|
spec:
|
||||||
|
targetNamespace: default
|
||||||
|
commonMetadata:
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/name: *app
|
||||||
|
dependsOn:
|
||||||
|
- name: external-secrets-stores
|
||||||
|
path: ./kubernetes/apps/default/windmill/app
|
||||||
|
prune: true
|
||||||
|
sourceRef:
|
||||||
|
kind: GitRepository
|
||||||
|
name: home-ops-kubernetes
|
||||||
|
wait: false
|
||||||
|
interval: 30m
|
||||||
|
retryInterval: 1m
|
||||||
|
timeout: 5m
|
||||||
|
postBuild:
|
||||||
|
substitute:
|
||||||
|
APP: *app
|
||||||
|
GATUS_SUBDOMAIN: sh
|
@@ -32,4 +32,5 @@ resources:
|
|||||||
- ./stakater.yaml
|
- ./stakater.yaml
|
||||||
- ./stevehipwell.yaml
|
- ./stevehipwell.yaml
|
||||||
- ./vector.yaml
|
- ./vector.yaml
|
||||||
|
- ./windmill.yaml
|
||||||
- ./xenitab.yaml
|
- ./xenitab.yaml
|
||||||
|
10
kubernetes/flux/repositories/helm/windmill.yaml
Normal file
10
kubernetes/flux/repositories/helm/windmill.yaml
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
---
|
||||||
|
# yaml-language-server: $schema=https://kubernetes-schemas.pages.dev/source.toolkit.fluxcd.io/helmrepository_v1beta2.json
|
||||||
|
apiVersion: source.toolkit.fluxcd.io/v1
|
||||||
|
kind: HelmRepository
|
||||||
|
metadata:
|
||||||
|
name: windmill
|
||||||
|
namespace: flux-system
|
||||||
|
spec:
|
||||||
|
interval: 2h
|
||||||
|
url: https://windmill-labs.github.io/windmill-helm-charts/
|
Reference in New Issue
Block a user