{ description = "Andreas Zweili's Nixos configuration"; inputs = { nixpkgs.url = "github:nixos/nixpkgs/nixos-21.11"; nixpkgs-unstable.url = "github:NixOS/nixpkgs/nixos-unstable"; # look here for the hardware options https://github.com/NixOS/nixos-hardware/blob/master/flake.nix#L5 nixos-hardware.url = "github:nixos/nixos-hardware"; agenix = { url = "github:ryantm/agenix"; inputs.nixpkgs.follows = "nixpkgs"; }; home-manager = { url = "github:nix-community/home-manager/release-21.11"; inputs.nixpkgs.follows = "nixpkgs"; }; }; outputs = inputs@{ self , agenix , nixpkgs , nixpkgs-unstable , nixos-hardware , home-manager }: let custom = import ./custom; system = custom.system; username = custom.username; overlay-unstable = final: prev: { unstable = import nixpkgs-unstable { system = custom.system; config.allowUnfree = true; }; }; pkgs = import nixpkgs { inherit system; config = { allowUnfree = true; }; overlays = [ overlay-unstable ]; }; mkComputer = { hostname, system ? "x86_64-linux", home-module ? "headless" }: nixpkgs.lib.nixosSystem { inherit system pkgs; specialArgs = { inherit custom inputs; }; modules = ( [ # System configuration for this host "${self}/systems/${hostname}" # Common configuration "${self}/modules/common-x86" agenix.nixosModules.age { environment.systemPackages = [ agenix.defaultPackage.${system} ]; } home-manager.nixosModules.home-manager { home-manager.useGlobalPkgs = true; home-manager.useUserPackages = true; home-manager.users.${custom.username}.imports = [ (import "${self}/home-manager/${home-module}.nix" { inherit custom pkgs inputs; }) ]; } ]); }; mkRaspi = { hostname, system ? "aarch64-linux", home-module ? "headless" }: nixpkgs.lib.nixosSystem { inherit system; specialArgs = { inherit custom inputs; }; modules = ( [ # System configuration for this host "${self}/systems/${hostname}" # Common configuration ./modules/common agenix.nixosModules.age { environment.systemPackages = [ agenix.defaultPackage.${system} ]; } home-manager.nixosModules.home-manager { home-manager.useGlobalPkgs = true; home-manager.useUserPackages = true; home-manager.users.${custom.username}.imports = [ (import "${self}/home-manager/${home-module}.nix" { inherit custom pkgs inputs; }) ]; } ]); }; in { nixosConfigurations = { gwyn = mkComputer { hostname = "gwyn"; home-module = "desktop"; }; nixos-vm = mkComputer { hostname = "desktop-vm"; home-module = "desktop"; }; staubfinger = mkComputer { hostname = "staubfinger"; home-module = "desktop"; }; # Servers git = mkComputer { hostname = "git"; }; jdownloader = mkComputer { hostname = "jdownloader"; }; k3s-master1 = mkComputer { hostname = "k3s-master1"; }; k3s-node1 = mkComputer { hostname = "k3s-node1"; }; k3s-node2 = mkComputer { hostname = "k3s-node2"; }; mail = mkComputer { hostname = "mail"; }; nextcloud = mkComputer { hostname = "nextcloud"; }; nixos-management = mkComputer { hostname = "nixos-management"; home-module = "management"; }; nomad-master1 = mkComputer { hostname = "nomad-master1"; }; nomad-client1 = mkComputer { hostname = "nomad-client1"; }; pihole = mkComputer { hostname = "pihole"; }; plex = mkComputer { hostname = "plex"; }; proxy = mkComputer { hostname = "proxy"; }; raspi-test = mkRaspi { hostname = "raspi-test"; }; restic-server = mkComputer { hostname = "restic-server"; }; test-server = mkComputer { hostname = "test-server"; }; ttrss = mkComputer { hostname = "ttrss"; }; }; homeConfigurations = { "${custom.username}@co-ws-con4" = home-manager.lib.homeManagerConfiguration { configuration = import ./home-manager/work-wsl.nix; inherit system username; homeDirectory = "/home/${custom.username}"; extraSpecialArgs = { inherit custom inputs; }; }; }; }; }