Refactor for multiple systems
First step in refactoring my Nix setup to work better for configuring multiple machines. Broken things apart into more manageable chunks.
This commit is contained in:
parent
d1c7bd7cb3
commit
a5a54a86b8
26
flake.nix
26
flake.nix
|
@ -19,13 +19,13 @@
|
|||
|
||||
outputs = inputs@{ nixpkgs, home-manager, devenv, hyprland, hyprcontrib, codeium, ... }: {
|
||||
nixosConfigurations = {
|
||||
ritchie = nixpkgs.lib.nixosSystem {
|
||||
ritchie = nixpkgs.lib.nixosSystem { # My work machine
|
||||
system = "x86_64-linux";
|
||||
|
||||
specialArgs.inputs = inputs;
|
||||
|
||||
modules = [
|
||||
./system/configuration.nix
|
||||
./system/ritchie.nix
|
||||
|
||||
hyprland.nixosModules.default
|
||||
{ programs.hyprland.enable = true; }
|
||||
|
@ -34,12 +34,32 @@
|
|||
home-manager = {
|
||||
useGlobalPkgs = true;
|
||||
useUserPackages = true;
|
||||
users.tsv = import users/tsv/home.nix;
|
||||
users.tsv = import users/tsv/ritchie.nix;
|
||||
users.foxsoft = import users/foxsoft/home.nix;
|
||||
};
|
||||
}
|
||||
];
|
||||
};
|
||||
thompson = nixpkgs.lib.nixosSystem { # My personal laptop
|
||||
system = "x86_64-linux";
|
||||
|
||||
specialArgs.inputs = inputs;
|
||||
|
||||
modules = [
|
||||
./system/thompson.nix
|
||||
|
||||
hyprland.nixosModules.default
|
||||
{ programs.hyprland.enable = true; }
|
||||
|
||||
home-manager.nixosModules.home-manager {
|
||||
home-manager = {
|
||||
useGlobalPkgs = true;
|
||||
useUserPackages = true;
|
||||
users.tsv = import users/tsv/thompson.nix;
|
||||
};
|
||||
}
|
||||
];
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
|
|
|
@ -0,0 +1,29 @@
|
|||
# General filesystem setup used by my main machines.
|
||||
|
||||
{ config, ... }:
|
||||
|
||||
{
|
||||
boot.initrd.luks.devices = {
|
||||
root = {
|
||||
device = "/dev/disk/by-label/CRYPT";
|
||||
preLVM = true;
|
||||
allowDiscards = true;
|
||||
};
|
||||
};
|
||||
|
||||
fileSystems."/" =
|
||||
{ device = "/dev/disk/by-label/ROOT";
|
||||
fsType = "btrfs";
|
||||
};
|
||||
|
||||
fileSystems."/boot" =
|
||||
{ device = "/dev/disk/by-label/BOOT";
|
||||
fsType = "vfat";
|
||||
};
|
||||
|
||||
swapDevices = [
|
||||
{
|
||||
device = "/dev/mapper/vg-swap";
|
||||
}
|
||||
];
|
||||
}
|
|
@ -1,6 +1,3 @@
|
|||
# Do not modify this file! It was generated by ‘nixos-generate-config’
|
||||
# and may be overwritten by future invocations. Please make changes
|
||||
# to /etc/nixos/configuration.nix instead.
|
||||
{ config, lib, pkgs, modulesPath, ... }:
|
||||
|
||||
{
|
||||
|
@ -12,40 +9,25 @@
|
|||
boot.initrd.kernelModules = [ "dm-snapshot" ];
|
||||
boot.kernelModules = [ "kvm-intel" ];
|
||||
boot.extraModulePackages = [ ];
|
||||
|
||||
boot.initrd.luks.devices = {
|
||||
root = {
|
||||
device = "/dev/disk/by-label/CRYPT";
|
||||
preLVM = true;
|
||||
allowDiscards = true;
|
||||
};
|
||||
};
|
||||
|
||||
fileSystems."/" =
|
||||
{ device = "/dev/disk/by-label/ROOT";
|
||||
fsType = "btrfs";
|
||||
};
|
||||
|
||||
fileSystems."/boot" =
|
||||
{ device = "/dev/disk/by-label/BOOT";
|
||||
fsType = "vfat";
|
||||
};
|
||||
|
||||
swapDevices = [
|
||||
{
|
||||
device = "/dev/mapper/vg-swap";
|
||||
}
|
||||
];
|
||||
|
||||
# Enables DHCP on each ethernet and wireless interface. In case of scripted networking
|
||||
# (the default) this is the recommended approach. When using systemd-networkd it's
|
||||
# still possible to use this option, but it's recommended to use it in conjunction
|
||||
# with explicit per-interface declarations with `networking.interfaces.<interface>.useDHCP`.
|
||||
networking.useDHCP = lib.mkDefault true;
|
||||
# networking.interfaces.enp3s0.useDHCP = lib.mkDefault true;
|
||||
# networking.interfaces.wlo1.useDHCP = lib.mkDefault true;
|
||||
|
||||
nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
|
||||
powerManagement.cpuFreqGovernor = lib.mkDefault "powersave";
|
||||
hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
|
||||
|
||||
# NVidia stuff
|
||||
hardware.nvidia.modesetting.enable = true;
|
||||
services.xserver.videoDrivers = ["nvidia" ];
|
||||
|
||||
hardware.opengl.enable = true;
|
||||
hardware.nvidia.package = config.boot.kernelPackages.nvidiaPackages.stable;
|
||||
hardware.nvidia.prime = {
|
||||
sync.enable = true;
|
||||
nvidiaBusId = "PCI:1:0:0";
|
||||
intelBusId = "PCI:0:2:0";
|
||||
};
|
||||
}
|
|
@ -0,0 +1,32 @@
|
|||
|
||||
{ config, pkgs, inputs, ... }:
|
||||
|
||||
let
|
||||
nvidia-offload = pkgs.writeShellScriptBin "nvidia-offload" ''
|
||||
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
|
||||
exec "$@"
|
||||
'';
|
||||
in
|
||||
{
|
||||
imports =
|
||||
[
|
||||
./shared-configuration.nix
|
||||
./ritchie-hardware.nix
|
||||
./filesystem.nix
|
||||
];
|
||||
|
||||
networking.hostName = "ritchie";
|
||||
|
||||
users.users.foxsoft = {
|
||||
isNormalUser = true;
|
||||
extraGroups = [
|
||||
"tmux"
|
||||
];
|
||||
openssh.authorizedKeys.keyFiles = [
|
||||
../users/foxsoft/authorized_keys
|
||||
];
|
||||
};
|
||||
}
|
|
@ -1,26 +1,11 @@
|
|||
{ config, pkgs, inputs, ... }:
|
||||
|
||||
let
|
||||
nvidia-offload = pkgs.writeShellScriptBin "nvidia-offload" ''
|
||||
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
|
||||
exec "$@"
|
||||
'';
|
||||
in
|
||||
{
|
||||
imports =
|
||||
[
|
||||
./hardware-configuration.nix
|
||||
];
|
||||
|
||||
# Use the systemd-boot EFI boot loader.
|
||||
boot.loader.systemd-boot.enable = true;
|
||||
boot.loader.efi.canTouchEfiVariables = true;
|
||||
boot.supportedFilesystems = [ "ntfs" ];
|
||||
|
||||
networking.hostName = "ritchie";
|
||||
networking.networkmanager.enable = true;
|
||||
|
||||
i18n.defaultLocale = "en_GB.UTF-8";
|
||||
|
@ -51,16 +36,6 @@ in
|
|||
initialPassword = "password";
|
||||
};
|
||||
|
||||
users.users.foxsoft = {
|
||||
isNormalUser = true;
|
||||
extraGroups = [
|
||||
"tmux"
|
||||
];
|
||||
openssh.authorizedKeys.keyFiles = [
|
||||
../users/foxsoft/authorized_keys
|
||||
];
|
||||
};
|
||||
|
||||
nix.settings.trusted-users = [ "root" "tsv" ];
|
||||
|
||||
nix = {
|
||||
|
@ -76,16 +51,6 @@ in
|
|||
services.xserver.enable = true;
|
||||
services.xserver.displayManager.sddm.enable = true;
|
||||
services.xserver.desktopManager.plasma5.enable = true;
|
||||
hardware.nvidia.modesetting.enable = true;
|
||||
services.xserver.videoDrivers = ["nvidia" ];
|
||||
|
||||
hardware.opengl.enable = true;
|
||||
hardware.nvidia.package = config.boot.kernelPackages.nvidiaPackages.stable;
|
||||
hardware.nvidia.prime = {
|
||||
sync.enable = true;
|
||||
nvidiaBusId = "PCI:1:0:0";
|
||||
intelBusId = "PCI:0:2:0";
|
||||
};
|
||||
|
||||
hardware.bluetooth.enable = true;
|
||||
|
||||
|
@ -109,7 +74,6 @@ in
|
|||
|
||||
environment.variables.LC_ALL = "en_GB.UTF-8";
|
||||
|
||||
|
||||
nixpkgs.config.allowUnfree = true;
|
||||
|
||||
nixpkgs.overlays = [
|
|
@ -1,6 +1,11 @@
|
|||
{ config, pkgs, ... }:
|
||||
|
||||
{
|
||||
imports =
|
||||
[
|
||||
./packages.nix
|
||||
];
|
||||
|
||||
home.username = "tsv";
|
||||
home.homeDirectory = "/home/tsv";
|
||||
|
||||
|
@ -14,83 +19,6 @@
|
|||
MOZ_ENABLE_WAYLAND = 1;
|
||||
};
|
||||
|
||||
home.packages = with pkgs; [
|
||||
_1password-gui
|
||||
aaxtomp3
|
||||
aerc
|
||||
anki
|
||||
audible-cli
|
||||
awscli2
|
||||
awsebcli
|
||||
bitwarden
|
||||
bitwarden-cli
|
||||
cachix
|
||||
calibre
|
||||
chromium
|
||||
delta # Nice diffing pager for Git
|
||||
docker-compose
|
||||
dunst
|
||||
feh
|
||||
firefox
|
||||
fzf
|
||||
gcc
|
||||
git-crypt
|
||||
gitflow
|
||||
gnumake
|
||||
gnupg
|
||||
gimp
|
||||
grimblast
|
||||
gtk4.dev
|
||||
heroku
|
||||
htop
|
||||
hyprland-protocols
|
||||
hyprland-share-picker
|
||||
xdg-desktop-portal-hyprland
|
||||
hyprpaper
|
||||
imagemagick
|
||||
kde-gruvbox
|
||||
kitty
|
||||
kitty-themes
|
||||
libreoffice
|
||||
lshw
|
||||
microsoft-edge
|
||||
nerdfonts
|
||||
pandoc
|
||||
(pass.withExtensions (exts: [
|
||||
exts.pass-import
|
||||
exts.pass-otp
|
||||
]))
|
||||
pavucontrol
|
||||
pkg-config
|
||||
polkit-kde-agent
|
||||
progress
|
||||
pspg
|
||||
quodlibet
|
||||
qutebrowser
|
||||
ripgrep
|
||||
ruby_3_1
|
||||
rubyPackages_3_1.dip
|
||||
rubyPackages_3_1.solargraph
|
||||
rofi-wayland
|
||||
slack
|
||||
spotify
|
||||
termpdfpy
|
||||
thunderbird
|
||||
timg
|
||||
toot
|
||||
unzip
|
||||
usbutils
|
||||
w3m
|
||||
waybar
|
||||
wev
|
||||
wine
|
||||
winetricks
|
||||
wireplumber
|
||||
wl-clipboard
|
||||
wlr-randr
|
||||
zoom-us
|
||||
];
|
||||
|
||||
programs.tmux = {
|
||||
enable = true;
|
||||
plugins = with pkgs.tmuxPlugins; [
|
||||
|
|
|
@ -0,0 +1,69 @@
|
|||
{ config, pkgs, ... }:
|
||||
|
||||
{
|
||||
home.packages = with pkgs; [
|
||||
aaxtomp3
|
||||
aerc
|
||||
anki
|
||||
audible-cli
|
||||
bitwarden
|
||||
bitwarden-cli
|
||||
cachix
|
||||
calibre
|
||||
chromium
|
||||
delta # Nice diffing pager for Git
|
||||
docker-compose
|
||||
dunst
|
||||
feh
|
||||
firefox
|
||||
fzf
|
||||
gcc
|
||||
git-crypt
|
||||
gnumake
|
||||
gnupg
|
||||
gimp
|
||||
grimblast
|
||||
gtk4.dev
|
||||
htop
|
||||
hyprland-protocols
|
||||
hyprland-share-picker
|
||||
xdg-desktop-portal-hyprland
|
||||
hyprpaper
|
||||
imagemagick
|
||||
kde-gruvbox
|
||||
kitty
|
||||
kitty-themes
|
||||
lshw
|
||||
nerdfonts
|
||||
pandoc
|
||||
(pass.withExtensions (exts: [
|
||||
exts.pass-import
|
||||
exts.pass-otp
|
||||
]))
|
||||
pavucontrol
|
||||
pkg-config
|
||||
polkit-kde-agent
|
||||
progress
|
||||
pspg
|
||||
quodlibet
|
||||
qutebrowser
|
||||
ripgrep
|
||||
ruby_3_1
|
||||
rubyPackages_3_1.dip
|
||||
rubyPackages_3_1.solargraph
|
||||
rofi-wayland
|
||||
spotify
|
||||
termpdfpy
|
||||
thunderbird
|
||||
timg
|
||||
toot
|
||||
unzip
|
||||
usbutils
|
||||
w3m
|
||||
waybar
|
||||
wev
|
||||
wireplumber
|
||||
wl-clipboard
|
||||
wlr-randr
|
||||
];
|
||||
}
|
|
@ -0,0 +1,9 @@
|
|||
{ config, pkgs, ... }:
|
||||
|
||||
{
|
||||
imports =
|
||||
[
|
||||
./home.nix
|
||||
./work-packages.nix
|
||||
];
|
||||
}
|
|
@ -0,0 +1,15 @@
|
|||
{ config, pkgs, ... }:
|
||||
|
||||
{
|
||||
home.packages = with pkgs; [
|
||||
_1password-gui
|
||||
awscli2
|
||||
awsebcli
|
||||
gitflow
|
||||
heroku
|
||||
libreoffice
|
||||
microsoft-edge
|
||||
slack
|
||||
zoom-us
|
||||
];
|
||||
}
|
Loading…
Reference in New Issue