nixos/services.kubernetes.scheduler: remove with lib;

This commit is contained in:
Felix Buehler
2024-12-08 13:18:23 +01:00
parent ac653187c5
commit c41bc079d1

View File

@@ -1,7 +1,4 @@
{ config, lib, options, pkgs, ... }: { config, lib, options, pkgs, ... }:
with lib;
let let
top = config.services.kubernetes; top = config.services.kubernetes;
otop = options.services.kubernetes; otop = options.services.kubernetes;
@@ -11,42 +8,42 @@ in
###### interface ###### interface
options.services.kubernetes.scheduler = with lib.types; { options.services.kubernetes.scheduler = with lib.types; {
address = mkOption { address = lib.mkOption {
description = "Kubernetes scheduler listening address."; description = "Kubernetes scheduler listening address.";
default = "127.0.0.1"; default = "127.0.0.1";
type = str; type = str;
}; };
enable = mkEnableOption "Kubernetes scheduler"; enable = lib.mkEnableOption "Kubernetes scheduler";
extraOpts = mkOption { extraOpts = lib.mkOption {
description = "Kubernetes scheduler extra command line options."; description = "Kubernetes scheduler extra command line options.";
default = ""; default = "";
type = separatedString " "; type = separatedString " ";
}; };
featureGates = mkOption { featureGates = lib.mkOption {
description = "Attribute set of feature gates."; description = "Attribute set of feature gates.";
default = top.featureGates; default = top.featureGates;
defaultText = literalExpression "config.${otop.featureGates}"; defaultText = lib.literalExpression "config.${otop.featureGates}";
type = attrsOf bool; type = attrsOf bool;
}; };
kubeconfig = top.lib.mkKubeConfigOptions "Kubernetes scheduler"; kubeconfig = top.lib.mkKubeConfigOptions "Kubernetes scheduler";
leaderElect = mkOption { leaderElect = lib.mkOption {
description = "Whether to start leader election before executing main loop."; description = "Whether to start leader election before executing main loop.";
type = bool; type = bool;
default = true; default = true;
}; };
port = mkOption { port = lib.mkOption {
description = "Kubernetes scheduler listening port."; description = "Kubernetes scheduler listening port.";
default = 10251; default = 10251;
type = port; type = port;
}; };
verbosity = mkOption { verbosity = lib.mkOption {
description = '' description = ''
Optional glog verbosity level for logging statements. See Optional glog verbosity level for logging statements. See
<https://github.com/kubernetes/community/blob/master/contributors/devel/logging.md> <https://github.com/kubernetes/community/blob/master/contributors/devel/logging.md>
@@ -58,7 +55,7 @@ in
}; };
###### implementation ###### implementation
config = mkIf cfg.enable { config = lib.mkIf cfg.enable {
systemd.services.kube-scheduler = { systemd.services.kube-scheduler = {
description = "Kubernetes Scheduler Service"; description = "Kubernetes Scheduler Service";
wantedBy = [ "kubernetes.target" ]; wantedBy = [ "kubernetes.target" ];
@@ -67,12 +64,12 @@ in
Slice = "kubernetes.slice"; Slice = "kubernetes.slice";
ExecStart = ''${top.package}/bin/kube-scheduler \ ExecStart = ''${top.package}/bin/kube-scheduler \
--bind-address=${cfg.address} \ --bind-address=${cfg.address} \
${optionalString (cfg.featureGates != {}) ${lib.optionalString (cfg.featureGates != {})
"--feature-gates=${concatStringsSep "," (builtins.attrValues (mapAttrs (n: v: "${n}=${trivial.boolToString v}") cfg.featureGates))}"} \ "--feature-gates=${lib.concatStringsSep "," (builtins.attrValues (lib.mapAttrs (n: v: "${n}=${lib.trivial.boolToString v}") cfg.featureGates))}"} \
--kubeconfig=${top.lib.mkKubeConfig "kube-scheduler" cfg.kubeconfig} \ --kubeconfig=${top.lib.mkKubeConfig "kube-scheduler" cfg.kubeconfig} \
--leader-elect=${boolToString cfg.leaderElect} \ --leader-elect=${lib.boolToString cfg.leaderElect} \
--secure-port=${toString cfg.port} \ --secure-port=${toString cfg.port} \
${optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \ ${lib.optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \
${cfg.extraOpts} ${cfg.extraOpts}
''; '';
WorkingDirectory = top.dataDir; WorkingDirectory = top.dataDir;
@@ -94,7 +91,7 @@ in
}; };
}; };
services.kubernetes.scheduler.kubeconfig.server = mkDefault top.apiserverAddress; services.kubernetes.scheduler.kubeconfig.server = lib.mkDefault top.apiserverAddress;
}; };
meta.buildDocsInSandbox = false; meta.buildDocsInSandbox = false;