-
Notifications
You must be signed in to change notification settings - Fork 9
/
lima-init.nix
129 lines (106 loc) · 3.76 KB
/
lima-init.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
{ config, modulesPath, pkgs, lib, ... }:
let
LIMA_CIDATA_MNT = "/mnt/lima-cidata";
LIMA_CIDATA_DEV = "/dev/disk/by-label/cidata";
script = ''
echo "attempting to fetch configuration from LIMA user data..."
if [ -f ${LIMA_CIDATA_MNT}/lima.env ]; then
echo "storage exists";
else
echo "storage not exists";
exit 2
fi
# ripped from https://github.com/lima-vm/alpine-lima/blob/main/lima-init.sh
. "${LIMA_CIDATA_MNT}"/lima.env
export PATH=${pkgs.lib.makeBinPath [ pkgs.shadow pkgs.gawk pkgs.mount ]}:$PATH
# Create user
LIMA_CIDATA_HOMEDIR="/home/$LIMA_CIDATA_USER.linux"
id -u "$LIMA_CIDATA_USER" >/dev/null 2>&1 || useradd --home-dir "$LIMA_CIDATA_HOMEDIR" --create-home --uid "$LIMA_CIDATA_UID" "$LIMA_CIDATA_USER"
# Add user to sudoers
usermod -a -G wheel $LIMA_CIDATA_USER
usermod -a -G users $LIMA_CIDATA_USER
echo "fix symlink for /bin/bash"
ln -fs /run/current-system/sw/bin/bash /bin/bash
# Create authorized_keys
LIMA_CIDATA_SSHDIR="$LIMA_CIDATA_HOMEDIR"/.ssh
mkdir -p -m 700 "$LIMA_CIDATA_SSHDIR"
awk '/ssh-authorized-keys/ {flag=1; next} /^ *$/ {flag=0} flag {sub(/^ +- /, ""); gsub("\"", ""); print $0}' \
"${LIMA_CIDATA_MNT}"/user-data >"$LIMA_CIDATA_SSHDIR"/authorized_keys
LIMA_CIDATA_GID=$(id -g "$LIMA_CIDATA_USER")
chown -R "$LIMA_CIDATA_UID:$LIMA_CIDATA_GID" "$LIMA_CIDATA_SSHDIR"
chmod 600 "$LIMA_CIDATA_SSHDIR"/authorized_keys
LIMA_SSH_KEYS_CONF=/etc/ssh/authorized_keys.d
mkdir -p -m 700 "$LIMA_SSH_KEYS_CONF"
cp "$LIMA_CIDATA_SSHDIR"/authorized_keys "$LIMA_SSH_KEYS_CONF/$LIMA_CIDATA_USER"
# Add mounts to /etc/fstab
sed -i '/#LIMA-START/,/#LIMA-END/d' /etc/fstab
echo "#LIMA-START" >> /etc/fstab
awk -f- "${LIMA_CIDATA_MNT}"/user-data <<'EOF' >> /etc/fstab
/^mounts:/ {
flag = 1
next
}
/^ *$/ {
flag = 0
}
flag {
sub(/^ *- \[/, "")
sub(/"?\] *$/, "")
gsub("\"?, \"?", "\t")
print $0
}
EOF
echo "#LIMA-END" >> /etc/fstab
systemctl daemon-reload
systemctl restart local-fs.target
#echo "$LIMA_CIDATA_SLIRP_GATEWAY host.lima.internal" >> /etc/hosts
cp "${LIMA_CIDATA_MNT}"/meta-data /run/lima-ssh-ready
cp "${LIMA_CIDATA_MNT}"/meta-data /run/lima-boot-done
exit 0
'';
in {
imports = [];
systemd.services.lima-init = {
inherit script;
description = "Reconfigure the system from lima-init userdata on startup";
after = [ "network-pre.target" ];
restartIfChanged = true;
unitConfig.X-StopOnRemoval = false;
serviceConfig = {
Type = "oneshot";
RemainAfterExit = true;
};
};
systemd.services.lima-guestagent = {
enable = true;
description = "Forward ports to the lima-hostagent";
wantedBy = [ "multi-user.target" ];
after = [ "network.target" "lima-init.service" ];
requires = [ "lima-init.service" ];
serviceConfig = {
Type = "simple";
ExecStart = "${LIMA_CIDATA_MNT}/lima-guestagent daemon";
Restart = "on-failure";
};
};
fileSystems."${LIMA_CIDATA_MNT}" = {
device = "${LIMA_CIDATA_DEV}";
fsType = "auto";
options = [ "ro" "mode=0700" "dmode=0700" "overriderockperm" "exec" "uid=0" ];
};
environment.etc = {
environment.source = "${LIMA_CIDATA_MNT}/etc_environment";
};
networking.nat.enable = true;
environment.systemPackages = with pkgs; [
bash
sshfs
fuse3
git
];
boot.kernel.sysctl = {
"kernel.unprivileged_userns_clone" = 1;
"net.ipv4.ping_group_range" = "0 2147483647";
"net.ipv4.ip_unprivileged_port_start" = 0;
};
}