forked from fediversity/fediversity
		
	factor out function wrapper to module function #9
					 3 changed files with 71 additions and 41 deletions
				
			
		|  | @ -99,40 +99,37 @@ in | |||
|                     { | ||||
|                       options.enable = lib.mkEnableOption "Hello in the shell"; | ||||
|                     }; | ||||
|                   implementation = cfg: { | ||||
|                     input = cfg; | ||||
|                     output = lib.optionalAttrs cfg.enable { | ||||
|                   implementation = | ||||
|                     cfg: | ||||
|                     lib.optionalAttrs cfg.enable { | ||||
|                       resources.hello.login-shell.packages.hello = pkgs.hello; | ||||
|                     }; | ||||
|                   }; | ||||
|                 }; | ||||
|               environments.single-nixos-vm = | ||||
|                 { config, ... }: | ||||
|                 { | ||||
|                   resources.operator-environment.login-shell.username = "operator"; | ||||
|                   implementation = requests: { | ||||
|                     input = requests; | ||||
|                     output = | ||||
|                       { providers, ... }: | ||||
|                       { | ||||
|                         providers = { | ||||
|                           inherit (inputs.nixops4.modules.nixops4Provider) local; | ||||
|                         }; | ||||
|                         resources.the-machine = { | ||||
|                           type = providers.local.exec; | ||||
|                           imports = [ | ||||
|                             inputs.nixops4-nixos.modules.nixops4Resource.nixos | ||||
|                           ]; | ||||
|                           nixos.module = | ||||
|                             { ... }: | ||||
|                             { | ||||
|                               users.users = config.resources.shell.login-shell.apply ( | ||||
|                                 lib.filterAttrs (_name: value: value ? login-shell) requests | ||||
|                               ); | ||||
|                             }; | ||||
|                         }; | ||||
|                   implementation = | ||||
|                     requests: | ||||
|                     { providers, ... }: | ||||
|                     { | ||||
|                       providers = { | ||||
|                         inherit (inputs.nixops4.modules.nixops4Provider) local; | ||||
|                       }; | ||||
|                   }; | ||||
|                       resources.the-machine = { | ||||
|                         type = providers.local.exec; | ||||
|                         imports = [ | ||||
|                           inputs.nixops4-nixos.modules.nixops4Resource.nixos | ||||
|                         ]; | ||||
|                         nixos.module = | ||||
|                           { ... }: | ||||
|                           { | ||||
|                             users.users = config.resources.shell.login-shell.apply ( | ||||
|                               lib.filterAttrs (_name: value: value ? login-shell) requests | ||||
|                             ); | ||||
|                           }; | ||||
|                       }; | ||||
|                     }; | ||||
|                 }; | ||||
|             }; | ||||
|             options = { | ||||
|  |  | |||
|  | @ -103,18 +103,19 @@ in | |||
|             }; | ||||
|             resources = mkOption { | ||||
|               description = "Compute resources required by an application"; | ||||
|               type = functionTo application.config.config-mapping.output-type; | ||||
|               type = application.config.config-mapping.function-type; | ||||
|               readOnly = true; | ||||
|               default = input: (application.config.implementation input).output; | ||||
|               default = application.config.config-mapping.apply; | ||||
|             }; | ||||
|             # TODO(@fricklerhandwerk): this needs a better name, it's just the type | ||||
|             # TODO(@fricklerhandwerk): this needs a better name | ||||
|             config-mapping = mkOption { | ||||
|               description = "Function type for the mapping from application configuration to required resources"; | ||||
|               description = "Compute resources required by an application"; | ||||
|               type = submodule functionType; | ||||
|               readOnly = true; | ||||
|               default = { | ||||
|                 input-type = submodule application.config.module; | ||||
|                 output-type = application-resources; | ||||
|                 declare = application.config.implementation; | ||||
|               }; | ||||
|             }; | ||||
|           }; | ||||
|  | @ -151,6 +152,25 @@ in | |||
|               default = { | ||||
|                 input-type = application-resources; | ||||
|                 output-type = nixops4Deployment; | ||||
|                 declare = environment.config.implementation; | ||||
|               }; | ||||
|             }; | ||||
|             config-mapping = mkOption { | ||||
|               description = "Mapping from a configuration to a deployment"; | ||||
|               type = submodule functionType; | ||||
|               readOnly = true; | ||||
|               default = { | ||||
|                 input-type = config.configuration; | ||||
|                 output-type = nixops4Deployment; | ||||
|                 declare = | ||||
|                   cfg: | ||||
|                   # TODO: check cfg.enable.true | ||||
|                   let | ||||
|                     required-resources = lib.mapAttrs ( | ||||
|                       name: application-settings: config.applications.${name}.resources application-settings | ||||
|                     ) cfg.applications; | ||||
|                   in | ||||
|                   environment.config.resource-mapping.apply required-resources; | ||||
|               }; | ||||
|             }; | ||||
|             # TODO(@fricklerhandwerk): maybe this should be a separate thing such as `fediversity-setup`, | ||||
|  | @ -158,18 +178,9 @@ in | |||
|             # then the deployments can simply be the result of the function application baked into this module. | ||||
|             deployment = mkOption { | ||||
|               description = "Generate a deployment from a configuration, by applying an environment's resource policies to the applications' resource mappings"; | ||||
|               type = functionTo (environment.config.resource-mapping.output-type); | ||||
|               type = environment.config.config-mapping.function-type; | ||||
|               readOnly = true; | ||||
|               default = | ||||
|                 cfg: | ||||
|                 # TODO: check cfg.enable.true | ||||
|                 let | ||||
|                   required-resources = lib.mapAttrs ( | ||||
|                     name: application-settings: config.applications.${name}.resources application-settings | ||||
|                   ) cfg.applications; | ||||
|                 in | ||||
|                 (environment.config.implementation required-resources).output; | ||||
| 
 | ||||
|               default = environment.config.config-mapping.apply; | ||||
|             }; | ||||
|           }; | ||||
|         }) | ||||
|  |  | |||
|  | @ -19,6 +19,11 @@ in | |||
|       type = optionType; | ||||
|     }; | ||||
|     function-type = mkOption { | ||||
|       type = optionType; | ||||
|       readOnly = true; | ||||
|       default = functionTo config.output-type; | ||||
|     }; | ||||
|     wrapper-type = mkOption { | ||||
|       type = optionType; | ||||
|       readOnly = true; | ||||
|       default = functionTo (submodule { | ||||
|  | @ -32,5 +37,22 @@ in | |||
|         }; | ||||
|       }); | ||||
|     }; | ||||
|     declare = mkOption { | ||||
|       type = config.function-type; | ||||
|       default = _: { }; | ||||
|     }; | ||||
|     wrapper = mkOption { | ||||
|       type = config.wrapper-type; | ||||
|       readOnly = true; | ||||
|       default = input: fn: { | ||||
|         inherit input; | ||||
|         output = config.implementation fn.config.input; | ||||
|       }; | ||||
|     }; | ||||
|     apply = mkOption { | ||||
|       type = config.function-type; | ||||
|       readOnly = true; | ||||
|       default = input: (config.wrapper input).output; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue