System/machines/universe/configuration.nix

84 lines
2.1 KiB
Nix
Raw Permalink Normal View History

2023-08-05 13:37:03 -04:00
{ config, lib, pkgs, inputs, ... }:
{
# Setup hardware
imports = [ inputs.nixos-hardware.nixosModules.raspberry-pi-4 ];
fileSystems = {
"/" = {
device = "/dev/disk/by-label/NIXOS_SD";
fsType = "ext4";
options = [ "noatime" ];
};
};
# Sops setup for this machine
sops.secrets = {
# "borg-ssh-key" = {
# sopsFile = ../../secrets/tounge/borg.yaml;
# format = "yaml";
# };
# "borg-password" = {
# sopsFile = ../../secrets/tounge/borg.yaml;
# format = "yaml";
# };
"wifi" = {
sopsFile = ../../secrets/universe/wifi;
format = "binary";
};
};
# Setup system configuration
nathan = {
services = {
borg = {
enable = false;
extraExcludes = [ "/var/lib/docker" "/var/log" ];
passwordFile = config.sops.secrets."borg-password".path;
sshKey = config.sops.secrets."borg-ssh-key".path;
};
};
config = {
setupGrub = false;
userUid = "1001";
nix = {
2023-08-14 02:09:56 -04:00
autoUpdate = false;
2023-08-05 13:37:03 -04:00
autoGC = true;
};
harden = false;
};
};
2023-08-05 14:20:39 -04:00
# Use just normal ass linux, without zfs
2023-08-08 12:05:08 -04:00
boot.kernelPackages = pkgs.linuxKernel.packages.linux_6_4;
2023-08-05 14:20:39 -04:00
boot.supportedFilesystems =
lib.mkForce [ "btrfs" "cifs" "f2fs" "jfs" "ntfs" "vfat" "xfs" ];
2023-08-05 13:37:03 -04:00
# Configure networking
networking = {
domain = "mccarty.io";
useDHCP = true;
wireless = {
environmentFile = config.sops.secrets."wifi".path;
networks = { "Apollo" = { psk = "@PSK_WIFI@"; }; };
2023-08-05 15:14:34 -04:00
enable = true;
interfaces = [ "wlan0" ];
2023-08-05 13:37:03 -04:00
};
# Open ports in firewall
firewall = {
allowedTCPPorts = [ ];
allowedUDPPorts = [ ];
};
};
# Setup home manager
home-manager.users.nathan = import ./home.nix;
2023-10-07 20:28:01 -04:00
# Printer firmware
services.klipper = {
package = inputs.nixpkgs-unstable.legacyPackages.${pkgs.system}.klipper;
enable = true;
2023-10-07 23:44:31 -04:00
configFile = ./klipper/printer.cfg;
2023-10-07 20:28:01 -04:00
};
services.moonraker = { enable = true; };
services.mainsail = {
package = inputs.nixpkgs-unstable.legacyPackages.${pkgs.system}.mainsail;
enable = true;
2023-08-05 16:19:58 -04:00
};
2023-08-05 13:37:03 -04:00
}