nixos/flake.nix

246 lines
7.3 KiB
Nix
Raw Normal View History

2023-06-21 17:41:35 +01:00
{
description = "Evie's machine configurations";
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
stylix = {
url = "github:danth/stylix";
inputs.nixpkgs.follows = "nixpkgs";
};
};
2023-06-21 17:41:35 +01:00
2024-01-30 14:21:50 +00:00
outputs = {
self,
2024-01-30 14:21:50 +00:00
nixpkgs,
home-manager,
stylix,
...
}: let
systemConfig = {
hostName ? "Atlas",
user ? "xenia",
system ? "x86_64-linux",
stateVersion ? "23.05",
systemModules ? [],
homeModules ? [],
2024-01-30 14:21:50 +00:00
}: let
defaultUserShell = "zsh";
specialArgs = {
inherit hostName user;
accentColour = "base07"; # catppuccin lavender
catppuccinVariant = "Mocha";
};
2024-01-30 14:21:50 +00:00
in
nixpkgs.lib.nixosSystem {
inherit system specialArgs;
modules =
[
home-manager.nixosModules.home-manager
stylix.nixosModules.stylix
./hosts/${hostName}/configuration.nix
./hosts/${hostName}/hardware-configuration.nix
./system/default.nix
({
lib,
pkgs,
...
}: {
2024-01-19 09:47:14 +00:00
nix = {
enable = true;
settings = {
2024-03-02 11:47:39 +00:00
cores = 2;
2024-03-02 11:44:31 +00:00
max-jobs = 1;
2024-01-30 14:21:50 +00:00
trusted-users = ["root" user];
experimental-features = ["nix-command" "flakes"];
2024-01-19 09:47:14 +00:00
auto-optimise-store = true;
};
2024-01-19 09:47:14 +00:00
channel.enable = true;
2024-02-17 08:44:26 +00:00
nixPath = ["nixpkgs=${pkgs.path}"];
registry.nixpkgs.flake = nixpkgs;
2024-01-19 09:47:14 +00:00
gc = {
automatic = true;
options = "--delete-older-than 7d";
};
2024-01-19 09:47:14 +00:00
optimise.automatic = true;
extraOptions = ''
keep-outputs = false
keep-derivations = false
2024-01-19 09:47:14 +00:00
min-free = ${toString (100 * 1024 * 1024)}
max-free = ${toString (1024 * 1024 * 1024)}
'';
};
2024-02-09 14:08:42 +00:00
nixpkgs.config.allowUnfree = true;
networking = {inherit hostName;};
programs.${defaultUserShell}.enable = true;
system = {
inherit stateVersion;
autoUpgrade = {
enable = true;
flake = lib.mkDefault self.outPath;
flags = [
"--update-input"
"nixpkgs"
"--no-write-lock-file"
"-L" # print build logs
];
dates = "02:00";
};
};
2024-02-11 07:16:08 +00:00
users = {
defaultUserShell = pkgs.${defaultUserShell};
2024-02-11 07:16:08 +00:00
users = let
authorizedKeys.keys = [
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAINI1dWlS16Keil0MGPWmMsBzx8F9ylfz+fRwxUr8/tZ/ ion"
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDOcgeR3hh23aTiXnyC37xdP8oXfTZbbjgWzkUyxhT9P root@Vanguard"
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIANfkqd5lPTsSPU3SRYnAa1UjCYDmDeBTyzq5McmWlm6 xenia@Vanguard"
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJ/ZSSCN5sqrA+tdoIZr5EUm5DRuBV4dQ7J+QBEtUwUU xenia@Northstar"
];
in {
root.openssh = {inherit authorizedKeys;};
${user} = {
group = "users";
shell = pkgs.nushell;
2024-02-11 07:16:08 +00:00
isNormalUser = true;
description = "Evie Litherland-Smith";
extraGroups = ["networkmanager" "wheel" "video" "input" "uinput"];
initialHashedPassword = "$y$j9T$tHIPQt09Kf3KH2eIRze3g/$2mwSlcq27DTGvHNPJ5EP9/1CfL3bXP0F6oS/Vuffmn3";
openssh = {inherit authorizedKeys;};
};
};
2024-01-19 09:47:14 +00:00
};
home-manager = {
extraSpecialArgs = specialArgs;
2024-01-19 09:47:14 +00:00
useGlobalPkgs = true;
useUserPackages = true;
users = {
root = {
2024-01-30 14:21:50 +00:00
imports = [./home/default.nix];
2024-01-19 09:47:14 +00:00
home = {
inherit stateVersion;
username = "root";
homeDirectory = "/root";
};
2024-01-19 09:47:14 +00:00
programs.home-manager.enable = true;
};
${user} = let
username = user;
homeDirectory = "/home/${user}";
in {
imports =
2024-01-30 14:21:50 +00:00
[./hosts/${hostName}/home.nix ./home/default.nix]
2024-01-19 09:47:14 +00:00
++ homeModules;
2024-01-30 14:21:50 +00:00
home = {inherit username homeDirectory stateVersion;};
2024-01-19 09:47:14 +00:00
programs.home-manager.enable = true;
xdg.userDirs = {
enable = true;
createDirectories = true;
extraConfig = {
XDG_PROJECTS_DIR = "${homeDirectory}/Projects";
};
};
};
};
2024-01-19 09:47:14 +00:00
};
})
2024-01-30 14:21:50 +00:00
]
++ systemModules;
2024-01-30 14:21:50 +00:00
};
in {
nixosConfigurations = {
## Server
2024-01-30 14:21:50 +00:00
Legion = let
hostName = "Legion";
user = "xenia";
system = "x86_64-linux";
in
systemConfig {
inherit hostName user system;
systemModules = [
2023-11-23 08:40:32 +00:00
./services/caddy.nix
./services/gitea.nix
2023-11-23 08:40:32 +00:00
./services/grafana.nix
2024-02-09 14:08:42 +00:00
./services/minecraft.nix
./services/sshd.nix
./services/syncthing.nix
];
homeModules = [
./home/default.nix
];
};
2024-01-30 14:21:50 +00:00
## Personal
2024-01-30 14:21:50 +00:00
Northstar = let
hostName = "Northstar";
user = "xenia";
system = "x86_64-linux";
in
systemConfig {
inherit hostName user system;
systemModules = [
./system/laptop.nix
./system/hyprland.nix
./system/games.nix
];
homeModules = [
./home/hyprland/default.nix
];
};
2024-01-30 14:21:50 +00:00
Vanguard = let
hostName = "Vanguard";
user = "xenia";
system = "x86_64-linux";
in
systemConfig {
inherit hostName user system;
systemModules = [
./system/hyprland.nix
./system/games.nix
];
homeModules = [
./home/hyprland/default.nix
];
};
2024-01-30 14:21:50 +00:00
## Work
2024-01-30 14:21:50 +00:00
Ronin = let
hostName = "Ronin";
user = "elitherl";
system = "x86_64-linux";
in
systemConfig {
inherit hostName user system;
systemModules = [
./system/laptop.nix
./system/hyprland.nix
];
homeModules = [
./home/hyprland/default.nix
];
};
2023-12-19 10:10:06 +00:00
2024-01-30 14:21:50 +00:00
Scorch = let
hostName = "Scorch";
user = "elitherl";
system = "x86_64-linux";
in
systemConfig {
inherit hostName user system;
systemModules = [
./system/hyprland.nix
];
homeModules = [
./home/hyprland/default.nix
];
};
};
2024-01-30 14:21:50 +00:00
};
2023-06-21 17:41:35 +01:00
}