133 lines
5.0 KiB
Nix
133 lines
5.0 KiB
Nix
{ self, inputs, ... }: {
|
||
|
||
flake.nixosConfigurations."homebox" = inputs.nixpkgs.lib.nixosSystem {
|
||
|
||
modules = [
|
||
self.nixosModules.homebox
|
||
self.nixosModules.default
|
||
];
|
||
};
|
||
|
||
flake.nixosModules.homebox = { config, lib, pkgs, ... }:
|
||
|
||
{
|
||
|
||
imports = [ # Include the results of the hardware scan.
|
||
|
||
(import ./disko.nix { device1 = "/dev/nvme0n1"; device2 = "/dev/nvme1n1"; device3 = "/dev/sda"; })
|
||
];
|
||
|
||
config = {
|
||
|
||
services = {
|
||
xserver = {
|
||
enable = false;
|
||
videoDrivers = ["nvidia"];
|
||
};
|
||
displayManager = {
|
||
enable = false;
|
||
defaultSession = "hyprland";
|
||
autoLogin = {
|
||
enable = true;
|
||
user = "nathan";
|
||
};
|
||
};
|
||
pulseaudio.enable = false;
|
||
|
||
hardware.openrgb = {
|
||
enable = true;
|
||
motherboard = "amd";
|
||
};
|
||
};
|
||
|
||
hardware = {
|
||
nvidia = {
|
||
open = true;
|
||
modesetting.enable = true;
|
||
nvidiaPersistenced = true;
|
||
};
|
||
|
||
bluetooth = {
|
||
enable = true;
|
||
powerOnBoot = false;
|
||
};
|
||
};
|
||
|
||
sops = {
|
||
age.keyFile = "/var/lib/sops/age/keys.txt";
|
||
defaultSopsFile = ./secrets.yaml;
|
||
defaultSopsFormat = "yaml";
|
||
|
||
secrets = {
|
||
"nathan/pass" = {
|
||
neededForUsers = true;
|
||
};
|
||
};
|
||
};
|
||
|
||
sysconfig = {
|
||
|
||
host = "homebox";
|
||
|
||
docker.nvidia = true;
|
||
|
||
remoteBuildClient = false;
|
||
|
||
users = {
|
||
nathan = {
|
||
isSuperuser = true;
|
||
extraGroups = [ "networkmanager" "docker" ];
|
||
ssh.keys = [
|
||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIAsU69CxfQk58CvItPN426h5Alnpb60SH37wet97Vb57 nathan@laptop"
|
||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIEnUhN2uHwAJF/SLRX3wlGRmfhV3zpP88JQAYB+gh8jW nathan@localhost"
|
||
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCM7ZgIu4+ntHZbzo9iQPq5pUt7AhpOnfvvI0lWDgO4CgtkPGvyFrDnW87wjAKGKYkgKeHWHIkwq2hkEDqlPD+7xxtPpwzfyo7ZS23xlP31rL14HcG21jGHgx9SO7RmGDHHylu4PwJzz/KX59hcVmpSSV4hgB/mYA9UKe6VHv39X4y3HsjmiHwNBOKXltG4V+VkxOZD6HcZ62sgkyDTaqDpE7p+q8vHPbm6dVTKC9cMjtJmjB5EesMGKcEAy3VN2tA9M0EndtaLcBKM39vDXGpBsjURYZTu7NbQnncnO7L8kVL0nT4vA/d4mCjB51dPoXIcxn1ise0TOb9G7TxMbBQQO5YMOpiB2iuZRRvB3sYoKwbO8YfSxZi0EhvLcxkF9GBFw+pWPl0p0D2fPBbW88YQfEpoAt2EWvEu/pgaMJsTHpgaIuDwPLVQmDciX4MRoi324oElGSK8yN0P8IaCHhFchuehLBWvTi34Qot0GpnxeTzmlLzImICO9Yq0I7dk2rk= nathan@rpi-3dp"
|
||
];
|
||
shell = pkgs.zsh;
|
||
hashedPasswordFile = config.sops.secrets."nathan/pass".path;
|
||
home-manager = {
|
||
enable = true;
|
||
standalone = false;
|
||
extraModules = [
|
||
{
|
||
homeconfig = {
|
||
minimal = false;
|
||
virtual-machines = true;
|
||
hyprland.enable = false;
|
||
hyprlock.enable = false;
|
||
wal.enable = true;
|
||
mpd.enable = true;
|
||
hyprpanel.enable = false;
|
||
calcurse.enable = true;
|
||
rofi.enable = false;
|
||
firefox.enable = false;
|
||
git.enable = true;
|
||
nh.enable = true;
|
||
};
|
||
|
||
services.hypridle.enable = lib.mkForce false;
|
||
|
||
home.packages = with pkgs; [
|
||
wayvnc
|
||
openrgb
|
||
];
|
||
}
|
||
];
|
||
};
|
||
};
|
||
};
|
||
};
|
||
|
||
|
||
|
||
# This value determines the NixOS release from which the default
|
||
# settings for stateful data, like file locations and database versions
|
||
# on your system were taken. It‘s perfectly fine and recommended to leave
|
||
# this value at the release version of the first install of this system.
|
||
# Before changing this value read the documentation for this option
|
||
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
|
||
system.stateVersion = "23.05"; # Did you read the comment?
|
||
};
|
||
|
||
};
|
||
}
|