forked from cleverca22/not-os
-
Notifications
You must be signed in to change notification settings - Fork 0
/
runit.nix
60 lines (59 loc) · 1.5 KB
/
runit.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
{ pkgs, ... }:
let
sshd_config = pkgs.writeText "sshd_config" ''
HostKey /etc/ssh/ssh_host_rsa_key
HostKey /etc/ssh/ssh_host_ed25519_key
Port 22
PidFile /run/sshd.pid
Protocol 2
PermitRootLogin yes
PasswordAuthentication yes
AuthorizedKeysFile /etc/ssh/authorized_keys.d/%u
'';
compat = pkgs.runCommand "runit-compat" {} ''
mkdir -p $out/bin/
cat << EOF > $out/bin/poweroff
#!/bin/sh
exec runit-init 0
EOF
cat << EOF > $out/bin/reboot
#!/bin/sh
exec runit-init 6
EOF
chmod +x $out/bin/{poweroff,reboot}
'';
in
{
environment.systemPackages = [ compat pkgs.socat ];
environment.etc = {
"runit/1".source = pkgs.writeScript "1" ''
#!${pkgs.stdenv.shell}
ip addr add 10.0.2.15 dev eth0
ip link set eth0 up
ip route add 10.0.2.0/24 dev eth0
ip route add default via 10.0.2.2 dev eth0
mkdir /bin/
ln -s ${pkgs.stdenv.shell} /bin/sh
touch /etc/runit/stopit
chmod 0 /etc/runit/stopit
'';
"runit/2".source = pkgs.writeScript "2" ''
#!/bin/sh
cat /proc/uptime
exec runsvdir -P /etc/service
'';
"runit/3".source = pkgs.writeScript "3" ''
#!/bin/sh
echo and down we go
'';
"service/sshd/run".source = pkgs.writeScript "sshd_run" ''
#!/bin/sh
${pkgs.openssh}/bin/sshd -f ${sshd_config}
'';
"service/rngd/run".source = pkgs.writeScript "rngd" ''
#!/bin/sh
export PATH=$PATH:${pkgs.rng_tools}/bin
exec rngd -r /dev/hwrng
'';
};
}