2022-04-27 09:35:20 +00:00
|
|
|
{ stdenv
|
|
|
|
, lib
|
|
|
|
, fetchzip
|
|
|
|
, makeWrapper
|
|
|
|
, jre
|
|
|
|
, writeText
|
|
|
|
, nixosTests
|
2022-03-30 09:31:56 +00:00
|
|
|
, callPackage
|
2022-04-27 09:35:20 +00:00
|
|
|
|
|
|
|
, confFile ? null
|
|
|
|
, plugins ? [ ]
|
2020-11-06 00:33:48 +00:00
|
|
|
}:
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
2022-04-27 09:35:20 +00:00
|
|
|
pname = "keycloak";
|
2023-04-29 16:46:19 +00:00
|
|
|
version = "20.0.5";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
src = fetchzip {
|
2022-04-27 09:35:20 +00:00
|
|
|
url = "https://github.com/keycloak/keycloak/releases/download/${version}/keycloak-${version}.zip";
|
2023-04-29 16:46:19 +00:00
|
|
|
hash = "sha256-4h3q9J1+KufMaSuzbX9qaBwXPR8zhVpxQAXDBY3uPjM=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
2022-04-27 09:35:20 +00:00
|
|
|
nativeBuildInputs = [ makeWrapper jre ];
|
|
|
|
|
2022-11-21 17:40:18 +00:00
|
|
|
patches = [
|
|
|
|
# Make home.dir and config.dir configurable through the
|
|
|
|
# KC_HOME_DIR and KC_CONF_DIR environment variables.
|
|
|
|
./config_vars.patch
|
|
|
|
];
|
|
|
|
|
2022-04-27 09:35:20 +00:00
|
|
|
buildPhase = ''
|
|
|
|
runHook preBuild
|
|
|
|
'' + lib.optionalString (confFile != null) ''
|
|
|
|
install -m 0600 ${confFile} conf/keycloak.conf
|
|
|
|
'' + ''
|
|
|
|
install_plugin() {
|
2022-09-09 14:08:57 +00:00
|
|
|
if [ -d "$1" ]; then
|
|
|
|
find "$1" -type f \( -iname \*.ear -o -iname \*.jar \) -exec install -m 0500 "{}" "providers/" \;
|
|
|
|
else
|
|
|
|
install -m 0500 "$1" "providers/"
|
|
|
|
fi
|
2022-04-27 09:35:20 +00:00
|
|
|
}
|
|
|
|
${lib.concatMapStringsSep "\n" (pl: "install_plugin ${lib.escapeShellArg pl}") plugins}
|
|
|
|
'' + ''
|
|
|
|
patchShebangs bin/kc.sh
|
2022-11-21 17:40:18 +00:00
|
|
|
export KC_HOME_DIR=$(pwd)
|
|
|
|
export KC_CONF_DIR=$(pwd)/conf
|
2022-04-27 09:35:20 +00:00
|
|
|
bin/kc.sh build
|
|
|
|
|
|
|
|
runHook postBuild
|
|
|
|
'';
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
installPhase = ''
|
2022-04-27 09:35:20 +00:00
|
|
|
runHook preInstall
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
mkdir $out
|
|
|
|
cp -r * $out
|
|
|
|
|
2022-04-27 09:35:20 +00:00
|
|
|
rm $out/bin/*.{ps1,bat}
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2022-04-27 09:35:20 +00:00
|
|
|
runHook postInstall
|
|
|
|
'';
|
|
|
|
|
|
|
|
postFixup = ''
|
|
|
|
for script in $(find $out/bin -type f -executable); do
|
|
|
|
wrapProgram "$script" --set JAVA_HOME ${jre} --prefix PATH : ${jre}/bin
|
2022-03-30 09:31:56 +00:00
|
|
|
done
|
2020-04-24 23:36:52 +00:00
|
|
|
'';
|
|
|
|
|
2022-03-30 09:31:56 +00:00
|
|
|
passthru = {
|
|
|
|
tests = nixosTests.keycloak;
|
2022-04-27 09:35:20 +00:00
|
|
|
plugins = callPackage ./all-plugins.nix { };
|
|
|
|
enabledPlugins = plugins;
|
2022-03-30 09:31:56 +00:00
|
|
|
};
|
2020-11-06 00:33:48 +00:00
|
|
|
|
2021-01-15 22:18:51 +00:00
|
|
|
meta = with lib; {
|
2022-04-27 09:35:20 +00:00
|
|
|
homepage = "https://www.keycloak.org/";
|
2020-04-24 23:36:52 +00:00
|
|
|
description = "Identity and access management for modern applications and services";
|
2022-06-16 17:23:12 +00:00
|
|
|
sourceProvenance = with sourceTypes; [ binaryBytecode ];
|
2022-04-27 09:35:20 +00:00
|
|
|
license = licenses.asl20;
|
|
|
|
platforms = jre.meta.platforms;
|
2020-11-06 00:33:48 +00:00
|
|
|
maintainers = with maintainers; [ ngerstle talyz ];
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|