nix-config/hosts/rpi-netboot/default.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

136 lines
2.7 KiB
Nix
Raw Normal View History

2022-06-09 01:43:26 +02:00
{ hostRegistry, nixpkgs, config, lib, pkgs, modulesPath, ... }:
2022-03-13 23:49:12 +01:00
{
2022-06-12 17:26:32 +02:00
c3d2 = {
2022-03-13 23:49:12 +01:00
isInHq = true;
mergeHostsFile = true;
hq.interface = "eth0";
hq.statistics.enable = false;
audioServer.enable = true;
k-ot.enable = true;
autoUpdate = false;
hq.journalToMqtt = false;
2022-06-12 17:26:32 +02:00
};
2022-09-14 20:10:15 +02:00
boot.kernelParams = [ "verbose" "console=tty0" ];
2022-03-13 23:49:12 +01:00
swapDevices = [ ];
hardware = {
bluetooth.enable = true;
enableRedistributableFirmware = true;
};
2022-06-12 17:26:32 +02:00
2022-03-13 23:49:12 +01:00
powerManagement.cpuFreqGovernor = lib.mkDefault "performance";
networking = {
2022-06-13 20:36:41 +02:00
hostName = "rpi-netboot";
2022-03-13 23:49:12 +01:00
useDHCP = false;
interfaces.eth0.useDHCP = true;
firewall.enable = false;
};
fileSystems = {
2022-06-12 17:26:32 +02:00
"/" = {
fsType = "tmpfs";
options = [ "mode=0755" ];
2022-06-12 17:26:32 +02:00
};
"/etc" = {
fsType = "tmpfs";
options = [ "mode=0755" ];
2022-06-12 17:26:32 +02:00
};
# mount the server's /nix/store
"/nix/store" = {
2022-06-22 00:16:03 +02:00
device = "${hostRegistry.hosts.nfsroot.ip4}:/nix/store";
fsType = "nfs";
options = [ "nfsvers=3" "proto=tcp" "nolock" "hard" "async" "ro" ];
neededForBoot = true;
};
"/var" = {
fsType = "tmpfs";
options = [ "mode=0755" ];
2022-06-12 17:26:32 +02:00
};
};
2022-03-13 23:49:12 +01:00
environment.systemPackages = with pkgs; [
libraspberrypi
raspberrypi-eeprom
iw
libva-utils
mpv
vlc
yt-dlp
ncpamixer
pulseaudio # required for pactl
chromium
firefox
pavucontrol
glxinfo
2022-09-17 19:31:10 +02:00
projectm
2022-09-28 23:59:34 +02:00
# tracer-game
bevy_julia
2022-09-16 00:10:48 +02:00
bevy_mandelbrot
allcolors
2022-03-13 23:49:12 +01:00
];
programs.tmux.enable = true;
2022-03-13 23:49:12 +01:00
2022-06-09 02:02:44 +02:00
nix.gc.automatic = lib.mkForce false;
2022-03-13 23:49:12 +01:00
security.sudo = {
enable = true;
wheelNeedsPassword = false;
};
console = {
font = "${pkgs.terminus_font}/share/consolefonts/ter-u28n.psf.gz";
keyMap = "de";
};
services = {
2022-03-13 23:49:12 +01:00
# Do not log to flash
journald.extraConfig = ''
Storage=volatile
2022-06-12 17:26:32 +02:00
'';
openssh.enable = true;
xserver = {
2022-06-13 15:48:05 +02:00
enable = true;
layout = "de";
xkbOptions = "eurosign:e";
displayManager = {
lightdm.enable = true;
autoLogin = {
enable = true;
user = "k-ot";
2022-06-12 17:26:32 +02:00
};
defaultSession = "gnome-xorg";
2022-06-12 17:26:32 +02:00
};
desktopManager.gnome.enable = true;
};
};
2022-06-12 17:26:32 +02:00
systemd = {
2022-06-09 02:02:44 +02:00
# r/o /nix/store
services = {
2022-06-09 02:02:44 +02:00
nix-daemon.enable = false;
2022-06-13 15:48:05 +02:00
nix-gc.enable = false;
2022-06-12 17:26:32 +02:00
};
2022-06-09 02:02:44 +02:00
sockets.nix-daemon.enable = false;
2022-06-12 17:26:32 +02:00
user.services.x11vnc = {
description = "X11 VNC server";
wantedBy = [ "graphical-session.target" ];
partOf = [ "graphical-session.target" ];
serviceConfig = {
ExecStart = ''
${pkgs.x11vnc}/bin/x11vnc -shared -forever -passwd k-ot
'';
RestartSec = 3;
Restart = "always";
2022-06-12 17:26:32 +02:00
};
};
};
2022-03-13 23:49:12 +01:00
system.stateVersion = "21.11"; # Did you read the comment?
}