refactor flake
* switched from flake-utils to flake-parts * dropped the overlay and instead populate configurable options for all required authentik components in the module * `nixosModule.default` is now a top-level output following the flake spec, instead of the previously incorrect system-specific definition
This commit is contained in:
parent
e584b40578
commit
6830ada44a
5 changed files with 91 additions and 40 deletions
1
TODO.md
1
TODO.md
|
|
@ -2,6 +2,5 @@
|
||||||
|
|
||||||
* fill empty parts of README
|
* fill empty parts of README
|
||||||
* provide separate packages / modules for outposts
|
* provide separate packages / modules for outposts
|
||||||
* fix `flake check`
|
|
||||||
* configure github checks
|
* configure github checks
|
||||||
* add some more subtests to VM test
|
* add some more subtests to VM test
|
||||||
|
|
|
||||||
37
flake.lock
generated
37
flake.lock
generated
|
|
@ -17,6 +17,24 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"flake-parts": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs-lib": "nixpkgs-lib"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1687762428,
|
||||||
|
"narHash": "sha256-DIf7mi45PKo+s8dOYF+UlXHzE0Wl/+k3tXUyAoAnoGE=",
|
||||||
|
"owner": "hercules-ci",
|
||||||
|
"repo": "flake-parts",
|
||||||
|
"rev": "37dd7bb15791c86d55c5121740a1887ab55ee836",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "hercules-ci",
|
||||||
|
"repo": "flake-parts",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"flake-utils": {
|
"flake-utils": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1676283394,
|
"lastModified": 1676283394,
|
||||||
|
|
@ -71,6 +89,24 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"nixpkgs-lib": {
|
||||||
|
"locked": {
|
||||||
|
"dir": "lib",
|
||||||
|
"lastModified": 1685564631,
|
||||||
|
"narHash": "sha256-8ywr3AkblY4++3lIVxmrWZFzac7+f32ZEhH/A8pNscI=",
|
||||||
|
"owner": "NixOS",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"rev": "4f53efe34b3a8877ac923b9350c874e3dcd5dc0a",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"dir": "lib",
|
||||||
|
"owner": "NixOS",
|
||||||
|
"ref": "nixos-unstable",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"poetry2nix": {
|
"poetry2nix": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-utils": [
|
"flake-utils": [
|
||||||
|
|
@ -97,6 +133,7 @@
|
||||||
"root": {
|
"root": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"authentik-src": "authentik-src",
|
"authentik-src": "authentik-src",
|
||||||
|
"flake-parts": "flake-parts",
|
||||||
"flake-utils": "flake-utils",
|
"flake-utils": "flake-utils",
|
||||||
"napalm": "napalm",
|
"napalm": "napalm",
|
||||||
"nixpkgs": "nixpkgs",
|
"nixpkgs": "nixpkgs",
|
||||||
|
|
|
||||||
51
flake.nix
51
flake.nix
|
|
@ -3,6 +3,7 @@
|
||||||
|
|
||||||
inputs = {
|
inputs = {
|
||||||
flake-utils.url = "github:numtide/flake-utils";
|
flake-utils.url = "github:numtide/flake-utils";
|
||||||
|
flake-parts.url = "github:hercules-ci/flake-parts";
|
||||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05";
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05";
|
||||||
poetry2nix = {
|
poetry2nix = {
|
||||||
url = "github:nix-community/poetry2nix";
|
url = "github:nix-community/poetry2nix";
|
||||||
|
|
@ -24,35 +25,41 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = {
|
outputs = inputs@{
|
||||||
self,
|
self,
|
||||||
nixpkgs,
|
nixpkgs,
|
||||||
flake-utils,
|
flake-parts,
|
||||||
poetry2nix,
|
poetry2nix,
|
||||||
napalm,
|
napalm,
|
||||||
authentik-src
|
authentik-src,
|
||||||
|
...
|
||||||
}:
|
}:
|
||||||
flake-utils.lib.eachDefaultSystem (system:
|
|
||||||
|
flake-parts.lib.mkFlake
|
||||||
|
{ inherit inputs; }
|
||||||
|
({ inputs, lib, withSystem, ... }:
|
||||||
let
|
let
|
||||||
authentik-version = "2023.5.4"; # to pass to the drvs of some components
|
authentik-version = "2023.5.4"; # to pass to the drvs of some components
|
||||||
inherit (poetry2nix.legacyPackages.${system})
|
in rec {
|
||||||
|
systems = [
|
||||||
|
"x86_64-linux"
|
||||||
|
"aarch64-linux" # not tested
|
||||||
|
];
|
||||||
|
flake = {
|
||||||
|
nixosModules.default = { pkgs, ... }: {
|
||||||
|
imports = [ ./module.nix ];
|
||||||
|
services.authentik.authentikComponents = withSystem pkgs.stdenv.hostPlatform.system (
|
||||||
|
{ config, ... }:
|
||||||
|
{ inherit (config.packages) celery staticWorkdirDeps migrate pythonEnv frontend gopkgs docs; }
|
||||||
|
);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
perSystem = { inputs', pkgs, system, ... }: let
|
||||||
|
inherit (inputs'.poetry2nix.legacyPackages)
|
||||||
mkPoetryEnv
|
mkPoetryEnv
|
||||||
defaultPoetryOverrides;
|
defaultPoetryOverrides;
|
||||||
pkgs = nixpkgs.legacyPackages.${system};
|
in {
|
||||||
in
|
|
||||||
rec {
|
|
||||||
nixosModules = {
|
|
||||||
default = import ./module.nix;
|
|
||||||
};
|
|
||||||
overlays = {
|
|
||||||
default = final: prev: {
|
|
||||||
authentik = {
|
|
||||||
inherit (packages) celery staticWorkdirDeps migrate pythonEnv frontend gopkgs docs;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
packages = rec {
|
packages = rec {
|
||||||
inherit authentik-src;
|
|
||||||
docs = napalm.legacyPackages.${system}.buildPackage "${authentik-src}/website" {
|
docs = napalm.legacyPackages.${system}.buildPackage "${authentik-src}/website" {
|
||||||
version = authentik-version; # 0.0.0 specified upstream
|
version = authentik-version; # 0.0.0 specified upstream
|
||||||
NODE_ENV = "production";
|
NODE_ENV = "production";
|
||||||
|
|
@ -163,11 +170,10 @@
|
||||||
--prefix PYTHONPATH : ${staticWorkdirDeps}
|
--prefix PYTHONPATH : ${staticWorkdirDeps}
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
checks.default = (import ./test.nix {
|
checks.default = (import ./test.nix {
|
||||||
inherit pkgs overlays nixosModules;
|
inherit pkgs;
|
||||||
|
inherit (self) nixosModules;
|
||||||
});
|
});
|
||||||
|
|
||||||
devShells.default = pkgs.mkShell {
|
devShells.default = pkgs.mkShell {
|
||||||
packages = [
|
packages = [
|
||||||
# to generate a v2 lockfile from the v3 lockfile provided by upstream:
|
# to generate a v2 lockfile from the v3 lockfile provided by upstream:
|
||||||
|
|
@ -175,5 +181,6 @@
|
||||||
pkgs.nodejs
|
pkgs.nodejs
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
};
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
||||||
24
module.nix
24
module.nix
|
|
@ -17,7 +17,7 @@ let
|
||||||
mkEnableOption
|
mkEnableOption
|
||||||
mkOption;
|
mkOption;
|
||||||
|
|
||||||
inherit (pkgs.authentik)
|
inherit (cfg.authentikComponents)
|
||||||
migrate
|
migrate
|
||||||
gopkgs
|
gopkgs
|
||||||
celery
|
celery
|
||||||
|
|
@ -29,6 +29,16 @@ in
|
||||||
options.services.authentik = {
|
options.services.authentik = {
|
||||||
enable = mkEnableOption "authentik";
|
enable = mkEnableOption "authentik";
|
||||||
|
|
||||||
|
authentikComponents = {
|
||||||
|
celery = mkOption { type = types.package; };
|
||||||
|
staticWorkdirDeps = mkOption { type = types.package; };
|
||||||
|
migrate = mkOption { type = types.package; };
|
||||||
|
pythonEnv = mkOption { type = types.package; };
|
||||||
|
frontend = mkOption { type = types.package; };
|
||||||
|
gopkgs = mkOption { type = types.package; };
|
||||||
|
docs = mkOption { type = types.package; };
|
||||||
|
};
|
||||||
|
|
||||||
settings = mkOption {
|
settings = mkOption {
|
||||||
type = types.submodule {
|
type = types.submodule {
|
||||||
freeformType = settingsFormat.type;
|
freeformType = settingsFormat.type;
|
||||||
|
|
@ -45,8 +55,8 @@ in
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
services = {
|
services = {
|
||||||
authentik.settings = {
|
authentik.settings = {
|
||||||
blueprints_dir = mkDefault "${pkgs.authentik.staticWorkdirDeps}/blueprints";
|
blueprints_dir = mkDefault "${cfg.authentikComponents.staticWorkdirDeps}/blueprints";
|
||||||
template_dir = mkDefault "${pkgs.authentik.staticWorkdirDeps}/templates";
|
template_dir = mkDefault "${cfg.authentikComponents.staticWorkdirDeps}/templates";
|
||||||
postgresql = {
|
postgresql = {
|
||||||
user = mkDefault "authentik";
|
user = mkDefault "authentik";
|
||||||
name = mkDefault "authentik";
|
name = mkDefault "authentik";
|
||||||
|
|
@ -84,7 +94,7 @@ in
|
||||||
RemainAfterExit = true;
|
RemainAfterExit = true;
|
||||||
DynamicUser = true;
|
DynamicUser = true;
|
||||||
User = "authentik";
|
User = "authentik";
|
||||||
ExecStart = "${pkgs.authentik.migrate}/bin/migrate.py";
|
ExecStart = "${cfg.authentikComponents.migrate}/bin/migrate.py";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
authentik-worker = {
|
authentik-worker = {
|
||||||
|
|
@ -97,7 +107,7 @@ in
|
||||||
DynamicUser = true;
|
DynamicUser = true;
|
||||||
User = "authentik";
|
User = "authentik";
|
||||||
# TODO maybe make this configurable
|
# TODO maybe make this configurable
|
||||||
ExecStart = "${pkgs.authentik.celery}/bin/celery -A authentik.root.celery worker -Ofair --max-tasks-per-child=1 --autoscale 3,1 -E -B -s /tmp/celerybeat-schedule -Q authentik,authentik_scheduled,authentik_events";
|
ExecStart = "${cfg.authentikComponents.celery}/bin/celery -A authentik.root.celery worker -Ofair --max-tasks-per-child=1 --autoscale 3,1 -E -B -s /tmp/celerybeat-schedule -Q authentik,authentik_scheduled,authentik_events";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
authentik = {
|
authentik = {
|
||||||
|
|
@ -109,7 +119,7 @@ in
|
||||||
];
|
];
|
||||||
restartTriggers = [ config.environment.etc."authentik/config.yml".source ];
|
restartTriggers = [ config.environment.etc."authentik/config.yml".source ];
|
||||||
preStart = ''
|
preStart = ''
|
||||||
ln -svf ${pkgs.authentik.staticWorkdirDeps}/* /var/lib/authentik/
|
ln -svf ${cfg.authentikComponents.staticWorkdirDeps}/* /var/lib/authentik/
|
||||||
'';
|
'';
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Environment = [
|
Environment = [
|
||||||
|
|
@ -123,7 +133,7 @@ in
|
||||||
# TODO /run might be sufficient
|
# TODO /run might be sufficient
|
||||||
WorkingDirectory = "%S/authentik";
|
WorkingDirectory = "%S/authentik";
|
||||||
DynamicUser = true;
|
DynamicUser = true;
|
||||||
ExecStart = "${pkgs.authentik.gopkgs}/bin/server";
|
ExecStart = "${cfg.authentikComponents.gopkgs}/bin/server";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
||||||
2
test.nix
2
test.nix
|
|
@ -1,5 +1,4 @@
|
||||||
{ pkgs
|
{ pkgs
|
||||||
, overlays
|
|
||||||
, nixosModules
|
, nixosModules
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
|
|
@ -19,7 +18,6 @@ pkgs.nixosTest {
|
||||||
"${pkgs.path}/nixos/tests/common/user-account.nix"
|
"${pkgs.path}/nixos/tests/common/user-account.nix"
|
||||||
"${pkgs.path}/nixos/tests/common/x11.nix"
|
"${pkgs.path}/nixos/tests/common/x11.nix"
|
||||||
];
|
];
|
||||||
nixpkgs.overlays = [ overlays.default ];
|
|
||||||
|
|
||||||
services.authentik.enable = true;
|
services.authentik.enable = true;
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue