Progress rewrite further
This commit is contained in:
parent
bc6d1e6984
commit
b00e1c1c9d
15 changed files with 169 additions and 44 deletions
|
@ -1,4 +1,4 @@
|
||||||
{ config, pkgs, lib, ... }:
|
{ pkgs, ... }:
|
||||||
|
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
@ -14,14 +14,6 @@
|
||||||
useDHCP = true;
|
useDHCP = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
hardware.cpu.amd.updateMicrocode = true;
|
|
||||||
|
|
||||||
services = {
|
|
||||||
fstrim.enable = true;
|
|
||||||
btrfs.autoScrub.enable = true;
|
|
||||||
fwupd.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
boot = {
|
boot = {
|
||||||
loader = {
|
loader = {
|
||||||
canTouchEfiVariables = true;
|
canTouchEfiVariables = true;
|
||||||
|
@ -35,37 +27,17 @@
|
||||||
tmp.useTmpfs = true;
|
tmp.useTmpfs = true;
|
||||||
kernelPackages = pkgs.linuxPackages_xanmod_latest;
|
kernelPackages = pkgs.linuxPackages_xanmod_latest;
|
||||||
supportedFilesystems = [ "btfs" "vfat" "xfs" ];
|
supportedFilesystems = [ "btfs" "vfat" "xfs" ];
|
||||||
kernelModules = [ "kvm-amd" ];
|
|
||||||
extraModprobeConfig = "options kvm_amd nested=1";
|
|
||||||
initrd = {
|
initrd = {
|
||||||
availableKernelModules = [ "nvme" "xhci_pci" "ahci" "usbhid" "usb_storage" "sd_mod" ];
|
availableKernelModules = [ "nvme" "xhci_pci" "ahci"
|
||||||
postDeviceCommands = lib.mkAfter ''
|
"usbhid" "usb_storage" "sd_mod" ];
|
||||||
mkdir /btrfs_tmp
|
|
||||||
mount ${config.fileSystems."/".device} /btrfs_tmp
|
|
||||||
if [[ -e /btrfs_tmp/root ]]; then
|
|
||||||
mkdir -p /btrfs_tmp/old_roots
|
|
||||||
timestamp=$(date --date="@$(stat -c %Y /btrfs_tmp/root)" "+%Y-%m-%-d_%H:%M:%S")
|
|
||||||
mv /btrfs_tmp/root "/btrfs_tmp/old_roots/$timestamp"
|
|
||||||
fi
|
|
||||||
|
|
||||||
delete_subvolume_recursively() {
|
|
||||||
IFS=$'\n'
|
|
||||||
for i in $(btrfs subvolume list -o "$1" | cut -f 9- -d ' '); do
|
|
||||||
delete_subvolume_recursively "/btrfs_tmp/$i"
|
|
||||||
done
|
|
||||||
btrfs subvolume delete "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
for i in $(find /btrfs_tmp/old_roots/ -maxdepth 1 -mtime +30); do
|
|
||||||
delete_subvolume_recursively "$i"
|
|
||||||
done
|
|
||||||
|
|
||||||
btrfs subvolume create /btrfs_tmp/root
|
|
||||||
umount /btrfs_tmp
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
services = {
|
||||||
|
fstrim.enable = true;
|
||||||
|
btrfs.autoScrub.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
fileSystems = {
|
fileSystems = {
|
||||||
# These are system specific. If you have any additional drives that are not
|
# These are system specific. If you have any additional drives that are not
|
||||||
# your root device you can add and mount them here. Added nofail so that you can
|
# your root device you can add and mount them here. Added nofail so that you can
|
||||||
|
@ -85,13 +57,6 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
nixpkgs = {
|
|
||||||
config = {
|
|
||||||
allowUnfree = true;
|
|
||||||
};
|
|
||||||
hostPlatform = lib.mkDefault "x86_64-linux";
|
|
||||||
};
|
|
||||||
|
|
||||||
system.stateVersion = "24.11"; # [managed by install.sh] { state version }
|
system.stateVersion = "24.11"; # [managed by install.sh] { state version }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,8 +4,11 @@
|
||||||
imports = let
|
imports = let
|
||||||
modules = ../../modules/nixos;
|
modules = ../../modules/nixos;
|
||||||
in [
|
in [
|
||||||
"${modules}/hardware/nvidia"
|
"${modules}/core"
|
||||||
"${modules}/hardware/audio"
|
"${modules}/hardware/audio"
|
||||||
|
"${modules}/hardware/gpu/nvidia"
|
||||||
|
"${modules}/hardware/cpu/amd"
|
||||||
|
"${modules}/multimedia"
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,5 +6,7 @@
|
||||||
dirs = builtins.readDir path;
|
dirs = builtins.readDir path;
|
||||||
in
|
in
|
||||||
builtins.filter (name: dirs.${name} == "directory") (builtins.attrNames dirs);
|
builtins.filter (name: dirs.${name} == "directory") (builtins.attrNames dirs);
|
||||||
|
|
||||||
|
getModuleImports = builtins.attrNames (builtins.removeAttrs (builtins.readDir ./.) ["default.nix"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
6
modules/nixos/core/default.nix
Normal file
6
modules/nixos/core/default.nix
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
{ lib }:
|
||||||
|
|
||||||
|
{
|
||||||
|
imports = lib.getModuleImports;
|
||||||
|
}
|
||||||
|
|
27
modules/nixos/core/fonts.nix
Normal file
27
modules/nixos/core/fonts.nix
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
{ pkgs, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
fonts = {
|
||||||
|
packages = with pkgs; [
|
||||||
|
(nerdfonts.override {
|
||||||
|
fonts = [
|
||||||
|
"GoMono"
|
||||||
|
];
|
||||||
|
})
|
||||||
|
ipafont
|
||||||
|
noto-fonts-emoji
|
||||||
|
cantarell-fonts
|
||||||
|
newcomputermodern
|
||||||
|
];
|
||||||
|
|
||||||
|
fontconfig = {
|
||||||
|
enable = true;
|
||||||
|
cache32Bit = true;
|
||||||
|
subpixel.rgba = "rgb";
|
||||||
|
defaultFonts = {
|
||||||
|
monospace = [ "Go Mono Nerd Font" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
28
modules/nixos/core/impermanence.nix
Normal file
28
modules/nixos/core/impermanence.nix
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
{ config, lib, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
boot.initrd.postDeviceCommands = lib.mkAfter ''
|
||||||
|
mkdir /btrfs_tmp
|
||||||
|
mount ${config.fileSystems."/".device} /btrfs_tmp
|
||||||
|
if [[ -e /btrfs_tmp/root ]]; then
|
||||||
|
mkdir -p /btrfs_tmp/old_roots
|
||||||
|
timestamp=$(date --date="@$(stat -c %Y /btrfs_tmp/root)" "+%Y-%m-%-d_%H:%M:%S")
|
||||||
|
mv /btrfs_tmp/root "/btrfs_tmp/old_roots/$timestamp"
|
||||||
|
fi
|
||||||
|
|
||||||
|
delete_subvolume_recursively() {
|
||||||
|
IFS=$'\n'
|
||||||
|
for i in $(btrfs subvolume list -o "$1" | cut -f 9- -d ' '); do
|
||||||
|
delete_subvolume_recursively "/btrfs_tmp/$i"
|
||||||
|
done
|
||||||
|
btrfs subvolume delete "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
for i in $(find /btrfs_tmp/old_roots/ -maxdepth 1 -mtime +30); do
|
||||||
|
delete_subvolume_recursively "$i"
|
||||||
|
done
|
||||||
|
|
||||||
|
btrfs subvolume create /btrfs_tmp/root
|
||||||
|
umount /btrfs_tmp
|
||||||
|
'';
|
||||||
|
}
|
19
modules/nixos/core/nix.nix
Normal file
19
modules/nixos/core/nix.nix
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
{ lib, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
nix = {
|
||||||
|
settings = {
|
||||||
|
auto-optimise-store = true;
|
||||||
|
use-xdg-base-directories = true;
|
||||||
|
trusted-users = [ "@wheel" ];
|
||||||
|
allowed-users = [ "@wheel" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nixpkgs = {
|
||||||
|
config = {
|
||||||
|
allowUnfree = true;
|
||||||
|
};
|
||||||
|
hostPlatform = lib.mkDefault "x86_64-linux";
|
||||||
|
};
|
||||||
|
}
|
32
modules/nixos/core/security.nix
Normal file
32
modules/nixos/core/security.nix
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
{ ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
programs.gnupg = {
|
||||||
|
enable = true;
|
||||||
|
enableSSHSupport = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Sudo is scheduled to be replaced by systemd's run0.
|
||||||
|
* The blocker for this is persistent authentication support.
|
||||||
|
*
|
||||||
|
* https://github.com/systemd/systemd/issues/33366
|
||||||
|
* https://github.com/polkit-org/polkit/issues/472
|
||||||
|
*/
|
||||||
|
security.sudo = {
|
||||||
|
enable = true;
|
||||||
|
execWheelOnly = true;
|
||||||
|
extraConfig = ''
|
||||||
|
Defaults lecture="never"
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
security.apparmor.enable = true;
|
||||||
|
networking.firewall.enable = true;
|
||||||
|
|
||||||
|
/* Disable the root user */
|
||||||
|
users = {
|
||||||
|
users.root.hashedPassword = "!";
|
||||||
|
mutableUsers = false;
|
||||||
|
};
|
||||||
|
}
|
10
modules/nixos/core/zsh.nix
Normal file
10
modules/nixos/core/zsh.nix
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
{ ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
programs.zsh = {
|
||||||
|
enable = true;
|
||||||
|
shellInit = ''
|
||||||
|
export ZDOTDIR=$HOME/.local/share/zsh
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,6 +1,7 @@
|
||||||
{ ... }:
|
{ ... }:
|
||||||
|
|
||||||
{
|
{
|
||||||
|
security.rtkit.enable = true;
|
||||||
services.pipewire = {
|
services.pipewire = {
|
||||||
enable = true;
|
enable = true;
|
||||||
alsa = {
|
alsa = {
|
||||||
|
|
11
modules/nixos/hardware/cpu/amd/default.nix
Normal file
11
modules/nixos/hardware/cpu/amd/default.nix
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
{ pkgs, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
boot = {
|
||||||
|
kernelModules = [ "kvm-amd" ];
|
||||||
|
extraModprobeConfig = "options kvm_amd nested=1";
|
||||||
|
};
|
||||||
|
|
||||||
|
hardware.cpu.amd.updateMicrocode = true;
|
||||||
|
hardware.firmware = with pkgs; [ linux-firmware ];
|
||||||
|
}
|
5
modules/nixos/multimedia/default.nix
Normal file
5
modules/nixos/multimedia/default.nix
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{ lib }:
|
||||||
|
|
||||||
|
{
|
||||||
|
imports = lib.getModuleImports;
|
||||||
|
}
|
5
modules/nixos/multimedia/games/default.nix
Normal file
5
modules/nixos/multimedia/games/default.nix
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{ ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
11
modules/nixos/user/caem.nix
Normal file
11
modules/nixos/user/caem.nix
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
{ pkgs, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
users.users.caem = {
|
||||||
|
isNormalUser = true;
|
||||||
|
shell = pkgs.zsh;
|
||||||
|
extraGroups = [
|
||||||
|
"wheel"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue