{ description = "Kop's NixOS Flake"; inputs = { flake-utils.url = "github:numtide/flake-utils"; nixos-hardware.url = "github:NixOS/nixos-hardware/master"; # nix user repository nur = { url = "github:nix-community/NUR"; }; ## stable nixpkgs.url = "github:nixos/nixpkgs/nixos-24.11"; home-manager = { url = "github:nix-community/home-manager/release-24.11"; inputs.nixpkgs.follows = "nixpkgs"; }; nixos-generators = { url = "github:nix-community/nixos-generators"; inputs.nixpkgs.follows = "nixpkgs-unstable"; }; # secrets management agenix = { url = "github:ryantm/agenix"; inputs.nixpkgs.follows = "nixpkgs"; inputs.home-manager.follows = "home-manager"; }; nixos-wsl = { url = "github:nix-community/NixOS-WSL"; inputs.nixpkgs.follows = "nixpkgs"; }; nix-colors.url = "github:misterio77/nix-colors"; ## unstable #TODO: wait until https://github.com/NixOS/nixpkgs/pull/339641 is in unstable https://nixpk.gs/pr-tracker.html?pr=339641 #nixpkgs-unstable.url = "github:nixos/nixpkgs/a6916c76a7d202e3c02134e620f6477b8600ce9d"; nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable"; home-manager-unstable = { url = "github:nix-community/home-manager/master"; inputs.nixpkgs.follows = "nixpkgs-unstable"; }; # cosmic testing nixos-cosmic = { url = "github:lilyinstarlight/nixos-cosmic"; inputs.nixpkgs.follows = "nixpkgs-unstable"; }; # vim configuration with nix nixvim = { url = "github:nix-community/nixvim"; #inputs.nixpkgs.follows = "nixpkgs-unstable"; inputs.home-manager.follows = "home-manager-unstable"; }; # styling stylix = { url = "github:danth/stylix"; inputs.nixpkgs.follows = "nixpkgs-unstable"; inputs.home-manager.follows = "home-manager-unstable"; }; # disk management disko = { url = "github:nix-community/disko"; inputs.nixpkgs.follows = "nixpkgs-unstable"; inputs.home-manager.follows = "home-manager-unstable"; }; #hyprland = { # url = "git+https://github.com/hyprwm/Hyprland?submodules=1"; # inputs.nixpkgs.follows = "nixpkgs-unstable"; #}; }; outputs = { self, nur, nixpkgs, nixos-hardware, nixos-wsl, nixpkgs-unstable , agenix, home-manager, home-manager-unstable, nix-colors, nixos-cosmic , nixvim, nixos-generators, stylix, disko, flake-utils, ... }@inputs: let inherit (self) outputs; system = "x86_64-linux"; overlays = { outputs, ... }: { nixpkgs.overlays = with outputs.overlays; [ additions modifications unstable-packages stable-packages nur.overlay ]; }; defaultModules = [ ./modules agenix.nixosModules.default overlays ]; merge = list: builtins.foldl' (acc: elem: nixpkgs.lib.recursiveUpdate acc elem) { } list; # helper function to create a machine mkHost = { modules, specialArgs ? { pkgsVersion = nixpkgs-unstable; home-manager-version = home-manager-unstable; }, system ? "x86_64-linux", minimal ? false, graphical ? true }: let lib = specialArgs.pkgsVersion.lib; in specialArgs.pkgsVersion.lib.nixosSystem { inherit system; modules = modules ++ defaultModules ++ lib.lists.optionals (!minimal) [ specialArgs.home-manager-version.nixosModules.home-manager ] ++ lib.lists.optionals (!minimal && graphical) [ ./modules/graphical stylix.nixosModules.stylix ./modules/graphical/stylix.nix nixos-cosmic.nixosModules.default ./modules/graphical/cosmic.nix ({ outputs, ... }: { stylix.image = ./yuyukowallpaper.png; }) ]; specialArgs = specialArgs // { inherit inputs outputs; }; }; mkStableServer = { modules, specialArgs ? { pkgsVersion = nixpkgs; home-manager-version = home-manager; }, system ? "x86_64-linux", minimal ? false }: let lib = specialArgs.pkgsVersion.lib; in specialArgs.pkgsVersion.lib.nixosSystem { inherit system; modules = modules ++ [ ./modules agenix.nixosModules.default overlays ] ++ lib.lists.optionals (!minimal) [ specialArgs.home-manager-version.nixosModules.home-manager ]; specialArgs = specialArgs // { inherit inputs outputs; }; }; customPackages = flake-utils.lib.eachDefaultSystem (system: { packages = import ./pkgs { pkgs = nixpkgs-unstable.legacyPackages.${system}; } // { "server-vm" = nixos-generators.nixosGenerate { format = "vmware"; inherit system; #pkgs = nixpkgs-unstable.legacyPackages.x86_64-linux; specialArgs = { pkgsVersion = nixpkgs-unstable; } // { inherit inputs outputs; }; lib = nixpkgs-unstable.legacyPackages.x86_64-linux.lib; modules = defaultModules ++ [ home-manager-unstable.nixosModules.home-manager ./users/anon ./systems/amd-server-vm/configuration.nix { # 100G disk; virtualisation.diskSize = 100 * 1024; } ]; }; }; }); in { overlays = import ./overlays.nix { inherit inputs; }; nixosConfigurations = { "kop-pc" = mkHost { modules = [ ./users/kopatz ./systems/pc/configuration.nix ]; }; "nix-laptop" = mkHost { specialArgs = { ## Custom variables (e.g. ip, interface, etc) vars = import ./systems/userdata-default.nix // import ./systems/laptop/userdata.nix; pkgsVersion = nixpkgs-unstable; home-manager-version = home-manager-unstable; inherit nix-colors; }; modules = [ ### User specific ### ./users/kopatz ./systems/laptop/configuration.nix ./modules/collections/laptop.nix ./modules/ecryptfs.nix #./modules/fh/scanning.nix ./modules/support/ntfs.nix ./modules/thunderbolt.nix #./modules/vmware-host.nix #./modules/fh/forensik.nix #./modules/no-sleep-lid-closed.nix #./modules/static-ip.nix #./modules/wake-on-lan.nix nixos-hardware.nixosModules.dell-xps-15-7590-nvidia ]; }; "mini-pc" = mkStableServer { modules = [ ./users/anon ./systems/mini-pc/configuration.nix ]; }; "mini-pc-proxmox" = mkStableServer { modules = [ ./users/anon ./systems/mini-pc-proxmox/configuration.nix ]; }; "wsl" = mkHost { modules = [ #"${nixpkgs}/nixos/modules/profiles/minimal.nix" ./users/anon ./modules/nix/settings.nix ./systems/wsl/configuration.nix nixos-wsl.nixosModules.wsl ]; }; #initial install done with nix run github:nix-community/nixos-anywhere/73a6d3fef4c5b4ab9e4ac868f468ec8f9436afa7 -- --flake .#adam-site root@ #update with nixos-rebuild switch --flake .#adam-site --target-host "root@" "adam-site" = mkStableServer { minimal = true; system = "aarch64-linux"; specialArgs = { pkgsVersion = nixpkgs; home-manager-version = home-manager; }; modules = [ disko.nixosModules.disko ./systems/adam-site/configuration.nix ]; }; "proxmox-test-vm" = mkHost { minimal = true; modules = [ disko.nixosModules.disko ./systems/proxmox-test-vm/configuration.nix ]; }; "amd-server" = mkHost { modules = [ ./users/kopatz ./systems/amd-server/configuration.nix ]; }; # build vm -> nixos-rebuild build-vm --flake .#vm "vm" = mkHost { modules = [ ./users/vm ./systems/vm/configuration.nix ]; }; # nixos-rebuild switch --flake .#server-vm --target-host root@192.168.0.21 "server-vm" = mkHost { modules = [ ./users/anon ./systems/amd-server-vm/configuration.nix disko.nixosModules.disko ]; }; }; packages = customPackages.packages; }; }