{ description = "Nixos server config"; inputs = { nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05-small"; systems.url = "github:nix-systems/x86_64-linux"; flake-utils = { url = "github:numtide/flake-utils"; inputs.systems.follows = "systems"; }; # modules disko = { url = "github:nix-community/disko"; inputs = { nixpkgs.follows = "nixpkgs"; }; }; impermanence = { url = "github:nix-community/impermanence"; inputs = { }; }; simple-nixos-mailserver = { url = "gitlab:simple-nixos-mailserver/nixos-mailserver/nixos-23.05"; inputs = { nixpkgs.follows = "nixpkgs"; }; }; }; outputs = { self, nixpkgs, # modules simple-nixos-mailserver, impermanence, disko, ... } @ attrs: let system = "x86_64-linux"; pkgs = nixpkgs.legacyPackages.${system}; in { nixosConfigurations."server1" = nixpkgs.lib.nixosSystem { system = "x86_64-linux"; specialArgs = attrs; modules = [ ./hosts/server1/configuration.nix simple-nixos-mailserver.nixosModule disko.nixosModules.default impermanence.nixosModules.impermanence ]; }; devShells."${system}" = { default = pkgs.mkShell { packages = with pkgs; [ nil alejandra statix shellcheck ltex-ls cocogitto git-crypt ]; }; }; }; } # vim: ts=2