From 98973810d774dfa13f92d81ab3b42a52f3f84663 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Sat, 28 Jun 2025 14:33:33 -0400 Subject: [PATCH 01/12] Add back keycloak following changes to latest keycloak release --- ct/keycloak.sh | 72 +++++++++++++++++++++++++++++ install/keycloak-install.sh | 90 +++++++++++++++++++++++++++++++++++++ 2 files changed, 162 insertions(+) create mode 100644 ct/keycloak.sh create mode 100644 install/keycloak-install.sh diff --git a/ct/keycloak.sh b/ct/keycloak.sh new file mode 100644 index 00000000..349fadb7 --- /dev/null +++ b/ct/keycloak.sh @@ -0,0 +1,72 @@ +#!/usr/bin/env bash +source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func) +# Copyright (c) 2021-2025 tteck +# Author: tteck (tteckster) | Co-Author: remz1337 +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://www.keycloak.org/ + +APP="Keycloak" +var_tags="${var_tags:-access-management}" +var_cpu="${var_cpu:-2}" +var_ram="${var_ram:-2048}" +var_disk="${var_disk:-4}" +var_os="${var_os:-debian}" +var_version="${var_version:-12}" +var_unprivileged="${var_unprivileged:-1}" +var_postfix_sat="${var_postfix_sat:-yes}" + +header_info "$APP" +variables +color +catch_errors + +function update_script() { + header_info + check_container_storage + check_container_resources + if [[ ! -f /etc/systemd/system/keycloak.service ]]; then + msg_error "No ${APP} Installation Found!" + exit + fi + + msg_info "Stopping ${APP}" + systemctl stop keycloak + msg_ok "Stopped ${APP}" + + msg_info "Updating packages" + apt-get update &>/dev/null + apt-get -y upgrade &>/dev/null + msg_ok "Updated packages" + + RELEASE=$(curl -fsSL https://api.github.com/repos/keycloak/keycloak/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }') + msg_info "Updating ${APP} to v$RELEASE" + cd /opt + wget -q https://github.com/keycloak/keycloak/releases/download/$RELEASE/keycloak-$RELEASE.tar.gz + mv keycloak keycloak.old + tar -xzf keycloak-$RELEASE.tar.gz + tar -czf keycloak_conf_backup.tar.gz keycloak.old/conf + mv keycloak_conf_backup.tar.gz keycloak-$RELEASE/conf + cp -r keycloak.old/providers keycloak-$RELEASE + cp -r keycloak.old/themes keycloak-$RELEASE + mv keycloak-$RELEASE keycloak + rm keycloak-$RELEASE.tar.gz + rm -rf keycloak.old + msg_ok "Updated ${APP} LXC" + + msg_info "Restating Keycloak" + systemctl restart keycloak + msg_ok "Restated Keycloak" + exit +} + +start +build_container +description + +msg_ok "Completed Successfully!\n" +echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}" +echo -e "${INFO}${YW} Access it using the following URL:${CL}" +echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:8080/admin${CL}" +echo -e "${TAB}${GN}Temporary admin user:${BL}tmpadm${CL}" +echo -e "${TAB}${GN}Temporary admin password:${BL}admin123${CL}" +echo -e "${INFO}${YW} If you modified configurations files in `conf/`: Re-apply your changes to those files, otherwise leave them unchanged.${CL}" diff --git a/install/keycloak-install.sh b/install/keycloak-install.sh new file mode 100644 index 00000000..a0bf44bb --- /dev/null +++ b/install/keycloak-install.sh @@ -0,0 +1,90 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2025 community-scripts ORG +# Author: tteck (tteckster) | Co-Authors: Slaviša Arežina (tremor021), remz1337 +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://github.com/keycloak/keycloak + +source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" +color +verb_ip6 +catch_errors +setting_up_container +network_check +update_os + +msg_info "Installing Dependencies (Patience)" +$STD apt-get install -y curl +$STD apt-get install -y sudo +$STD apt-get install -y mc +$STD apt-get install -y ca-certificates-java +msg_ok "Installed Dependencies" + +msg_info "Installing OpenJDK" +$STD apt install wget lsb-release -y +$STD wget https://packages.microsoft.com/config/debian/$(lsb_release -rs)/packages-microsoft-prod.deb -O packages-microsoft-prod.deb +$STD dpkg -i packages-microsoft-prod.deb +$STD apt update +$STD apt install -y msopenjdk-21 +sudo update-java-alternatives --set msopenjdk-21-amd64 +rm packages-microsoft-prod.deb +msg_ok "Installed OpenJDK" + +msg_info "Installing PostgreSQL" +$STD apt-get install -y postgresql +DB_NAME="keycloak" +DB_USER="keycloak" +DB_PASS="$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13)" +$STD sudo -u postgres psql -c "CREATE USER $DB_USER WITH PASSWORD '$DB_PASS';" +$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCODING 'UTF8';" +$STD sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE $DB_NAME TO $DB_USER;" +msg_ok "Installed PostgreSQL" + +msg_info "Installing Keycloak" +temp_file=$(mktemp) +RELEASE=$(curl -fsSL https://api.github.com/repos/keycloak/keycloak/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }') +curl -fsSL "https://github.com/keycloak/keycloak/releases/download/$RELEASE/keycloak-$RELEASE.tar.gz" -o "$temp_file" +tar xzf $temp_file +mv keycloak-$RELEASE /opt/keycloak +msg_ok "Installed Keycloak" + +msg_info "Creating Service" +cat </etc/systemd/system/keycloak.service +[Unit] +Description=Keycloak Service +Requires=network.target +After=syslog.target network-online.target + +[Service] +Type=idle +User=root +WorkingDirectory=/opt/keycloak +ExecStart=/opt/keycloak/bin/kc.sh start +ExecStop=/opt/keycloak/bin/kc.sh stop +Restart=always +RestartSec=3 +Environment="JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64" +Environment="KC_DB=postgres" +Environment="KC_DB_USERNAME=$DB_USER" +Environment="KC_DB_PASSWORD=$DB_PASS" +Environment="KC_HTTP_ENABLED=true" +Environment="KC_BOOTSTRAP_ADMIN_USERNAME=tmpadm" +Environment="KC_BOOTSTRAP_ADMIN_PASSWORD=admin123" +# Comment following line and uncomment the next 2 if working behind a reverse proxy +Environment="KC_HOSTNAME_STRICT=false" +#Environment="KC_HOSTNAME=keycloak.example.com" +#Environment="KC_PROXY_HEADERS=xforwarded" +[Install] +WantedBy=multi-user.target +EOF +systemctl enable -q --now keycloak +msg_ok "Created Service" + +motd_ssh +customize + +msg_info "Cleaning up" +rm -f $temp_file +$STD apt-get -y autoremove +$STD apt-get -y autoclean +msg_ok "Cleaned" From 45a6418d598abde7cc91af66fd479a6e53b001cf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 13:08:24 -0400 Subject: [PATCH 02/12] Temporary redirect of install urls for testing --- misc/build.func | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/misc/build.func b/misc/build.func index b75e5b38..7fd759a2 100644 --- a/misc/build.func +++ b/misc/build.func @@ -1282,7 +1282,7 @@ EOF' pct exec "$CTID" -- bash -c "apt-get update >/dev/null && apt-get install -y sudo curl mc gnupg2 >/dev/null" fi msg_ok "Customized LXC Container" - lxc-attach -n "$CTID" -- bash -c "$(curl -fsSL https://git.community-scripts.org/community-scripts/ProxmoxVED/raw/branch/main/install/$var_install.sh)" $? + lxc-attach -n "$CTID" -- bash -c "$(curl -fsSL https://raw.githubusercontent.com/remz1337/ProxmoxVED/raw/branch/pr-keycloak/install/$var_install.sh)" $? } From c1bdeb065301d7eceae1900a9b35a71ebc271282 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 13:09:38 -0400 Subject: [PATCH 03/12] Implement feedback from PR review --- ct/keycloak.sh | 72 ++++++++++++++++++------------------- install/keycloak-install.sh | 47 ++++++++++++------------ 2 files changed, 61 insertions(+), 58 deletions(-) diff --git a/ct/keycloak.sh b/ct/keycloak.sh index 349fadb7..6761d578 100644 --- a/ct/keycloak.sh +++ b/ct/keycloak.sh @@ -13,7 +13,6 @@ var_disk="${var_disk:-4}" var_os="${var_os:-debian}" var_version="${var_version:-12}" var_unprivileged="${var_unprivileged:-1}" -var_postfix_sat="${var_postfix_sat:-yes}" header_info "$APP" variables @@ -21,42 +20,43 @@ color catch_errors function update_script() { - header_info - check_container_storage - check_container_resources - if [[ ! -f /etc/systemd/system/keycloak.service ]]; then - msg_error "No ${APP} Installation Found!" - exit - fi - - msg_info "Stopping ${APP}" - systemctl stop keycloak - msg_ok "Stopped ${APP}" - - msg_info "Updating packages" - apt-get update &>/dev/null - apt-get -y upgrade &>/dev/null - msg_ok "Updated packages" - - RELEASE=$(curl -fsSL https://api.github.com/repos/keycloak/keycloak/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }') - msg_info "Updating ${APP} to v$RELEASE" - cd /opt - wget -q https://github.com/keycloak/keycloak/releases/download/$RELEASE/keycloak-$RELEASE.tar.gz - mv keycloak keycloak.old - tar -xzf keycloak-$RELEASE.tar.gz - tar -czf keycloak_conf_backup.tar.gz keycloak.old/conf - mv keycloak_conf_backup.tar.gz keycloak-$RELEASE/conf - cp -r keycloak.old/providers keycloak-$RELEASE - cp -r keycloak.old/themes keycloak-$RELEASE - mv keycloak-$RELEASE keycloak - rm keycloak-$RELEASE.tar.gz - rm -rf keycloak.old - msg_ok "Updated ${APP} LXC" - - msg_info "Restating Keycloak" - systemctl restart keycloak - msg_ok "Restated Keycloak" + header_info + check_container_storage + check_container_resources + if [[ ! -f /etc/systemd/system/keycloak.service ]]; then + msg_error "No ${APP} Installation Found!" exit + fi + + msg_info "Stopping ${APP}" + systemctl stop keycloak + msg_ok "Stopped ${APP}" + + msg_info "Updating packages" + apt-get update &>/dev/null + apt-get -y upgrade &>/dev/null + msg_ok "Updated packages" + + msg_info "Backup old Keycloak" + cd /opt + mv keycloak keycloak.old + tar -czf keycloak_conf_backup.tar.gz keycloak.old/conf + msg_ok "Backup done" + + fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "tarball" "latest" "/opt/keycloak" + + msg_info "Updating ${APP}" + cd /opt + mv keycloak_conf_backup.tar.gz keycloak/conf + cp -r keycloak.old/providers keycloak + cp -r keycloak.old/themes keycloak + rm -rf keycloak.old + msg_ok "Updated ${APP} LXC" + + msg_info "Restating Keycloak" + systemctl restart keycloak + msg_ok "Restated Keycloak" + exit } start diff --git a/install/keycloak-install.sh b/install/keycloak-install.sh index a0bf44bb..fd1ec809 100644 --- a/install/keycloak-install.sh +++ b/install/keycloak-install.sh @@ -14,24 +14,25 @@ network_check update_os msg_info "Installing Dependencies (Patience)" -$STD apt-get install -y curl -$STD apt-get install -y sudo -$STD apt-get install -y mc -$STD apt-get install -y ca-certificates-java +#$STD apt-get install -y ca-certificates-java msg_ok "Installed Dependencies" -msg_info "Installing OpenJDK" -$STD apt install wget lsb-release -y -$STD wget https://packages.microsoft.com/config/debian/$(lsb_release -rs)/packages-microsoft-prod.deb -O packages-microsoft-prod.deb -$STD dpkg -i packages-microsoft-prod.deb -$STD apt update -$STD apt install -y msopenjdk-21 -sudo update-java-alternatives --set msopenjdk-21-amd64 -rm packages-microsoft-prod.deb -msg_ok "Installed OpenJDK" +#msg_info "Installing OpenJDK" +#$STD apt install wget lsb-release -y +#$STD wget https://packages.microsoft.com/config/debian/$(lsb_release -rs)/packages-microsoft-prod.deb -O packages-microsoft-prod.deb +#$STD dpkg -i packages-microsoft-prod.deb +#$STD apt update +#$STD apt install -y msopenjdk-21 +#sudo update-java-alternatives --set msopenjdk-21-amd64 +#rm packages-microsoft-prod.deb +#msg_ok "Installed OpenJDK" + +JAVA_VERSION=21 setup_java + msg_info "Installing PostgreSQL" -$STD apt-get install -y postgresql +#$STD apt-get install -y postgresql +PG_VERSION=16 setup_postgresql DB_NAME="keycloak" DB_USER="keycloak" DB_PASS="$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13)" @@ -40,13 +41,15 @@ $STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCO $STD sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE $DB_NAME TO $DB_USER;" msg_ok "Installed PostgreSQL" -msg_info "Installing Keycloak" -temp_file=$(mktemp) -RELEASE=$(curl -fsSL https://api.github.com/repos/keycloak/keycloak/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }') -curl -fsSL "https://github.com/keycloak/keycloak/releases/download/$RELEASE/keycloak-$RELEASE.tar.gz" -o "$temp_file" -tar xzf $temp_file -mv keycloak-$RELEASE /opt/keycloak -msg_ok "Installed Keycloak" +fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "tarball" "latest" "/opt/keycloak" + +#msg_info "Installing Keycloak" +#temp_file=$(mktemp) +#RELEASE=$(curl -fsSL https://api.github.com/repos/keycloak/keycloak/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }') +#curl -fsSL "https://github.com/keycloak/keycloak/releases/download/$RELEASE/keycloak-$RELEASE.tar.gz" -o "$temp_file" +#tar xzf $temp_file +#mv keycloak-$RELEASE /opt/keycloak +#msg_ok "Installed Keycloak" msg_info "Creating Service" cat </etc/systemd/system/keycloak.service @@ -84,7 +87,7 @@ motd_ssh customize msg_info "Cleaning up" -rm -f $temp_file +#rm -f $temp_file $STD apt-get -y autoremove $STD apt-get -y autoclean msg_ok "Cleaned" From 28a86e6703900ee7ebe7e6fff189735061a1b22f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 13:37:14 -0400 Subject: [PATCH 04/12] Clarify config change instructions --- ct/keycloak.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/keycloak.sh b/ct/keycloak.sh index 6761d578..7ce18cd1 100644 --- a/ct/keycloak.sh +++ b/ct/keycloak.sh @@ -69,4 +69,4 @@ echo -e "${INFO}${YW} Access it using the following URL:${CL}" echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:8080/admin${CL}" echo -e "${TAB}${GN}Temporary admin user:${BL}tmpadm${CL}" echo -e "${TAB}${GN}Temporary admin password:${BL}admin123${CL}" -echo -e "${INFO}${YW} If you modified configurations files in `conf/`: Re-apply your changes to those files, otherwise leave them unchanged.${CL}" +echo -e "${INFO}${YW} If you modified ${BL}cache-ispn.xml${YW}: Re-apply your changes to the new file, otherwise leave it unchanged.${CL}" From 60ba17032d3a87a67c31ee695bfcbf00116e1199 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 14:00:42 -0400 Subject: [PATCH 05/12] Temporary redirect of url to test on my fork --- ct/keycloak.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/keycloak.sh b/ct/keycloak.sh index 7ce18cd1..e4f26d5b 100644 --- a/ct/keycloak.sh +++ b/ct/keycloak.sh @@ -1,5 +1,5 @@ #!/usr/bin/env bash -source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func) +source <(curl -fsSL https://raw.githubusercontent.com/remz1337/ProxmoxVE/pr-keycloak/misc/build.func) # Copyright (c) 2021-2025 tteck # Author: tteck (tteckster) | Co-Author: remz1337 # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE From fd87cf6c1d7a8b8a30fc52b137886f160e99aa2a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 14:08:20 -0400 Subject: [PATCH 06/12] Temporary redirect url (fix) --- misc/build.func | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/misc/build.func b/misc/build.func index 7fd759a2..ac7d163e 100644 --- a/misc/build.func +++ b/misc/build.func @@ -1282,7 +1282,7 @@ EOF' pct exec "$CTID" -- bash -c "apt-get update >/dev/null && apt-get install -y sudo curl mc gnupg2 >/dev/null" fi msg_ok "Customized LXC Container" - lxc-attach -n "$CTID" -- bash -c "$(curl -fsSL https://raw.githubusercontent.com/remz1337/ProxmoxVED/raw/branch/pr-keycloak/install/$var_install.sh)" $? + lxc-attach -n "$CTID" -- bash -c "$(curl -fsSL https://raw.githubusercontent.com/remz1337/ProxmoxVED/pr-keycloak/install/$var_install.sh)" $? } From 875b7ab140c45077b6d5fd7a677d724683314972 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 14:26:38 -0400 Subject: [PATCH 07/12] Download keycloak binaries instead of source --- install/keycloak-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/keycloak-install.sh b/install/keycloak-install.sh index fd1ec809..a990c3a9 100644 --- a/install/keycloak-install.sh +++ b/install/keycloak-install.sh @@ -41,7 +41,7 @@ $STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCO $STD sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE $DB_NAME TO $DB_USER;" msg_ok "Installed PostgreSQL" -fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "tarball" "latest" "/opt/keycloak" +fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "prebuild" "latest" "/opt/keycloak" #msg_info "Installing Keycloak" #temp_file=$(mktemp) From b080301e4059db7a32ce30503a93441769299e05 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 14:35:33 -0400 Subject: [PATCH 08/12] Add pattern to fetch function since it's a prebuilt binary --- install/keycloak-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/keycloak-install.sh b/install/keycloak-install.sh index a990c3a9..89cb51bf 100644 --- a/install/keycloak-install.sh +++ b/install/keycloak-install.sh @@ -41,7 +41,7 @@ $STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCO $STD sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE $DB_NAME TO $DB_USER;" msg_ok "Installed PostgreSQL" -fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "prebuild" "latest" "/opt/keycloak" +fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "prebuild" "latest" "/opt/keycloak" "keycloak-*.tar.gz" #msg_info "Installing Keycloak" #temp_file=$(mktemp) From 849dd9750115494a3d7175b2157f924c52c2821e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 14:46:23 -0400 Subject: [PATCH 09/12] Fix JAVA_HOME environment variable to use temurin JDK --- install/keycloak-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/keycloak-install.sh b/install/keycloak-install.sh index 89cb51bf..b7ced765 100644 --- a/install/keycloak-install.sh +++ b/install/keycloak-install.sh @@ -66,7 +66,7 @@ ExecStart=/opt/keycloak/bin/kc.sh start ExecStop=/opt/keycloak/bin/kc.sh stop Restart=always RestartSec=3 -Environment="JAVA_HOME=/usr/lib/jvm/java-21-openjdk-amd64" +Environment="JAVA_HOME=/usr/lib/jvm/temurin-21-jdk-amd64" Environment="KC_DB=postgres" Environment="KC_DB_USERNAME=$DB_USER" Environment="KC_DB_PASSWORD=$DB_PASS" From d0b68432f864d807f0e7ae91f68625ec32fd77a7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 14:49:38 -0400 Subject: [PATCH 10/12] Temporary fix url to test with my fork --- ct/keycloak.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/keycloak.sh b/ct/keycloak.sh index e4f26d5b..f28e152d 100644 --- a/ct/keycloak.sh +++ b/ct/keycloak.sh @@ -1,5 +1,5 @@ #!/usr/bin/env bash -source <(curl -fsSL https://raw.githubusercontent.com/remz1337/ProxmoxVE/pr-keycloak/misc/build.func) +source <(curl -fsSL https://raw.githubusercontent.com/remz1337/ProxmoxVED/pr-keycloak/misc/build.func) # Copyright (c) 2021-2025 tteck # Author: tteck (tteckster) | Co-Author: remz1337 # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE From c24c858562e221e3d2b834227c7e24acf4254e59 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20B=C3=A9dard-Couture?= Date: Thu, 3 Jul 2025 14:55:51 -0400 Subject: [PATCH 11/12] Fix fetch command in update path to retrieve binaries and clean up old commented code --- ct/keycloak.sh | 2 +- install/keycloak-install.sh | 31 +++---------------------------- 2 files changed, 4 insertions(+), 29 deletions(-) diff --git a/ct/keycloak.sh b/ct/keycloak.sh index f28e152d..8d897845 100644 --- a/ct/keycloak.sh +++ b/ct/keycloak.sh @@ -43,7 +43,7 @@ function update_script() { tar -czf keycloak_conf_backup.tar.gz keycloak.old/conf msg_ok "Backup done" - fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "tarball" "latest" "/opt/keycloak" + fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "prebuild" "latest" "/opt/keycloak" "keycloak-*.tar.gz" msg_info "Updating ${APP}" cd /opt diff --git a/install/keycloak-install.sh b/install/keycloak-install.sh index b7ced765..6d1deb16 100644 --- a/install/keycloak-install.sh +++ b/install/keycloak-install.sh @@ -13,44 +13,20 @@ setting_up_container network_check update_os -msg_info "Installing Dependencies (Patience)" -#$STD apt-get install -y ca-certificates-java -msg_ok "Installed Dependencies" - -#msg_info "Installing OpenJDK" -#$STD apt install wget lsb-release -y -#$STD wget https://packages.microsoft.com/config/debian/$(lsb_release -rs)/packages-microsoft-prod.deb -O packages-microsoft-prod.deb -#$STD dpkg -i packages-microsoft-prod.deb -#$STD apt update -#$STD apt install -y msopenjdk-21 -#sudo update-java-alternatives --set msopenjdk-21-amd64 -#rm packages-microsoft-prod.deb -#msg_ok "Installed OpenJDK" - JAVA_VERSION=21 setup_java - - -msg_info "Installing PostgreSQL" -#$STD apt-get install -y postgresql PG_VERSION=16 setup_postgresql + +msg_info "Configuring PostgreSQL user" DB_NAME="keycloak" DB_USER="keycloak" DB_PASS="$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13)" $STD sudo -u postgres psql -c "CREATE USER $DB_USER WITH PASSWORD '$DB_PASS';" $STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCODING 'UTF8';" $STD sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE $DB_NAME TO $DB_USER;" -msg_ok "Installed PostgreSQL" +msg_ok "Configured PostgreSQL user" fetch_and_deploy_gh_release "keycloak" "keycloak/keycloak" "prebuild" "latest" "/opt/keycloak" "keycloak-*.tar.gz" -#msg_info "Installing Keycloak" -#temp_file=$(mktemp) -#RELEASE=$(curl -fsSL https://api.github.com/repos/keycloak/keycloak/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }') -#curl -fsSL "https://github.com/keycloak/keycloak/releases/download/$RELEASE/keycloak-$RELEASE.tar.gz" -o "$temp_file" -#tar xzf $temp_file -#mv keycloak-$RELEASE /opt/keycloak -#msg_ok "Installed Keycloak" - msg_info "Creating Service" cat </etc/systemd/system/keycloak.service [Unit] @@ -87,7 +63,6 @@ motd_ssh customize msg_info "Cleaning up" -#rm -f $temp_file $STD apt-get -y autoremove $STD apt-get -y autoclean msg_ok "Cleaned" From be8e38ab372be8e5071761d7c51c0b56fe71865e Mon Sep 17 00:00:00 2001 From: GitHub Actions Date: Thu, 24 Jul 2025 07:40:14 +0000 Subject: [PATCH 12/12] Update .app files --- ct/headers/keycloak | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 ct/headers/keycloak diff --git a/ct/headers/keycloak b/ct/headers/keycloak new file mode 100644 index 00000000..0c20d751 --- /dev/null +++ b/ct/headers/keycloak @@ -0,0 +1,6 @@ + __ __ __ __ + / //_/__ __ _______/ /___ ____ _/ /__ + / ,< / _ \/ / / / ___/ / __ \/ __ `/ //_/ + / /| / __/ /_/ / /__/ / /_/ / /_/ / ,< +/_/ |_\___/\__, /\___/_/\____/\__,_/_/|_| + /____/