{ inputs = { nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; nixpkgs-stable.url = "github:NixOS/nixpkgs/nixos-25.11"; nixos-hardware.url = "github:NixOS/nixos-hardware/master"; colmena = { url = "github:zhaofengli/colmena"; inputs.nixpkgs.follows = "nixpkgs"; inputs.flake-utils.follows = "flake-utils"; }; home-manager = { url = "github:nix-community/home-manager"; inputs.nixpkgs.follows = "nixpkgs"; }; flake-utils.url = "github:numtide/flake-utils"; agenix = { url = "github:ryantm/agenix"; inputs.nixpkgs.follows = "nixpkgs"; inputs.darwin.follows = ""; }; vscode-extensions = { url = "github:nix-community/nix-vscode-extensions"; inputs.nixpkgs.follows = "nixpkgs"; }; disko = { url = "github:nix-community/disko/latest"; inputs.nixpkgs.follows = "nixpkgs"; }; lanzaboote = { url = "github:nix-community/lanzaboote/v1.0.0"; inputs.nixpkgs.follows = "nixpkgs"; }; simple-nixos-mailserver.url = "gitlab:simple-nixos-mailserver/nixos-mailserver"; }; outputs = { self, agenix, colmena, disko, flake-utils, home-manager, lanzaboote, nixos-hardware, nixpkgs-stable, nixpkgs, simple-nixos-mailserver, vscode-extensions, }@inputs: let inherit (nixpkgs) lib; var = import ./var { inherit lib; }; lib' = import ./lib.nix { inherit lib var; }; mypkgs = self.packages.x86_64-linux; specialArgs = rec { inherit inputs lib' mypkgs var ; secrets = lib'.walk-dir ./secrets; }; mkModule = { entry, isServer ? false, }: { imports = [ entry ./mod ] ++ (if isServer then [ ] else [ ./home ]); }; nixosModules = lib.genAttrs var.desktops (host: mkModule { entry = ./host/${host}; }) // lib.genAttrs var.servers ( host: mkModule { entry = ./host/${host}; isServer = true; } ); in { nixosConfigurations = lib.genAttrs var.desktops ( host: nixpkgs.lib.nixosSystem { system = "x86_64-linux"; inherit specialArgs; modules = [ nixosModules.${host} ]; } ) // { "test-vm" = nixpkgs.lib.nixosSystem { system = "x86_64-linux"; inherit specialArgs; modules = [ { imports = [ ./mod ./host/test-vm ]; } ]; }; }; colmenaHive = colmena.lib.makeHive ( { meta = { nixpkgs = import nixpkgs { system = "x86_64-linux"; }; inherit specialArgs; }; "roam" = { deployment = { targetHost = "185.163.117.158"; buildOnTarget = true; }; imports = [ nixosModules."roam" ]; }; } // lib.genAttrs var.desktops (host: { deployment.targetHost = null; deployment.allowLocalDeployment = true; imports = [ nixosModules.${host} ]; }) ); } // flake-utils.lib.eachDefaultSystem ( system: let pkgs = nixpkgs.legacyPackages.${system}; in { devShells = import ./devshells { inherit pkgs; } // { default = pkgs.mkShell { buildInputs = [ colmena.packages.${system}.colmena agenix.packages.${system}.default pkgs.openssl pkgs.jq pkgs.syncthing ]; }; }; formatter = pkgs.nixfmt-tree; packages = import ./packages { inherit inputs system; }; } ); }