{ description = "Nix package, NixOS module and VM integration test for authentik"; inputs = { flake-utils.url = "github:numtide/flake-utils"; nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05"; poetry2nix = { url = "github:nix-community/poetry2nix"; inputs = { nixpkgs.follows = "nixpkgs"; flake-utils.follows = "flake-utils"; }; }; napalm = { url = "github:nix-community/napalm"; inputs = { nixpkgs.follows = "nixpkgs"; flake-utils.follows = "flake-utils"; }; }; authentik-src = { # change version string in outputs as well when updating url = "github:goauthentik/authentik/version/2023.5.1"; flake = false; }; }; outputs = { self, nixpkgs, flake-utils, poetry2nix, napalm, authentik-src }: flake-utils.lib.eachDefaultSystem (system: let authentik-version = "2023.5.1"; # to pass to the drvs of some components inherit (poetry2nix.legacyPackages.${system}) mkPoetryEnv defaultPoetryOverrides; pkgs = nixpkgs.legacyPackages.${system}; in rec { nixosModules = { default = import ./module.nix; }; overlays = { default = final: prev: { authentik = { inherit (packages) celery staticWorkdirDeps migrate pythonEnv frontend gopkgs docs; }; }; }; packages = rec { inherit authentik-src; docs = napalm.legacyPackages.${system}.buildPackage "${authentik-src}/website" { version = authentik-version; # 0.0.0 specified upstream NODE_ENV = "production"; nodejs = pkgs.nodejs_20; npmCommands = [ "cp -v ${authentik-src}/SECURITY.md ../SECURITY.md" "cp -vr ${authentik-src}/blueprints ../blueprints" "npm install --include=dev" "npm run build-docs-only" ]; installPhase = '' mv -v ../website $out ''; }; frontend = napalm.legacyPackages.${system}.buildPackage "${authentik-src}/web" { version = authentik-version; # 0.0.0 specified upstream packageLock = ./web-package-lock.json; # needs to be lock file version 2 for napalm, upstream uses v3 NODE_ENV = "production"; nodejs = pkgs.nodejs_20; preBuild = '' ln -sv ${docs} ../website ''; npmCommands = [ "npm install --include=dev" "sed -i'' -e 's,/usr/bin/env node,/bin/node,' node_modules/@lingui/cli/dist/lingui.js" "patchShebangs node_modules/@lingui/cli/dist/lingui.js" "npm run build" ]; installPhase = '' mkdir $out mv dist $out/dist cp -r authentik icons $out ''; }; pythonEnv = mkPoetryEnv { projectDir = authentik-src; python = pkgs.python311; overrides = [ defaultPoetryOverrides ] ++ (import ./poetry2nix-python-overrides.nix pkgs); }; # server + outposts gopkgs = pkgs.buildGo120Module { pname = "authentik-gopgks"; version = authentik-version; prePatch = '' sed -i"" -e 's,./web/dist/,${frontend}/dist/,' web/static.go sed -i"" -e 's,./web/dist/,${frontend}/dist/,' internal/web/static.go sed -i"" -e 's,./lifecycle/gunicorn.conf.py,${staticWorkdirDeps}/lifecycle/gunicorn.conf.py,' internal/gounicorn/gounicorn.go ''; src = pkgs.lib.cleanSourceWith { src = authentik-src; filter = (path: _: (builtins.any (x: x) ( (map (infix: pkgs.lib.hasInfix infix path) [ "/cmd" "/internal" ]) ++ (map (suffix: pkgs.lib.hasSuffix suffix path) [ "/web" "/web/static.go" "/web/robots.txt" "/web/security.txt" "go.mod" "go.sum" ]) )) ); }; subPackages = [ "cmd/ldap" "cmd/server" "cmd/proxy" ]; vendorSha256 = "sha256-QOYKsYb6TpzHRI8vSI5zpRHr2aCeUN67KABTRE2Y2kg="; nativeBuildInputs = [ pkgs.makeWrapper ]; postInstall = '' wrapProgram $out/bin/server --prefix PATH : ${pythonEnv}/bin wrapProgram $out/bin/server --prefix PYTHONPATH : ${staticWorkdirDeps} ''; }; staticWorkdirDeps = pkgs.linkFarm "authentik-static-workdir-deps" [ { name = "authentik"; path = "${authentik-src}/authentik"; } { name = "locale"; path = "${authentik-src}/locale"; } { name = "blueprints"; path = "${authentik-src}/blueprints"; } { name = "internal"; path = "${authentik-src}/internal"; } { name = "lifecycle"; path = "${authentik-src}/lifecycle"; } { name = "schemas"; path = "${authentik-src}/schemas"; } { name = "web"; path = frontend; } ]; migrate = pkgs.runCommandLocal "authentik-migrate.py" { nativeBuildInputs = [ pkgs.makeWrapper ]; } '' mkdir -vp $out/bin cp ${authentik-src}/lifecycle/migrate.py $out/bin/migrate.py chmod +w $out/bin/migrate.py patchShebangs $out/bin/migrate.py wrapProgram $out/bin/migrate.py \ --prefix PATH : ${pythonEnv}/bin \ --prefix PYTHONPATH : ${staticWorkdirDeps} ''; # worker celery = pkgs.runCommandLocal "authentik-celery" { nativeBuildInputs = [ pkgs.makeWrapper ]; } '' mkdir -vp $out/bin ln -sv ${pythonEnv}/bin/celery $out/bin/celery wrapProgram $out/bin/celery \ --prefix PYTHONPATH : ${staticWorkdirDeps} ''; }; checks.default = (import ./test.nix { inherit pkgs overlays nixosModules; }); devShells.default = pkgs.mkShell { packages = [ # to generate a v2 lockfile from the v3 lockfile provided by upstream: # npm install --lockfile-version 2 --package-lock-only pkgs.nodejs ]; }; }); }