python3Packages.orjson: Disable failing tests on 32 bit
[NixPkgs.git] / nixos / modules / services / cluster / kubernetes / proxy.nix
blob015784f7e311611c81db3b88d4eeee53fd01e2c5
1 { config, lib, options, pkgs, ... }:
3 with lib;
5 let
6   top = config.services.kubernetes;
7   otop = options.services.kubernetes;
8   cfg = top.proxy;
9 in
11   imports = [
12     (mkRenamedOptionModule [ "services" "kubernetes" "proxy" "address" ] ["services" "kubernetes" "proxy" "bindAddress"])
13   ];
15   ###### interface
16   options.services.kubernetes.proxy = with lib.types; {
18     bindAddress = mkOption {
19       description = lib.mdDoc "Kubernetes proxy listening address.";
20       default = "0.0.0.0";
21       type = str;
22     };
24     enable = mkEnableOption (lib.mdDoc "Kubernetes proxy");
26     extraOpts = mkOption {
27       description = lib.mdDoc "Kubernetes proxy extra command line options.";
28       default = "";
29       type = separatedString " ";
30     };
32     featureGates = mkOption {
33       description = lib.mdDoc "List set of feature gates";
34       default = top.featureGates;
35       defaultText = literalExpression "config.${otop.featureGates}";
36       type = listOf str;
37     };
39     hostname = mkOption {
40       description = lib.mdDoc "Kubernetes proxy hostname override.";
41       default = config.networking.hostName;
42       defaultText = literalExpression "config.networking.hostName";
43       type = str;
44     };
46     kubeconfig = top.lib.mkKubeConfigOptions "Kubernetes proxy";
48     verbosity = mkOption {
49       description = lib.mdDoc ''
50         Optional glog verbosity level for logging statements. See
51         <https://github.com/kubernetes/community/blob/master/contributors/devel/logging.md>
52       '';
53       default = null;
54       type = nullOr int;
55     };
57   };
59   ###### implementation
60   config = mkIf cfg.enable {
61     systemd.services.kube-proxy = {
62       description = "Kubernetes Proxy Service";
63       wantedBy = [ "kubernetes.target" ];
64       after = [ "kube-apiserver.service" ];
65       path = with pkgs; [ iptables conntrack-tools ];
66       serviceConfig = {
67         Slice = "kubernetes.slice";
68         ExecStart = ''${top.package}/bin/kube-proxy \
69           --bind-address=${cfg.bindAddress} \
70           ${optionalString (top.clusterCidr!=null)
71             "--cluster-cidr=${top.clusterCidr}"} \
72           ${optionalString (cfg.featureGates != [])
73             "--feature-gates=${concatMapStringsSep "," (feature: "${feature}=true") cfg.featureGates}"} \
74           --hostname-override=${cfg.hostname} \
75           --kubeconfig=${top.lib.mkKubeConfig "kube-proxy" cfg.kubeconfig} \
76           ${optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \
77           ${cfg.extraOpts}
78         '';
79         WorkingDirectory = top.dataDir;
80         Restart = "on-failure";
81         RestartSec = 5;
82       };
83       unitConfig = {
84         StartLimitIntervalSec = 0;
85       };
86     };
88     services.kubernetes.proxy.hostname = with config.networking; mkDefault hostName;
90     services.kubernetes.pki.certs = {
91       kubeProxyClient = top.lib.mkCert {
92         name = "kube-proxy-client";
93         CN = "system:kube-proxy";
94         action = "systemctl restart kube-proxy.service";
95       };
96     };
98     services.kubernetes.proxy.kubeconfig.server = mkDefault top.apiserverAddress;
99   };
101   meta.buildDocsInSandbox = false;