diff options
author | Linnnus <[email protected]> | 2024-12-21 15:32:01 +0000 |
---|---|---|
committer | Linnnus <[email protected]> | 2024-12-27 09:07:36 +0100 |
commit | 99f77809ea6f5d873c1b8cfd7b4816f877e29316 (patch) | |
tree | 659c28032b21e012973be4880e7c48291af32f83 /hosts | |
parent | 13774af03212266507af7f6b722978dd5db538e5 (diff) |
Add new host omar
Diffstat (limited to 'hosts')
-rw-r--r-- | hosts/omar/configuration.nix | 81 | ||||
-rw-r--r-- | hosts/omar/hardware-configuration.nix | 54 |
2 files changed, 135 insertions, 0 deletions
diff --git a/hosts/omar/configuration.nix b/hosts/omar/configuration.nix new file mode 100644 index 0000000..9248c3c --- /dev/null +++ b/hosts/omar/configuration.nix @@ -0,0 +1,81 @@ +{ + config, + lib, + pkgs, + ... +}: { + imports = [ + # Include the results of the hardware scan. + ./hardware-configuration.nix + + ../../shared/nixos/common-nix-settings + ../../shared/nixos/common-shell-settings + ../../shared/nixos/common-hm-settings + ../../shared/nixos/zfs-impermenance + ]; + + boot.loader.grub = { + # Use the GRUB 2 boot loader. + enable = true; + + # Install grub on the main HDD. + device = "/dev/sda"; + + # ZFS on root requires GRUB to be able to read the pool. + # The pool was created with `-o compatibility=grub2`. + zfsSupport = true; + }; + + # The host id is required by ZFS. + # It is used to (among other things) avoid multiple hosts modifying the same dataset unsafely. + # This was randomly generated. + networking.hostId = "b6e8e80a"; + + # Should match containing folder. + networking.hostName = "omar"; + + # Pick only one of the below networking options. + networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. + # networking.networkmanager.enable = true; # Easiest to use and most distros use this by default. + + # Create the main user. + users.users.linus = { + isNormalUser = true; + hashedPassword = "$y$j9T$UmZES4WC8FWrjBvdazq2e/$rzneAKZeySwSVKiSZJfXC.fciiQdGqxB5uyRaPQ6OF."; + extraGroups = ["wheel"]; + }; + users.mutableUsers = false; + + home-manager.users.linus = { + imports = [ + # I am planning on using this host when traveling. + ../../shared/home-manager/development-full + ]; + }; + + # Enable the X11 windowing system. + # services.xserver.enable = true; + + # Configure keymap in X11 + # services.xserver.xkb.layout = "us"; + # services.xserver.xkb.options = "eurosign:e,caps:escape"; + + # Enable CUPS to print documents. + # services.printing.enable = true; + + # Enable sound. + # hardware.pulseaudio.enable = true; + # OR + # services.pipewire = { + # enable = true; + # pulse.enable = true; + # }; + + # Enable touchpad support (enabled default in most desktopManager). + # services.libinput.enable = true; + + # Enable the OpenSSH daemon. + services.openssh.enable = true; + + system.stateVersion = "24.11"; +} diff --git a/hosts/omar/hardware-configuration.nix b/hosts/omar/hardware-configuration.nix new file mode 100644 index 0000000..611bfa3 --- /dev/null +++ b/hosts/omar/hardware-configuration.nix @@ -0,0 +1,54 @@ +# 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, + ... +}: { + imports = [ + (modulesPath + "/installer/scan/not-detected.nix") + ]; + + boot.initrd.availableKernelModules = ["uhci_hcd" "ehci_pci" "ahci" "usb_storage" "sd_mod"]; + boot.initrd.kernelModules = []; + boot.kernelModules = []; + boot.extraModulePackages = []; + + fileSystems."/" = { + device = "rpool/local/root"; + fsType = "zfs"; + }; + + fileSystems."/nix" = { + device = "rpool/local/nix"; + fsType = "zfs"; + }; + + fileSystems."/persist" = { + device = "rpool/safe/persist"; + fsType = "zfs"; + }; + + fileSystems."/home" = { + device = "rpool/safe/home"; + fsType = "zfs"; + }; + + swapDevices = [ + {device = "/dev/disk/by-uuid/a719dc89-0c69-4384-b9f7-b82b2a0f5cf1";} + ]; + + # 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.enp9s0.useDHCP = lib.mkDefault true; + # networking.interfaces.wlp5s0.useDHCP = lib.mkDefault true; + + nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; + hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; +} |