2025-12-14 13:44:56 -05:00
|
|
|
# unpackPhase
|
|
|
|
|
# patchPhase
|
|
|
|
|
# configurePhase
|
|
|
|
|
# buildPhase
|
|
|
|
|
# checkPhase
|
|
|
|
|
# installPhase
|
|
|
|
|
# fixupPhase
|
|
|
|
|
# installCheckPhase
|
|
|
|
|
# distPhase
|
|
|
|
|
{
|
2025-12-16 19:31:33 -05:00
|
|
|
config,
|
2025-12-14 20:28:48 -05:00
|
|
|
lib,
|
2025-12-14 13:44:56 -05:00
|
|
|
stdenv,
|
2025-12-14 18:24:24 -05:00
|
|
|
writeShellScript,
|
2025-12-14 13:44:56 -05:00
|
|
|
k8s,
|
2025-12-14 20:28:48 -05:00
|
|
|
openssh,
|
2025-12-14 13:44:56 -05:00
|
|
|
...
|
|
|
|
|
}:
|
2025-12-14 18:24:24 -05:00
|
|
|
let
|
2025-12-16 19:31:33 -05:00
|
|
|
vm_name_to_hostname =
|
|
|
|
|
let
|
|
|
|
|
mapping = {
|
|
|
|
|
"nc0" = "controller0";
|
|
|
|
|
"nc1" = "controller1";
|
|
|
|
|
"nc2" = "controller2";
|
|
|
|
|
"nw0" = "worker0";
|
|
|
|
|
"nw1" = "worker1";
|
|
|
|
|
"nw2" = "worker2";
|
|
|
|
|
};
|
|
|
|
|
in
|
|
|
|
|
(vm_name: mapping."${vm_name}");
|
|
|
|
|
|
2025-12-14 20:28:48 -05:00
|
|
|
deploy_script_body = (
|
|
|
|
|
''
|
|
|
|
|
set -euo pipefail
|
|
|
|
|
IFS=$'\n\t'
|
|
|
|
|
DIR="$( cd "$( dirname "''${BASH_SOURCE[0]}" )" && pwd )"
|
|
|
|
|
''
|
2025-12-16 19:31:33 -05:00
|
|
|
+ (lib.concatMapStringsSep "\n" deploy_control_plane [
|
2025-12-14 20:28:48 -05:00
|
|
|
"nc0"
|
|
|
|
|
"nc1"
|
|
|
|
|
"nc2"
|
|
|
|
|
])
|
2025-12-16 19:31:33 -05:00
|
|
|
+ (lib.concatMapStringsSep "\n" deploy_worker [
|
|
|
|
|
"nw0"
|
|
|
|
|
"nw1"
|
|
|
|
|
"nw2"
|
|
|
|
|
])
|
2025-12-14 20:28:48 -05:00
|
|
|
);
|
2025-12-14 18:24:24 -05:00
|
|
|
deploy_script = (writeShellScript "deploy-script" deploy_script_body);
|
2025-12-14 20:28:48 -05:00
|
|
|
deploy_file = (
|
|
|
|
|
{
|
|
|
|
|
dest_dir,
|
|
|
|
|
file,
|
|
|
|
|
name ? (builtins.baseNameOf file),
|
|
|
|
|
owner,
|
|
|
|
|
group,
|
|
|
|
|
mode,
|
|
|
|
|
}:
|
|
|
|
|
''
|
|
|
|
|
##
|
|
|
|
|
## deploy ${name} to ${dest_dir}
|
|
|
|
|
##
|
|
|
|
|
${openssh}/bin/ssh mrmanager doas rm -f ${dest_dir}/${name} ~/${name}
|
|
|
|
|
${openssh}/bin/scp ${file} mrmanager:~/${name}
|
|
|
|
|
${openssh}/bin/ssh mrmanager doas install -o ${toString owner} -g ${toString group} -m ${mode} ~/${name} ${dest_dir}/${name}
|
|
|
|
|
${openssh}/bin/ssh mrmanager doas rm -f ~/${name}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
''
|
|
|
|
|
);
|
2025-12-16 19:31:33 -05:00
|
|
|
deploy_control_plane = (
|
2025-12-14 20:28:48 -05:00
|
|
|
vm_name:
|
|
|
|
|
(
|
|
|
|
|
''
|
|
|
|
|
##
|
|
|
|
|
## Create directories on ${vm_name}
|
|
|
|
|
##
|
2025-12-16 19:31:33 -05:00
|
|
|
${openssh}/bin/ssh mrmanager doas install -d -o 0 -g 0 -m 0755 /vm/${vm_name}/persist/keys
|
2025-12-14 20:28:48 -05:00
|
|
|
${openssh}/bin/ssh mrmanager doas install -d -o 10016 -g 10016 -m 0755 /vm/${vm_name}/persist/keys/etcd
|
|
|
|
|
${openssh}/bin/ssh mrmanager doas install -d -o 10024 -g 10024 -m 0755 /vm/${vm_name}/persist/keys/kube
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
''
|
|
|
|
|
+ (lib.concatMapStringsSep "\n" deploy_file [
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/etcd";
|
|
|
|
|
file = "${k8s.keys.kube-api-server}/kube-api-server.crt";
|
|
|
|
|
owner = 10016;
|
|
|
|
|
group = 10016;
|
|
|
|
|
mode = "0640";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/etcd";
|
|
|
|
|
file = "${k8s.keys.kube-api-server}/kube-api-server.key";
|
|
|
|
|
owner = 10016;
|
|
|
|
|
group = 10016;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/etcd";
|
|
|
|
|
file = "${k8s.ca}/ca.crt";
|
|
|
|
|
owner = 10016;
|
|
|
|
|
group = 10016;
|
|
|
|
|
mode = "0640";
|
|
|
|
|
}
|
2025-12-14 23:24:23 -05:00
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.ca}/ca.crt";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0640";
|
|
|
|
|
}
|
2025-12-15 19:47:35 -05:00
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.ca}/ca.key";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
2025-12-14 23:24:23 -05:00
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.keys.kube-api-server}/kube-api-server.crt";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0640";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.keys.kube-api-server}/kube-api-server.key";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.encryption_config}/encryption-config.yaml";
|
|
|
|
|
name = "encryption-config.yaml";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.keys.service-accounts}/service-accounts.crt";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0640";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.keys.service-accounts}/service-accounts.key";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
2025-12-15 19:47:35 -05:00
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.client-configs.kube-controller-manager}/kube-controller-manager.kubeconfig";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
2025-12-15 20:09:46 -05:00
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.client-configs.kube-scheduler}/kube-scheduler.kubeconfig";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
2025-12-14 20:28:48 -05:00
|
|
|
])
|
|
|
|
|
)
|
|
|
|
|
);
|
2025-12-16 19:31:33 -05:00
|
|
|
deploy_worker = (
|
|
|
|
|
vm_name:
|
|
|
|
|
(
|
|
|
|
|
''
|
|
|
|
|
##
|
|
|
|
|
## Create directories on ${vm_name}
|
|
|
|
|
##
|
|
|
|
|
${openssh}/bin/ssh mrmanager doas install -d -o 0 -g 0 -m 0755 /vm/${vm_name}/persist/keys
|
|
|
|
|
${openssh}/bin/ssh mrmanager doas install -d -o 10024 -g 10024 -m 0755 /vm/${vm_name}/persist/keys/kube
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
''
|
|
|
|
|
+ (lib.concatMapStringsSep "\n" deploy_file [
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.ca}/ca.crt";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0640";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.keys."${vm_name_to_hostname vm_name}"}/${vm_name_to_hostname vm_name}.crt";
|
|
|
|
|
name = "kubelet.crt";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0640";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${k8s.keys."${vm_name_to_hostname vm_name}"}/${vm_name_to_hostname vm_name}.key";
|
|
|
|
|
name = "kubelet.key";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
dest_dir = "/vm/${vm_name}/persist/keys/kube";
|
|
|
|
|
file = "${
|
|
|
|
|
k8s.client-configs."${vm_name_to_hostname vm_name}"
|
|
|
|
|
}/${vm_name_to_hostname vm_name}.kubeconfig";
|
|
|
|
|
name = "kubeconfig";
|
|
|
|
|
owner = 10024;
|
|
|
|
|
group = 10024;
|
|
|
|
|
mode = "0600";
|
|
|
|
|
}
|
|
|
|
|
])
|
|
|
|
|
)
|
|
|
|
|
);
|
2025-12-14 18:24:24 -05:00
|
|
|
in
|
2025-12-14 13:44:56 -05:00
|
|
|
stdenv.mkDerivation (finalAttrs: {
|
2025-12-14 18:24:24 -05:00
|
|
|
name = "deploy-script";
|
|
|
|
|
nativeBuildInputs = [ ];
|
2025-12-14 13:44:56 -05:00
|
|
|
buildInputs = [ ];
|
|
|
|
|
|
|
|
|
|
unpackPhase = "true";
|
|
|
|
|
|
|
|
|
|
installPhase = ''
|
2025-12-14 18:24:24 -05:00
|
|
|
cp ${deploy_script} "$out"
|
2025-12-14 13:44:56 -05:00
|
|
|
'';
|
|
|
|
|
})
|