2023-09-28 14:08:07 +02:00
|
|
|
{
|
|
|
|
description = "NixOS System Config";
|
2023-12-15 13:45:45 +01:00
|
|
|
inputs = {
|
2024-01-31 03:36:27 +01:00
|
|
|
# Stable Packages
|
2024-12-01 23:39:07 +01:00
|
|
|
nixpkgs.url = "nixpkgs/nixos-24.11";
|
2024-01-31 03:36:27 +01:00
|
|
|
# Unstable Packages
|
|
|
|
nixpkgs-unstable.url = "nixpkgs/nixos-unstable";
|
2023-12-15 13:45:45 +01:00
|
|
|
# home-manager - Dotfile mnagement - add /master at the end to pull from master
|
2024-12-01 23:39:07 +01:00
|
|
|
home-manager.url = "github:nix-community/home-manager/release-24.11";
|
2023-12-15 13:45:45 +01:00
|
|
|
home-manager.inputs.nixpkgs.follows = "nixpkgs";
|
2024-01-30 12:46:32 +01:00
|
|
|
# Nix colorizer / themer
|
2024-12-04 18:06:57 +01:00
|
|
|
stylix.url = "github:danth/stylix/release-24.11";
|
2024-12-03 19:29:00 +01:00
|
|
|
stylix.inputs.nixpkgs.follows = "nixpkgs";
|
2024-04-08 14:56:39 +02:00
|
|
|
# nixvim - neovim configuration management in nix
|
2024-12-01 23:39:07 +01:00
|
|
|
nixvim.url = "github:nix-community/nixvim/nixos-24.11";
|
2023-12-15 13:45:45 +01:00
|
|
|
# lanzaboote - Secureboot Configuration
|
|
|
|
lanzaboote.url = "github:nix-community/lanzaboote";
|
|
|
|
lanzaboote.inputs.nixpkgs.follows = "nixpkgs";
|
2024-01-31 03:36:27 +01:00
|
|
|
# nixpkgs-wayland - Wayland-specific packages not in nixpkgs
|
|
|
|
nixpkgs-wayland.url = "github:nix-community/nixpkgs-wayland";
|
2023-12-15 13:45:45 +01:00
|
|
|
# nur - Nix User Repository - user-submitted / maintained packages
|
|
|
|
nur.url = "github:nix-community/NUR";
|
|
|
|
# sops-nix - Secret Management with SOPS using GPG Keys
|
|
|
|
sops-nix.url = "github:Mic92/sops-nix";
|
|
|
|
# nixos-hardware - Hardware Configurations
|
|
|
|
nixos-hardware.url = "github:NixOS/nixos-hardware/master";
|
|
|
|
# nixos-generators - Automated Image / ISO Creation
|
|
|
|
nixos-generators.url = "github:nix-community/nixos-generators";
|
|
|
|
nixos-generators.inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
# disko - Declarative Disk Partitioning
|
|
|
|
disko.url = "github:nix-community/disko";
|
|
|
|
disko.inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
# Firefox theme, for "Gradience" GTK Theming
|
2024-07-28 10:53:34 +02:00
|
|
|
# firefox-gnome-theme.url = "github:rafaelmardojai/firefox-gnome-theme";
|
|
|
|
# firefox-gnome-theme.flake = false;
|
2023-12-15 13:45:45 +01:00
|
|
|
# deploy-rs, declarative NixOS deployments
|
|
|
|
deploy-rs.url = "github:serokell/deploy-rs";
|
|
|
|
deploy-rs.inputs.nixpkgs.follows = "nixpkgs";
|
2024-08-20 09:39:42 +02:00
|
|
|
# Steam Deck configs for NixOS
|
|
|
|
jovian.url = "github:Jovian-Experiments/Jovian-NixOS";
|
2024-01-01 06:05:29 +01:00
|
|
|
# Manage Plasma desktop with Nix
|
|
|
|
plasma-manager.url = "github:pjones/plasma-manager";
|
2024-06-12 14:27:57 +02:00
|
|
|
plasma-manager.inputs.nixpkgs.follows = "nixpkgs";
|
2024-08-21 15:57:05 +02:00
|
|
|
# Gnome / KDE-like overview
|
2024-01-07 04:03:33 +01:00
|
|
|
};
|
2024-08-14 01:26:41 +02:00
|
|
|
outputs = { self, nixpkgs, sops-nix, deploy-rs, ... } @inputs:
|
2023-09-28 14:08:07 +02:00
|
|
|
let
|
|
|
|
inherit (self) outputs;
|
2024-01-30 12:46:32 +01:00
|
|
|
stateVersion = "23.11";
|
|
|
|
hmStateVersion = "23.11";
|
2024-08-13 11:41:19 +02:00
|
|
|
libx = import ./lib/default.nix { inherit self inputs outputs stateVersion hmStateVersion; };
|
2023-09-28 14:08:07 +02:00
|
|
|
in {
|
|
|
|
nixosConfigurations = {
|
2024-07-15 13:39:14 +02:00
|
|
|
# Linode VMs
|
2024-07-30 15:22:49 +02:00
|
|
|
osaka-linode-01 = libx.mkHost { hostname = "osaka-linode-01"; type = "small";};
|
|
|
|
milan-linode-01 = libx.mkHost { hostname = "milan-linode-01"; type = "small";};
|
2024-06-23 12:11:32 +02:00
|
|
|
frankfurt-linode-01 = libx.mkHost { hostname = "frankfurt-linode-01"; type = "small";};
|
2024-07-12 07:40:25 +02:00
|
|
|
|
|
|
|
# Servers
|
2024-06-23 12:11:32 +02:00
|
|
|
framework-server = libx.mkHost { hostname = "framework-server"; };
|
2024-07-12 07:40:25 +02:00
|
|
|
warsaw-ovh-01 = libx.mkHost { hostname = "warsaw-ovh-01"; };
|
2024-06-23 12:11:32 +02:00
|
|
|
nuc-server = libx.mkHost { hostname = "nuc-server"; };
|
2024-07-12 07:40:25 +02:00
|
|
|
|
|
|
|
# User Machines
|
2024-12-01 23:58:25 +01:00
|
|
|
nixos-desktop = libx.mkHost { hostname = "nixos-desktop"; unfree = true; desktop = "plasma6"; };
|
2025-01-04 21:00:57 +01:00
|
|
|
framework13 = libx.mkHost { hostname = "framework13"; unfree = true; desktop = "gnome"; };
|
2025-01-07 18:07:50 +01:00
|
|
|
framework16 = libx.mkHost { hostname = "framework16"; unfree = true; desktop = "gnome"; };
|
2024-09-24 14:58:47 +02:00
|
|
|
steamdeck = libx.mkDeck { hostname = "steamdeck"; desktop = "plasma6"; };
|
2024-07-12 07:40:25 +02:00
|
|
|
|
|
|
|
# Raspberry Pi's
|
2024-06-23 12:11:32 +02:00
|
|
|
backups-rpi4 = libx.mkHost { hostname = "backups-rpi4"; system = "aarch64-linux"; type = "small"; };
|
|
|
|
piaware-rpi4 = libx.mkHost { hostname = "piaware-rpi4"; system = "aarch64-linux"; type = "small"; };
|
|
|
|
quitman-rpi4 = libx.mkHost { hostname = "quitman-rpi4"; system = "aarch64-linux"; type = "small"; };
|
|
|
|
bakersfield-rpi4 = libx.mkHost { hostname = "bakersfield-rpi4"; system = "aarch64-linux"; type = "small"; };
|
2023-09-28 14:08:07 +02:00
|
|
|
};
|
|
|
|
homeConfigurations = {
|
2024-07-15 13:39:14 +02:00
|
|
|
# Linode VMs
|
2024-07-30 15:22:49 +02:00
|
|
|
"albert@osaka-linode-01" = libx.mkHome { hostname = "osaka-linode-01"; type = "small"; };
|
|
|
|
"albert@milan-linode-01" = libx.mkHome { hostname = "milan-linode-01"; type = "small"; };
|
2024-06-23 12:11:32 +02:00
|
|
|
"albert@frankfurt-linode-01" = libx.mkHome { hostname = "frankfurt-linode-01"; type = "small"; };
|
2024-07-12 07:40:25 +02:00
|
|
|
|
|
|
|
# Servers
|
2024-06-23 12:11:32 +02:00
|
|
|
"albert@framework-server" = libx.mkHome { hostname = "framework-server"; };
|
2024-07-28 10:53:34 +02:00
|
|
|
"albert@warsaw-ovh-01" = libx.mkHome { hostname = "warsaw-ovh-01"; };
|
2024-06-23 12:11:32 +02:00
|
|
|
"albert@nuc-server" = libx.mkHome { hostname = "nuc-server"; };
|
2024-07-12 07:40:25 +02:00
|
|
|
|
|
|
|
# User Machines
|
2025-01-04 21:00:57 +01:00
|
|
|
"albert@nixos-desktop" = libx.mkHome { hostname = "nixos-desktop"; desktop = "plasma6"; };
|
|
|
|
"albert@framework13" = libx.mkHome { hostname = "framework13"; desktop = "gnome"; };
|
2025-01-07 18:07:50 +01:00
|
|
|
"albert@framework16" = libx.mkHome { hostname = "framework16"; desktop = "gnome"; };
|
2024-09-24 14:58:47 +02:00
|
|
|
"albert@steamdeck" = libx.mkHome { hostname = "steamdeck"; desktop = "plasma6"; };
|
2024-07-12 07:40:25 +02:00
|
|
|
|
|
|
|
# Raspberry Pi's
|
2024-06-23 12:11:32 +02:00
|
|
|
"albert@backups-rpi4" = libx.mkHome { hostname = "backups-rpi4"; system = "aarch64-linux"; type = "small"; };
|
|
|
|
"albert@piaware-rpi4" = libx.mkHome { hostname = "piaware-rpi4"; system = "aarch64-linux"; type = "small"; };
|
|
|
|
"albert@quitman-rpi4" = libx.mkHome { hostname = "quitman-rpi4"; system = "aarch64-linux"; type = "small"; };
|
|
|
|
"albert@bakersfield-rpi4" = libx.mkHome { hostname = "bakersfield-rpi4"; system = "aarch64-linux"; type = "small"; };
|
2024-07-12 07:40:25 +02:00
|
|
|
|
2024-03-20 14:59:42 +01:00
|
|
|
# Containers
|
2025-01-07 20:35:53 +01:00
|
|
|
"albert@rdesktop" = libx.mkHome { hostname = "rdesktop"; desktop = "gnome"; };
|
2023-09-28 14:08:07 +02:00
|
|
|
};
|
2023-12-09 14:10:15 +01:00
|
|
|
deploy.nodes = {
|
2024-07-15 13:39:14 +02:00
|
|
|
# Linode VMs
|
2024-06-23 12:11:32 +02:00
|
|
|
osaka-linode-01 = libx.deploy { hostname = "osaka-linode-01"; };
|
|
|
|
milan-linode-01 = libx.deploy { hostname = "milan-linode-01"; };
|
2024-06-24 12:57:28 +02:00
|
|
|
frankfurt-linode-01 = libx.deploy { hostname = "frankfurt-linode-01"; };
|
2024-06-23 12:11:32 +02:00
|
|
|
|
2024-07-12 07:40:25 +02:00
|
|
|
# Servers
|
2024-09-24 06:34:05 +02:00
|
|
|
# framework-server = libx.deploy { hostname = "framework-server"; };
|
2024-07-16 13:10:54 +02:00
|
|
|
warsaw-ovh-01 = libx.deploy { hostname = "warsaw-ovh-01"; };
|
2024-11-20 23:38:40 +01:00
|
|
|
nuc-server = libx.deploy { hostname = "nuc-server"; };
|
2024-06-23 15:21:45 +02:00
|
|
|
|
2024-10-16 06:48:05 +02:00
|
|
|
# Raspberry Pi's
|
2024-10-10 13:58:06 +02:00
|
|
|
# backups-rpi4 = libx.deploy { hostname = "backups-rpi4"; system = "aarch64-linux"; };
|
2024-10-05 10:32:14 +02:00
|
|
|
# piaware-rpi4 = libx.deploy { hostname = "piaware-rpi4"; system = "aarch64-linux"; };
|
2024-06-23 12:11:32 +02:00
|
|
|
bakersfield-rpi4 = libx.deploy { hostname = "bakersfield-rpi4"; system = "aarch64-linux"; };
|
2024-12-11 05:17:47 +01:00
|
|
|
quitman-rpi4 = libx.deploy { hostname = "quitman-rpi4"; system = "aarch64-linux"; };
|
2023-12-09 14:10:15 +01:00
|
|
|
};
|
2023-12-12 05:27:40 +01:00
|
|
|
imageConfigurations = {
|
2024-08-13 05:53:37 +02:00
|
|
|
nixos-linode-img = libx.mkMinImage { hostname = "nixos-linode-img"; format = "linode"; };
|
|
|
|
nixos-rpi4-img = libx.mkImage { hostname = "nixos-rpi4-img"; format = "sd-aarch64"; system = "aarch64-linux"; };
|
2023-12-12 05:27:40 +01:00
|
|
|
nixos-iso-console = libx.mkImage { hostname = "nixos-iso-console"; format = "iso"; };
|
2024-06-23 09:10:56 +02:00
|
|
|
nixos-iso-desktop = libx.mkImage { hostname = "nixos-iso-desktop"; format = "iso"; desktop = "plasma6"; unfree = true; };
|
2023-12-12 05:27:40 +01:00
|
|
|
};
|
2023-12-12 05:29:35 +01:00
|
|
|
|
|
|
|
# Checks for deploy-rs - Makes deploy-rs fail when system evaluations fail
|
2023-12-13 04:23:41 +01:00
|
|
|
checks = builtins.mapAttrs (system: deployLib: deployLib.deployChecks self.deploy) deploy-rs.lib;
|
2023-12-12 05:29:35 +01:00
|
|
|
|
|
|
|
# Devshell for bootstrapping; acessible via 'nix develop'
|
|
|
|
devShells = libx.forAllSystems (system:
|
|
|
|
let pkgs = nixpkgs.legacyPackages.${system};
|
|
|
|
in import ./shell.nix { inherit pkgs sops-nix deploy-rs system; }
|
|
|
|
);
|
2023-09-28 14:08:07 +02:00
|
|
|
};
|
2024-01-30 12:46:32 +01:00
|
|
|
}
|