depot/ops/nixos/porcorosso/default.nix

269 lines
7.2 KiB
Nix
Raw Normal View History

# SPDX-FileCopyrightText: 2020 Luke Granger-Brown <depot@lukegb.com>
#
# SPDX-License-Identifier: Apache-2.0
{ depot, lib, pkgs, rebuilder, config, ... }:
let
inherit (depot.ops) secrets;
nvidia-offload-profile = ''
export __NV_PRIME_RENDER_OFFLOAD=1
export __NV_PRIME_RENDER_OFFLOAD_PROVIDER=NVIDIA-G0
export __GLX_VENDOR_LIBRARY_NAME=nvidia
export __VK_LAYER_NV_optimus=NVIDIA_only
'';
nvidia-offload = pkgs.writeShellScriptBin "nvidia-offload"
(nvidia-offload-profile + ''
exec -a "$0" "$@"
'');
in {
imports = [
../lib/zfs.nix
../lib/graphical-client.nix
2020-07-19 17:20:21 +00:00
../lib/whitby-distributed.nix
];
boot.initrd.availableKernelModules = [
"xhci_pci"
"ahci"
"nvme"
"usbhid"
"usb_storage"
"sd_mod"
"rtsx_pci_sdmmc"
];
boot.kernelModules = [ "kvm-intel" ];
2020-05-11 20:15:49 +00:00
boot.supportedFilesystems = [ "ntfs" ];
2020-11-04 17:09:53 +00:00
boot.kernel.sysctl = {
"abi.vsyscall32" = "0";
};
fileSystems = let
zfs = device: {
device = device;
fsType = "zfs";
};
in {
"/" = zfs "zpool/local/root";
"/nix" = zfs "zpool/local/nix";
"/tmp" = zfs "zpool/local/tmp";
"/var" = zfs "zpool/safe/var";
"/home" = zfs "zpool/safe/home";
"/persist" = zfs "zpool/safe/persist";
"/boot" = {
device = "/dev/disk/by-label/NIXBOOT";
fsType = "vfat";
};
2020-05-11 20:15:49 +00:00
"/data" = {
device = "/dev/disk/by-label/BULKDATA";
fsType = "ntfs";
2020-06-13 17:29:10 +00:00
options = [ "rw" "uid=1000" "gid=100" "dmask=022" "fmask=024" "windows_names" ];
2020-05-11 20:15:49 +00:00
};
2020-07-19 16:49:56 +00:00
"/home/lukegb/mnt" = { device = "192.168.1.40:/"; fsType = "nfs"; };
};
nix.maxJobs = lib.mkDefault 12;
powerManagement.cpuFreqGovernor = lib.mkDefault "powersave";
hardware.enableRedistributableFirmware = true;
# Use the systemd-boot EFI boot loader.
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
# ZFS!
services.zfs.rollbackOnBoot.enable = true;
# Enable HyperV guesting
virtualisation.hypervGuest.enable = true;
2020-10-04 00:03:28 +00:00
# Enable Podman
virtualisation.podman = {
enable = true;
dockerCompat = true;
};
2020-11-03 16:03:22 +00:00
# Enable libvirtd.
virtualisation.libvirtd = {
enable = true;
};
networking.hostName = "porcorosso";
networking.hostId = "1ee729a4";
# Boot faster.
systemd.services.systemd-udev-settle.enable = false;
systemd.services.NetworkManager-wait-online.enable = false;
# The global useDHCP flag is deprecated, therefore explicitly set to false here.
# Per-interface useDHCP will be mandatory in the future, so this generated config
# replicates the default behaviour.
# Use NetworkManager instead.
networking.useDHCP = false;
networking.interfaces.eno1.useDHCP = false;
networking.networkmanager.enable = true;
my.ip.tailscale = "100.125.26.108";
# Set your time zone.
time.timeZone = "Europe/London";
# List packages installed in system profile. To search, run:
# $ nix search wget
environment.systemPackages = with pkgs; [
pciutils
nvidia-offload
rebuilder
2020-05-10 01:12:29 +00:00
deluge
(writeShellScriptBin "windows" ''
set -ue
if [[ $EUID -ne 0 ]]; then
exec sudo "$0" "$@"
fi
2020-10-25 11:36:16 +00:00
efibootmgr -n 0001
systemctl reboot
'')
];
# Some programs need SUID wrappers, can be configured further or are
# started in user sessions.
# programs.gnupg.agent = { enable = true; enableSSHSupport = true; };
# List services that you want to enable:
# Enable CUPS to print documents.
services.printing.enable = true;
services.printing.drivers = with depot.pkgs; [ intermec-cups-driver ];
2020-12-19 19:26:36 +00:00
# Add fwupd.
services.fwupd.enable = true;
# Enable the X11 windowing system.
services.xserver.enable = true;
services.xserver.layout = "us";
services.xserver.libinput.enable = true;
services.xserver.windowManager.i3.enable = true;
2020-12-23 23:35:16 +00:00
#services.xserver.videoDrivers = [ "nvidia" ];
services.xserver.videoDrivers = [ "intel" ];
specialisation.intelGraphics.configuration = {
services.xserver.videoDrivers = lib.mkForce [ "intel" ];
};
services.xserver.displayManager.gdm = {
enable = true;
};
hardware.opengl.driSupport32Bit = true;
hardware.opengl.extraPackages = with pkgs; [
intel-media-driver vaapiVdpau libvdpau-va-gl libva
];
hardware.opengl.extraPackages32 = with pkgs.pkgsi686Linux; [ libva ];
hardware.pulseaudio.support32Bit = true;
# Define a user account.
users.users.lukegb = {
2020-11-03 16:03:22 +00:00
extraGroups = [ "wheel" "networkmanager" "libvirtd" ];
2020-10-25 11:36:16 +00:00
};
my.home-manager.system = {...}: {
home.packages = lib.mkAfter (with pkgs; [
(steam.override { extraProfile = nvidia-offload-profile; })
(writeScriptBin "javaws" ''
#!/bin/sh
exec ${depot.nix.pkgs.javaws-env}/bin/javaws-env "$@"
'')
2020-11-24 02:56:18 +00:00
factorio-experimental
(depot.nix.pkgs.secretsync.configure {
workingDir = "/home/lukegb/depot";
gitlabAccessToken = secrets.deployer.gitlabAccessToken;
manifestVariable = "SECRETS_MANIFEST";
variablesToFile = {
"OPS_SECRETS_DEFAULT_NIX" = "ops/secrets/default.nix";
};
})
efibootmgr
iw
2020-11-25 02:13:14 +00:00
obs-studio
2020-05-31 17:58:29 +00:00
vulkan-tools
2020-10-25 11:36:16 +00:00
]);
2020-10-25 12:00:15 +00:00
xdg.configFile."pulse/default.pa".source = ./default.pa;
};
2020-05-22 12:04:47 +00:00
# github.com/target/lorri
services.lorri.enable = true;
# Things to persist.
services.openssh.hostKeys = [
{
path = "/persist/etc/ssh/ssh_host_ed25519_key";
type = "ed25519";
}
{
path = "/persist/etc/ssh/ssh_host_rsa_key";
type = "rsa";
bits = 4096;
}
];
environment.etc = {
"NetworkManager/system-connections" = {
source = "/persist/etc/NetworkManager/system-connections/";
};
"nixos" = { source = "/persist/etc/nixos/"; };
};
systemd.tmpfiles.rules = [
#"L /etc/nixos - - - - /persist/etc/nixos"
2020-11-04 17:09:53 +00:00
"d /var/lib/libvirt 0755 root - - -"
];
systemd.mounts = let
bindMount' = dir: {
unitConfig.RequiresMountsFor = dir;
options = "bind";
what = "/persist${dir}";
where = dir;
};
bindMountSvc = dir: svc: (bindMount' dir) // {
bindsTo = [svc];
partOf = [svc];
};
bindMount = dir: (bindMount' dir) // {
wantedBy = ["multi-user.target"];
};
in [
(bindMountSvc "/var/lib/libvirt" "libvirtd.service")
(bindMount "/root")
];
# Enable Thunderbolt device management.
services.hardware.bolt.enable = true;
2020-06-20 22:11:24 +00:00
services.redis.enable = true;
services.postgresql.enable = true;
services.postgresql.ensureUsers = [{
name = "lukegb";
ensurePermissions = {
"ALL TABLES IN SCHEMA public" = "ALL PRIVILEGES";
"DATABASE lukegb" = "ALL PRIVILEGES";
};
}];
services.postgresql.authentication = ''
local all all trust
host all all 127.0.0.1/32 trust
host all all ::1/128 trust
'';
nix.buildMachines = [ {
hostName = "totoro";
system = "x86_64-linux";
maxJobs = 4;
speedFactor = 2;
supportedFeatures = [ "nixos-test" "benchmark" "big-parallel" "kvm" ];
mandatoryFeatures = [ ];
}];
2020-06-20 22:11:24 +00:00
# This value determines the NixOS release with which your system is to be
# compatible, in order to avoid breaking some software such as database
# servers. You should change this only after NixOS release notes say you
# should.
2020-05-11 20:15:49 +00:00
system.stateVersion = "20.03"; # Did you read the comment?
2020-06-13 17:31:37 +00:00
}