summary refs log tree commit diff
path: root/pkgs/servers
diff options
context:
space:
mode:
authortalyz <kim.lindberger@gmail.com>2020-10-26 15:33:57 +0100
committertalyz <kim.lindberger@gmail.com>2020-10-29 12:47:10 +0100
commit89e83833af35bd0ec3fdc65c435358a676a41d89 (patch)
treec20f0b9e9d9ffb409d96a55aaeb6dc47c6dca420 /pkgs/servers
parentd1d3c86c70cad38944f50f7be544326133fff292 (diff)
downloadnixpkgs-89e83833af35bd0ec3fdc65c435358a676a41d89.tar
nixpkgs-89e83833af35bd0ec3fdc65c435358a676a41d89.tar.gz
nixpkgs-89e83833af35bd0ec3fdc65c435358a676a41d89.tar.bz2
nixpkgs-89e83833af35bd0ec3fdc65c435358a676a41d89.tar.lz
nixpkgs-89e83833af35bd0ec3fdc65c435358a676a41d89.tar.xz
nixpkgs-89e83833af35bd0ec3fdc65c435358a676a41d89.tar.zst
nixpkgs-89e83833af35bd0ec3fdc65c435358a676a41d89.zip
nixos/keycloak: Add support for MySQL and external DBs with SSL
- Add support for using MySQL as an option to PostgreSQL.
- Enable connecting to external DBs with SSL
- Add a database port config option
Diffstat (limited to 'pkgs/servers')
-rw-r--r--pkgs/servers/keycloak/default.nix23
1 files changed, 14 insertions, 9 deletions
diff --git a/pkgs/servers/keycloak/default.nix b/pkgs/servers/keycloak/default.nix
index 95935ce8f8a..67d3d9bd45a 100644
--- a/pkgs/servers/keycloak/default.nix
+++ b/pkgs/servers/keycloak/default.nix
@@ -1,11 +1,11 @@
-{ stdenv, fetchzip, makeWrapper, jre, writeText, nixosTests
-, postgresql_jdbc ? null
+{ stdenv, lib, fetchzip, makeWrapper, jre, writeText, nixosTests
+, postgresql_jdbc ? null, mysql_jdbc ? null
 }:
 
 let
   mkModuleXml = name: jarFile: writeText "module.xml" ''
     <?xml version="1.0" ?>
-    <module xmlns="urn:jboss:module:1.3" name="org.${name}">
+    <module xmlns="urn:jboss:module:1.3" name="${name}">
         <resources>
             <resource-root path="${jarFile}"/>
         </resources>
@@ -33,17 +33,22 @@ stdenv.mkDerivation rec {
 
     rm -rf $out/bin/*.{ps1,bat}
 
-    module_path=$out/modules/system/layers/keycloak/org
+    module_path=$out/modules/system/layers/keycloak
     if ! [[ -d $module_path ]]; then
         echo "The module path $module_path not found!"
         exit 1
     fi
 
-    ${if postgresql_jdbc != null then ''
-      mkdir -p $module_path/postgresql/main
-      ln -s ${postgresql_jdbc}/share/java/postgresql-jdbc.jar $module_path/postgresql/main
-      ln -s ${mkModuleXml "postgresql" "postgresql-jdbc.jar"} $module_path/postgresql/main/module.xml
-    '' else ""}
+    ${lib.optionalString (postgresql_jdbc != null) ''
+      mkdir -p $module_path/org/postgresql/main
+      ln -s ${postgresql_jdbc}/share/java/postgresql-jdbc.jar $module_path/org/postgresql/main/
+      ln -s ${mkModuleXml "org.postgresql" "postgresql-jdbc.jar"} $module_path/org/postgresql/main/module.xml
+    ''}
+    ${lib.optionalString (mysql_jdbc != null) ''
+      mkdir -p $module_path/com/mysql/main
+      ln -s ${mysql_jdbc}/share/java/mysql-connector-java.jar $module_path/com/mysql/main/
+      ln -s ${mkModuleXml "com.mysql" "mysql-connector-java.jar"} $module_path/com/mysql/main/module.xml
+    ''}
 
     wrapProgram $out/bin/standalone.sh --set JAVA_HOME ${jre}
     wrapProgram $out/bin/add-user-keycloak.sh --set JAVA_HOME ${jre}