forked from fediversity/fediversity
		
	factor out function wrapper to module function
note that this does not yet contain the 'type check', as this does not
function yet.
this could be added in `data-model.nix` like:
```nix
function-type-check = mkOption {
  type = application.config.config-mapping.function-type;
  readOnly = true;
  default = input: {
    inherit input;
    output = application.config.config-mapping.implementation-type
input;
  };
};
```
... or even to `function.nix` itself, like:
```nix
function-type-check = mkOption {
  type = config.function-type;
  readOnly = true;
  default = input: {
    inherit input;
    output = config.implementation-type input;
  };
};
```
			
			
This commit is contained in:
		
							parent
							
								
									9c219341b1
								
							
						
					
					
						commit
						6fa9c40662
					
				
					 3 changed files with 32 additions and 30 deletions
				
			
		|  | @ -99,20 +99,18 @@ 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 = | ||||
|                   implementation = | ||||
|                     requests: | ||||
|                     { providers, ... }: | ||||
|                     { | ||||
|                       providers = { | ||||
|  | @ -134,7 +132,6 @@ in | |||
|                     }; | ||||
|                 }; | ||||
|             }; | ||||
|             }; | ||||
|             options = { | ||||
|               example-configuration = mkOption { | ||||
|                 type = config.configuration; | ||||
|  |  | |||
|  | @ -99,13 +99,13 @@ in | |||
|             }; | ||||
|             implementation = mkOption { | ||||
|               description = "Mapping of application configuration to deployment resources, a description of what an application needs to run"; | ||||
|               type = application.config.config-mapping.function-type; | ||||
|               type = application.config.config-mapping.implementation-type; | ||||
|             }; | ||||
|             resources = mkOption { | ||||
|               description = "Compute resources required by an application"; | ||||
|               type = functionTo application.config.config-mapping.output-type; | ||||
|               readOnly = true; | ||||
|               default = input: (application.config.implementation input).output; | ||||
|               default = application.config.implementation; | ||||
|             }; | ||||
|             # TODO(@fricklerhandwerk): this needs a better name, it's just the type | ||||
|             config-mapping = mkOption { | ||||
|  | @ -142,7 +142,7 @@ in | |||
|             }; | ||||
|             implementation = mkOption { | ||||
|               description = "Mapping of resources required by applications to available resources; the result can be deployed"; | ||||
|               type = environment.config.resource-mapping.function-type; | ||||
|               type = environment.config.resource-mapping.implementation-type; | ||||
|             }; | ||||
|             resource-mapping = mkOption { | ||||
|               description = "Function type for the mapping from resources to a (NixOps4) deployment"; | ||||
|  | @ -168,7 +168,7 @@ in | |||
|                     name: application-settings: config.applications.${name}.resources application-settings | ||||
|                   ) cfg.applications; | ||||
|                 in | ||||
|                 (environment.config.implementation required-resources).output; | ||||
|                 environment.config.implementation required-resources; | ||||
| 
 | ||||
|             }; | ||||
|           }; | ||||
|  |  | |||
|  | @ -18,6 +18,11 @@ in | |||
|     output-type = mkOption { | ||||
|       type = optionType; | ||||
|     }; | ||||
|     implementation-type = mkOption { | ||||
|       type = optionType; | ||||
|       readOnly = true; | ||||
|       default = functionTo config.output-type; | ||||
|     }; | ||||
|     function-type = mkOption { | ||||
|       type = optionType; | ||||
|       readOnly = true; | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue