janus-ca pkg updates
This commit is contained in:
@@ -9,25 +9,45 @@ in
|
|||||||
flake.modules.nixos.janus-ca =
|
flake.modules.nixos.janus-ca =
|
||||||
{ config, lib, ... }:
|
{ config, lib, ... }:
|
||||||
let
|
let
|
||||||
|
cfg = config.janus-ca;
|
||||||
johnHome = lib.attrByPath [ "users" "users" username "home" ] "/home/${username}" config;
|
johnHome = lib.attrByPath [ "users" "users" username "home" ] "/home/${username}" config;
|
||||||
johnGroup = lib.attrByPath [ "users" "users" username "group" ] username config;
|
johnGroup = lib.attrByPath [ "users" "users" username "group" ] username config;
|
||||||
|
cfgInEtc = lib.hasPrefix "/etc/" cfg.certDir;
|
||||||
|
certDirEtcPath =
|
||||||
|
if cfgInEtc then
|
||||||
|
lib.removePrefix "/etc/" cfg.certDir
|
||||||
|
else
|
||||||
|
cfg.certDir;
|
||||||
|
certRootEtcPath = "${certDirEtcPath}/root_ca.crt";
|
||||||
mkStepRules = home: user: group: [
|
mkStepRules = home: user: group: [
|
||||||
"d ${home}/.step 0700 ${user} ${group} -"
|
"d ${home}/.step 0700 ${user} ${group} -"
|
||||||
"d ${home}/.step/config 0700 ${user} ${group} -"
|
"d ${home}/.step/config 0700 ${user} ${group} -"
|
||||||
"d ${home}/.step/certs 0700 ${user} ${group} -"
|
"d ${home}/.step/certs 0700 ${user} ${group} -"
|
||||||
"L+ ${home}/.step/config/defaults.json - - - - /etc/step/config/defaults.json"
|
"L+ ${home}/.step/config/defaults.json - - - - /etc/step-ca/defaults.json"
|
||||||
"L+ ${home}/.step/certs/root_ca.crt - - - - /etc/step/certs/root_ca.crt"
|
"L+ ${home}/.step/certs/root_ca.crt - - - - ${cfg.certDir}/root_ca.crt"
|
||||||
];
|
];
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
environment.etc."step/config/defaults.json".text = builtins.toJSON {
|
options.janus-ca = {
|
||||||
inherit ca-url fingerprint;
|
certDir = lib.mkOption {
|
||||||
root = "/etc/step-ca/certs/root_ca.crt";
|
description = "String path to where the mtls certs will be stored.";
|
||||||
|
type = lib.types.str;
|
||||||
|
default = "/etc/step-ca/certs";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = {
|
||||||
|
environment.etc = lib.mkIf cfgInEtc {
|
||||||
|
"step-ca/defaults.json".text = builtins.toJSON {
|
||||||
|
inherit ca-url fingerprint;
|
||||||
|
root = "/etc/${certRootEtcPath}";
|
||||||
|
};
|
||||||
|
"${certRootEtcPath}".source = ./root_ca.crt;
|
||||||
|
};
|
||||||
|
systemd.tmpfiles.rules =
|
||||||
|
mkStepRules johnHome username johnGroup
|
||||||
|
++ mkStepRules "/root" "root" "root";
|
||||||
};
|
};
|
||||||
environment.etc."step-ca/certs/root_ca.crt".source = ./root_ca.crt;
|
|
||||||
systemd.tmpfiles.rules =
|
|
||||||
mkStepRules johnHome username johnGroup
|
|
||||||
++ mkStepRules "/root" "root" "root";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
flake.modules.homeManager.janus-ca = { config, ... }: {
|
flake.modules.homeManager.janus-ca = { config, ... }: {
|
||||||
|
|||||||
Reference in New Issue
Block a user