sbc-deploys/modules/k3s/default.nix

41 lines
1 KiB
Nix
Raw Normal View History

{
2023-05-08 18:43:41 +00:00
server = { enable ? true }:
{ config, pkgs, ... }: {
networking.firewall.enable = false;
2023-05-08 18:43:41 +00:00
environment.systemPackages = with pkgs; [
k3s
2023-07-25 03:57:12 +00:00
(writeShellScriptBin "kube" (builtins.readFile ./kubectl))
2023-05-08 18:43:41 +00:00
];
2023-05-08 18:43:41 +00:00
sops.secrets.k3s_env = {
format = "binary";
sopsFile = ../../secrets/k3s_env.bin;
};
2023-05-08 18:43:41 +00:00
services.k3s = {
inherit enable;
environmentFile = config.sops.secrets.k3s_env.path;
2024-07-05 00:28:45 +00:00
extraFlags = "--disable traefik --disable servicelb --cluster-cidr=10.42.0.0/16,2001:cafe:42::/56 --service-cidr=10.43.0.0/16,2001:cafe:43::/112";
2023-05-08 18:43:41 +00:00
role = "server";
};
};
2023-05-08 18:43:41 +00:00
agent = { serverIp, enable ? true }:
{ config, ... }: {
networking.firewall.enable = false;
2023-05-08 18:43:41 +00:00
sops.secrets.k3s_token = {
format = "yaml";
sopsFile = ../../secrets/k3s.yaml;
};
2023-05-08 18:43:41 +00:00
services.k3s = {
inherit enable;
role = "agent";
serverAddr = "https://${serverIp}:6443";
tokenFile = config.sops.secrets.k3s_token.path;
};
};
}