{ description = "NixOS Configuration for Skipper"; nixConfig = { extra-substituters = [ "https://adtya.cachix.org" "https://nix-community.cachix.org" "https://cache.nixos.org" ]; extra-trusted-public-keys = [ "adtya.cachix.org-1:lAuNLx0Ehzx6FoH20rVkMD7KyZZevlLfvm3lwMAzrnU=" "nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs=" "cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=" ]; }; inputs = { nixpkgs.url = "github:NixOS/nixpkgs?ref=nixos-unstable"; lix-module = { url = "https://git.lix.systems/lix-project/nixos-module/archive/2.91.0.tar.gz"; inputs.nixpkgs.follows = "nixpkgs"; }; home-manager = { url = "github:nix-community/home-manager?ref=master"; inputs.nixpkgs.follows = "nixpkgs"; }; impermanence.url = "github:nix-community/impermanence?ref=master"; lanzaboote.url = "github:nix-community/lanzaboote?ref=master"; sops-nix.url = "github:Mic92/sops-nix?ref=master"; deploy-rs.url = "github:serokell/deploy-rs?ref=master"; flake-utils.url = "github:numtide/flake-utils?ref=main"; neovim-nightly.url = "github:nix-community/neovim-nightly-overlay?ref=master"; caddy.url = "git+https://forge.acomputer.lol/adtya/caddy-with-modules?ref=main"; adtyaxyz.url = "git+https://forge.acomputer.lol/adtya/adtya.xyz?ref=main"; wiki.url = "git+https://forge.acomputer.lol/adtya/wiki?ref=main"; }; outputs = { self , nixpkgs , lix-module , home-manager , impermanence , lanzaboote , sops-nix , deploy-rs , flake-utils , neovim-nightly , caddy , adtyaxyz , wiki , } @ inputs: let inherit (nixpkgs) lib; packages = system: import nixpkgs { inherit system; config = { allowUnfree = true; }; overlays = [ (import ./extra-packages) ]; }; in { nixosModules.default = import ./modules; nixosConfigurations = { Skipper = let hostname = "Skipper"; system = "x86_64-linux"; username = "adtya"; in nixpkgs.lib.nixosSystem { inherit system; pkgs = packages system; specialArgs = { inherit inputs username; }; modules = [ { system.configurationRevision = lib.mkIf (self ? rev) self.rev; networking.hostName = lib.mkDefault hostname; nixpkgs.hostPlatform = lib.mkDefault system; } lix-module.nixosModules.default sops-nix.nixosModules.sops lanzaboote.nixosModules.lanzaboote impermanence.nixosModules.impermanence home-manager.nixosModules.home-manager self.nixosModules.default ./common ./hosts/skipper ./home ]; }; Rico0 = let hostname = "Rico0"; system = "aarch64-linux"; username = "adtya"; in nixpkgs.lib.nixosSystem { inherit system; pkgs = packages system; specialArgs = { inherit inputs username; }; modules = [ { system.configurationRevision = lib.mkIf (self ? rev) self.rev; networking.hostName = lib.mkDefault hostname; nixpkgs.hostPlatform = lib.mkDefault system; } sops-nix.nixosModules.sops self.nixosModules.default ./common ./hosts/rico0 ]; }; Rico1 = let hostname = "Rico1"; system = "aarch64-linux"; username = "adtya"; in nixpkgs.lib.nixosSystem { inherit system; pkgs = packages system; specialArgs = { inherit inputs username; }; modules = [ { system.configurationRevision = lib.mkIf (self ? rev) self.rev; networking.hostName = lib.mkDefault hostname; nixpkgs.hostPlatform = lib.mkDefault system; } sops-nix.nixosModules.sops self.nixosModules.default ./common ./hosts/rico1 ]; }; Rico2 = let hostname = "Rico2"; system = "aarch64-linux"; username = "adtya"; in nixpkgs.lib.nixosSystem { inherit system; pkgs = packages system; specialArgs = { inherit inputs username; }; modules = [ { system.configurationRevision = lib.mkIf (self ? rev) self.rev; networking.hostName = lib.mkDefault hostname; nixpkgs.hostPlatform = lib.mkDefault system; } sops-nix.nixosModules.sops self.nixosModules.default ./common ./hosts/rico2 ]; }; Wynne = let hostname = "Wynne"; system = "x86_64-linux"; username = "adtya"; in nixpkgs.lib.nixosSystem { inherit system; pkgs = packages system; specialArgs = { inherit inputs username; }; modules = [ { system.configurationRevision = lib.mkIf (self ? rev) self.rev; networking.hostName = lib.mkDefault hostname; nixpkgs.hostPlatform = lib.mkDefault system; } sops-nix.nixosModules.sops self.nixosModules.default ./common ./hosts/wynne ]; }; Layne = let hostname = "Layne"; system = "x86_64-linux"; username = "adtya"; in nixpkgs.lib.nixosSystem { inherit system; pkgs = packages system; specialArgs = { inherit inputs username; }; modules = [ { system.configurationRevision = lib.mkIf (self ? rev) self.rev; networking.hostName = lib.mkDefault hostname; nixpkgs.hostPlatform = lib.mkDefault system; } sops-nix.nixosModules.sops self.nixosModules.default ./common ./hosts/layne ]; }; Bifrost = let hostname = "Bifrost"; system = "x86_64-linux"; username = "adtya"; in nixpkgs.lib.nixosSystem { inherit system; pkgs = packages system; specialArgs = { inherit inputs username; }; modules = [ { system.configurationRevision = lib.mkIf (self ? rev) self.rev; networking.hostName = lib.mkForce hostname; nixpkgs.hostPlatform = lib.mkDefault system; } sops-nix.nixosModules.sops self.nixosModules.default ./common ./hosts/bifrost ]; }; }; deploy.nodes = { Rico0 = { hostname = "Rico0"; sshUser = "adtya"; profiles.system = { user = "root"; path = deploy-rs.lib.aarch64-linux.activate.nixos self.nixosConfigurations.Rico0; }; }; Rico1 = { hostname = "Rico1"; sshUser = "adtya"; profiles.system = { user = "root"; path = deploy-rs.lib.aarch64-linux.activate.nixos self.nixosConfigurations.Rico1; }; }; Rico2 = { hostname = "Rico2"; sshUser = "adtya"; profiles.system = { user = "root"; path = deploy-rs.lib.aarch64-linux.activate.nixos self.nixosConfigurations.Rico2; }; }; Wynne = { hostname = "Wynne"; sshUser = "adtya"; profiles.system = { user = "root"; path = deploy-rs.lib.x86_64-linux.activate.nixos self.nixosConfigurations.Wynne; }; }; Layne = { hostname = "Layne"; sshUser = "adtya"; profiles.system = { user = "root"; path = deploy-rs.lib.x86_64-linux.activate.nixos self.nixosConfigurations.Layne; }; }; Bifrost = { hostname = "Bifrost"; sshUser = "adtya"; profiles.system = { user = "root"; path = deploy-rs.lib.x86_64-linux.activate.nixos self.nixosConfigurations.Bifrost; }; }; }; } // flake-utils.lib.eachDefaultSystem (system: let pkgs = import nixpkgs { inherit system; }; in { formatter = pkgs.nixpkgs-fmt; devShells.default = pkgs.mkShell { buildInputs = with pkgs; [ git statix sops age deploy-rs.packages.${pkgs.system}.default ]; }; packages.getpaper = pkgs.callPackage ./extra-packages/scripts/getpaper { }; packages.digitalOceanImage = (pkgs.nixos { imports = [ "${nixpkgs}/nixos/modules/virtualisation/digital-ocean-image.nix" ]; system.stateVersion = "24.11"; }).digitalOceanImage; } ); }