diff options
| author | seth <[email protected]> | 2024-02-02 16:13:17 -0500 |
|---|---|---|
| committer | seth <[email protected]> | 2024-02-02 19:22:07 -0500 |
| commit | 1e32ab22f3fc2a4959f90ded95d7318bd4e23623 (patch) | |
| tree | a38ddb5f3fe720bc140f6a10cd41fd820adb4a5f /modules | |
| parent | 9758b8236dcaafb958e6ef4f634d201af0bea80b (diff) | |
systems: use new configurations flakeModule
Diffstat (limited to 'modules')
| -rw-r--r-- | modules/flake/configurations.nix | 211 | ||||
| -rw-r--r-- | modules/flake/default.nix | 5 |
2 files changed, 216 insertions, 0 deletions
diff --git a/modules/flake/configurations.nix b/modules/flake/configurations.nix new file mode 100644 index 0000000..3d2d512 --- /dev/null +++ b/modules/flake/configurations.nix @@ -0,0 +1,211 @@ +{ + config, + lib, + withSystem, + inputs, + self, + ... +}: let + namespace = "configurations"; + cfg = config.${namespace}; + + inherit + (lib) + genAttrs + literalExpression + mapAttrs + mdDoc + mkOption + recursiveUpdate + types + ; + + builderType = types.functionTo pkgsType; + modulesType = types.listOf types.unspecified; + pkgsType = types.lazyAttrsOf types.raw; + + kernelFor = type: + { + nixos = "linux"; + darwin = "darwin"; + } + .${type}; + + builderStringFor = type: + { + nixos = "inputs.nixpkgs.lib.nixosSystem"; + darwin = "inputs.nix-darwin.lib.darwinSystem"; + } + .${type}; + + mkSystem = type: name: let + args = cfg.${type}.systems.${name}; + in + args.builder ( + (removeAttrs args ["builder"]) + // { + modules = args.modules ++ [../../systems/${name} {networking.hostName = name;}]; + specialArgs = { + inherit inputs self; + inputs' = withSystem args.system ({inputs', ...}: inputs'); + secretsDir = ../../secrets/${name}; + }; + } + ); + + mkUser = name: let + args = cfg.home.users.${name}; + in + args.builder (recursiveUpdate (removeAttrs args ["builder"]) { + inherit (args) pkgs; + + modules = + [ + ../../users/${name}/home.nix + + { + _module.args.osConfig = {}; + programs.home-manager.enable = true; + } + ] + ++ args.modules; + + extraSpecialArgs = { + inherit inputs self; + inputs' = withSystem args.pkgs.system ({inputs', ...}: inputs'); + }; + }); + + mapSystems = type: mapAttrs (name: _: mkSystem type name) cfg.${type}.systems; + mapUsers = mapAttrs (name: _: mkUser name) cfg.home.users; + + systemsSubmodule = type: { + options = { + builder = mkOption { + type = builderType; + default = cfg.${type}.builder; + example = literalExpression (builderStringFor type); + description = mdDoc '' + Function to build this ${type}Configuration with + ''; + }; + + modules = mkOption { + type = modulesType; + default = []; + example = literalExpression "[ self.${type}Modules.default ]"; + description = mdDoc '' + Extra modules to add to this ${type}Configuration + ''; + }; + + system = mkOption { + type = types.str; + default = "x86_64-${kernelFor type}"; + example = literalExpression "aarch64-${kernelFor type}"; + description = mdDoc '' + System to build this ${type}Configuration for + ''; + }; + }; + }; + + usersSubmodule = { + options = { + builder = mkOption { + type = builderType; + default = cfg.home.builder; + example = literalExpression "inputs.home-manager.lib.homeManagerConfiguration"; + description = mdDoc '' + Function to build this homeConfiguration with + ''; + }; + + modules = mkOption { + type = modulesType; + default = []; + example = literalExpression "[ self.hmModules.default ]"; + description = mdDoc '' + Extra modules to add to this homeConfiguration + ''; + }; + + pkgs = mkOption { + type = pkgsType; + default = cfg.home.pkgs; + example = literalExpression "inputs.nixpkgs.legacyPackages.aarch64-linux"; + description = mdDoc '' + Instance of nixpkgs to use in this homeConfiguration + ''; + }; + }; + }; + + mkSystemOptions = type: { + builder = mkOption { + type = builderType; + example = literalExpression (builderStringFor type); + description = mdDoc '' + Default function to build ${type}Configurations with + ''; + }; + + systems = mkOption { + type = types.attrsOf (types.submodule (systemsSubmodule type)); + default = {}; + example = literalExpression '' + { + foo = { + system = "aarch64-${kernelFor type}"; + }; + } + ''; + description = mdDoc '' + Attribute set of ${type}Configuration definitions + ''; + }; + }; +in { + options.${namespace} = + genAttrs ["nixos" "darwin"] mkSystemOptions + // { + home = { + builder = mkOption { + type = builderType; + example = literalExpression "inputs.home-manager.lib.homeManagerConfiguration"; + description = mdDoc '' + Default function to build homeConfigurations with + ''; + }; + + pkgs = mkOption { + type = pkgsType; + example = literalExpression "inputs.nixpkgs.legacyPackages.aarch64-linux"; + description = mdDoc '' + Default instance of nixpkgs to use in homeConfigurations + ''; + }; + + users = mkOption { + type = types.attrsOf (types.submodule usersSubmodule); + default = {}; + example = literalExpression '' + { + john = { + pkgs = inputs.nixpkgs.legacyPackages.aarch64-linux; + }; + } + ''; + description = mdDoc '' + Attribute set of homeConfiguration definitions + ''; + }; + }; + }; + + config.flake = { + nixosConfigurations = mapSystems "nixos"; + darwinConfigurations = mapSystems "darwin"; + homeConfigurations = mapUsers; + }; +} diff --git a/modules/flake/default.nix b/modules/flake/default.nix new file mode 100644 index 0000000..e86bee4 --- /dev/null +++ b/modules/flake/default.nix @@ -0,0 +1,5 @@ +{ + flake.flakeModules = { + configurations = import ./configurations.nix; + }; +} |
