{ description = "Kop's NixOS Flake"; inputs = { # secrets management agenix.url = "github:ryantm/agenix"; nixpkgs.url = "github:nixos/nixpkgs/nixos-23.11"; nixos-hardware.url = "github:NixOS/nixos-hardware/master"; nixpkgs-unstable.url = "nixpkgs/nixos-unstable"; home-manager = { url = "github:nix-community/home-manager/release-23.11"; inputs.nixpkgs.follows = "nixpkgs"; }; home-manager-unstable = { url = "github:nix-community/home-manager/master"; inputs.nixpkgs.follows = "nixpkgs-unstable"; }; nixos-wsl = { url = "github:nix-community/NixOS-WSL"; inputs.nixpkgs.follows = "nixpkgs"; }; nix-colors.url = "github:misterio77/nix-colors"; nur = { url = "github:nix-community/NUR"; }; nixos-cosmic = { url = "github:lilyinstarlight/nixos-cosmic"; inputs.nixpkgs.follows = "nixpkgs"; }; nixvim = { url = "github:nix-community/nixvim"; inputs.nixpkgs.follows = "nixpkgs"; }; }; outputs = { self, nur, nixpkgs, nixos-hardware, nixos-wsl, nixpkgs-unstable, agenix, home-manager, home-manager-unstable, nix-colors, nixos-cosmic, nixvim }@inputs: let inherit (self) outputs; system = "x86_64-linux"; # helper function to create a machine mkHost = ({modules, specialArgs ? { pkgsVersion = nixpkgs-unstable;}}: nixpkgs-unstable.lib.nixosSystem { inherit system; modules = modules ++ [ ./modules ({ config, outputs, ... }: { nixpkgs.overlays = with outputs.overlays; [additions modifications unstable-packages nur.overlay]; }) home-manager-unstable.nixosModules.home-manager agenix.nixosModules.default nixos-cosmic.nixosModules.default ]; specialArgs = specialArgs // { inherit inputs outputs;}; }); in { overlays = import ./overlays.nix {inherit inputs;}; nixosConfigurations.server = mkHost { modules = [ ./users/anon ./modules/collections/server.nix ./systems/server/configuration.nix ]; specialArgs = { ## Custom variables (e.g. ip, interface, etc) vars = import ./systems/userdata-default.nix // import ./systems/server/userdata.nix; pkgsVersion = nixpkgs-unstable; }; }; nixosConfigurations."kop-pc" = mkHost { modules = [ ./users/kopatz ./systems/pc/configuration.nix ]; }; nixosConfigurations."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; inherit nix-colors; }; modules = [ ### User specific ### ./users/kopatz ./systems/laptop/configuration.nix ./modules/collections/laptop.nix ./modules/ecryptfs.nix ./modules/services/syncthing.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 ]; }; nixosConfigurations."mini-pc" = mkHost { specialArgs = { vars = import ./systems/userdata-default.nix; pkgsVersion = nixpkgs-unstable; }; modules = [ ./users/anon ./systems/mini-pc/configuration.nix ]; }; # build vm -> nixos-rebuild build-vm --flake .#vm nixosConfigurations."vm" = mkHost { specialArgs = { vars = import ./systems/userdata-default.nix; pkgsVersion = nixpkgs-unstable; }; modules = [ ./users/vm ./systems/vm/configuration.nix ]; }; nixosConfigurations."wsl" = mkHost { modules = [ #"${nixpkgs}/nixos/modules/profiles/minimal.nix" ./users/anon ./modules/nix/settings.nix ./systems/wsl/configuration.nix ]; }; }; }