258 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			258 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| {pkgs, lib, config, ...}:
 | |
| 
 | |
| with lib;
 | |
| 
 | |
| let
 | |
|   cfg = config.dysnomia;
 | |
| 
 | |
|   printProperties = properties:
 | |
|     concatMapStrings (propertyName:
 | |
|       let
 | |
|         property = properties.${propertyName};
 | |
|       in
 | |
|       if isList property then "${propertyName}=(${lib.concatMapStrings (elem: "\"${toString elem}\" ") (properties.${propertyName})})\n"
 | |
|       else "${propertyName}=\"${toString property}\"\n"
 | |
|     ) (builtins.attrNames properties);
 | |
| 
 | |
|   properties = pkgs.stdenv.mkDerivation {
 | |
|     name = "dysnomia-properties";
 | |
|     buildCommand = ''
 | |
|       cat > $out << "EOF"
 | |
|       ${printProperties cfg.properties}
 | |
|       EOF
 | |
|     '';
 | |
|   };
 | |
| 
 | |
|   containersDir = pkgs.stdenv.mkDerivation {
 | |
|     name = "dysnomia-containers";
 | |
|     buildCommand = ''
 | |
|       mkdir -p $out
 | |
|       cd $out
 | |
| 
 | |
|       ${concatMapStrings (containerName:
 | |
|         let
 | |
|           containerProperties = cfg.containers.${containerName};
 | |
|         in
 | |
|         ''
 | |
|           cat > ${containerName} <<EOF
 | |
|           ${printProperties containerProperties}
 | |
|           type=${containerName}
 | |
|           EOF
 | |
|         ''
 | |
|       ) (builtins.attrNames cfg.containers)}
 | |
|     '';
 | |
|   };
 | |
| 
 | |
|   linkMutableComponents = {containerName}:
 | |
|     ''
 | |
|       mkdir ${containerName}
 | |
| 
 | |
|       ${concatMapStrings (componentName:
 | |
|         let
 | |
|           component = cfg.components.${containerName}.${componentName};
 | |
|         in
 | |
|         "ln -s ${component} ${containerName}/${componentName}\n"
 | |
|       ) (builtins.attrNames (cfg.components.${containerName} or {}))}
 | |
|     '';
 | |
| 
 | |
|   componentsDir = pkgs.stdenv.mkDerivation {
 | |
|     name = "dysnomia-components";
 | |
|     buildCommand = ''
 | |
|       mkdir -p $out
 | |
|       cd $out
 | |
| 
 | |
|       ${concatMapStrings (containerName:
 | |
|         linkMutableComponents { inherit containerName; }
 | |
|       ) (builtins.attrNames cfg.components)}
 | |
|     '';
 | |
|   };
 | |
| 
 | |
|   dysnomiaFlags = {
 | |
|     enableApacheWebApplication = config.services.httpd.enable;
 | |
|     enableAxis2WebService = config.services.tomcat.axis2.enable;
 | |
|     enableDockerContainer = config.virtualisation.docker.enable;
 | |
|     enableEjabberdDump = config.services.ejabberd.enable;
 | |
|     enableMySQLDatabase = config.services.mysql.enable;
 | |
|     enablePostgreSQLDatabase = config.services.postgresql.enable;
 | |
|     enableTomcatWebApplication = config.services.tomcat.enable;
 | |
|     enableMongoDatabase = config.services.mongodb.enable;
 | |
|     enableSubversionRepository = config.services.svnserve.enable;
 | |
|     enableInfluxDatabase = config.services.influxdb.enable;
 | |
|   };
 | |
| in
 | |
| {
 | |
|   options = {
 | |
|     dysnomia = {
 | |
| 
 | |
|       enable = mkOption {
 | |
|         type = types.bool;
 | |
|         default = false;
 | |
|         description = "Whether to enable Dysnomia";
 | |
|       };
 | |
| 
 | |
|       enableAuthentication = mkOption {
 | |
|         type = types.bool;
 | |
|         default = false;
 | |
|         description = "Whether to publish privacy-sensitive authentication credentials";
 | |
|       };
 | |
| 
 | |
|       package = mkOption {
 | |
|         type = types.path;
 | |
|         description = "The Dysnomia package";
 | |
|       };
 | |
| 
 | |
|       properties = mkOption {
 | |
|         description = "An attribute set in which each attribute represents a machine property. Optionally, these values can be shell substitutions.";
 | |
|         default = {};
 | |
|       };
 | |
| 
 | |
|       containers = mkOption {
 | |
|         description = "An attribute set in which each key represents a container and each value an attribute set providing its configuration properties";
 | |
|         default = {};
 | |
|       };
 | |
| 
 | |
|       components = mkOption {
 | |
|         description = "An atttribute set in which each key represents a container and each value an attribute set in which each key represents a component and each value a derivation constructing its initial state";
 | |
|         default = {};
 | |
|       };
 | |
| 
 | |
|       extraContainerProperties = mkOption {
 | |
|         description = "An attribute set providing additional container settings in addition to the default properties";
 | |
|         default = {};
 | |
|       };
 | |
| 
 | |
|       extraContainerPaths = mkOption {
 | |
|         description = "A list of paths containing additional container configurations that are added to the search folders";
 | |
|         default = [];
 | |
|       };
 | |
| 
 | |
|       extraModulePaths = mkOption {
 | |
|         description = "A list of paths containing additional modules that are added to the search folders";
 | |
|         default = [];
 | |
|       };
 | |
| 
 | |
|       enableLegacyModules = mkOption {
 | |
|         type = types.bool;
 | |
|         default = true;
 | |
|         description = "Whether to enable Dysnomia legacy process and wrapper modules";
 | |
|       };
 | |
|     };
 | |
|   };
 | |
| 
 | |
|   config = mkIf cfg.enable {
 | |
| 
 | |
|     environment.etc = {
 | |
|       "dysnomia/containers" = {
 | |
|         source = containersDir;
 | |
|       };
 | |
|       "dysnomia/components" = {
 | |
|         source = componentsDir;
 | |
|       };
 | |
|       "dysnomia/properties" = {
 | |
|         source = properties;
 | |
|       };
 | |
|     };
 | |
| 
 | |
|     environment.variables = {
 | |
|       DYSNOMIA_STATEDIR = "/var/state/dysnomia-nixos";
 | |
|       DYSNOMIA_CONTAINERS_PATH = "${lib.concatMapStrings (containerPath: "${containerPath}:") cfg.extraContainerPaths}/etc/dysnomia/containers";
 | |
|       DYSNOMIA_MODULES_PATH = "${lib.concatMapStrings (modulePath: "${modulePath}:") cfg.extraModulePaths}/etc/dysnomia/modules";
 | |
|     };
 | |
| 
 | |
|     environment.systemPackages = [ cfg.package ];
 | |
| 
 | |
|     dysnomia.package = pkgs.dysnomia.override (origArgs: dysnomiaFlags // lib.optionalAttrs (cfg.enableLegacyModules) {
 | |
|       enableLegacy = builtins.trace ''
 | |
|         WARNING: Dysnomia has been configured to use the legacy 'process' and 'wrapper'
 | |
|         modules for compatibility reasons! If you rely on these modules, consider
 | |
|         migrating to better alternatives.
 | |
| 
 | |
|         More information: https://raw.githubusercontent.com/svanderburg/dysnomia/f65a9a84827bcc4024d6b16527098b33b02e4054/README-legacy.md
 | |
| 
 | |
|         If you have migrated already or don't rely on these Dysnomia modules, you can
 | |
|         disable legacy mode with the following NixOS configuration option:
 | |
| 
 | |
|         dysnomia.enableLegacyModules = false;
 | |
| 
 | |
|         In a future version of Dysnomia (and NixOS) the legacy option will go away!
 | |
|       '' true;
 | |
|     });
 | |
| 
 | |
|     dysnomia.properties = {
 | |
|       hostname = config.networking.hostName;
 | |
|       inherit (config.nixpkgs.localSystem) system;
 | |
| 
 | |
|       supportedTypes = [
 | |
|         "echo"
 | |
|         "fileset"
 | |
|         "process"
 | |
|         "wrapper"
 | |
| 
 | |
|         # These are not base modules, but they are still enabled because they work with technology that are always enabled in NixOS
 | |
|         "systemd-unit"
 | |
|         "sysvinit-script"
 | |
|         "nixos-configuration"
 | |
|       ]
 | |
|       ++ optional (dysnomiaFlags.enableApacheWebApplication) "apache-webapplication"
 | |
|       ++ optional (dysnomiaFlags.enableAxis2WebService) "axis2-webservice"
 | |
|       ++ optional (dysnomiaFlags.enableDockerContainer) "docker-container"
 | |
|       ++ optional (dysnomiaFlags.enableEjabberdDump) "ejabberd-dump"
 | |
|       ++ optional (dysnomiaFlags.enableInfluxDatabase) "influx-database"
 | |
|       ++ optional (dysnomiaFlags.enableMySQLDatabase) "mysql-database"
 | |
|       ++ optional (dysnomiaFlags.enablePostgreSQLDatabase) "postgresql-database"
 | |
|       ++ optional (dysnomiaFlags.enableTomcatWebApplication) "tomcat-webapplication"
 | |
|       ++ optional (dysnomiaFlags.enableMongoDatabase) "mongo-database"
 | |
|       ++ optional (dysnomiaFlags.enableSubversionRepository) "subversion-repository";
 | |
|     };
 | |
| 
 | |
|     dysnomia.containers = lib.recursiveUpdate ({
 | |
|       process = {};
 | |
|       wrapper = {};
 | |
|     }
 | |
|     // lib.optionalAttrs (config.services.httpd.enable) { apache-webapplication = {
 | |
|       documentRoot = config.services.httpd.virtualHosts.localhost.documentRoot;
 | |
|     }; }
 | |
|     // lib.optionalAttrs (config.services.tomcat.axis2.enable) { axis2-webservice = {}; }
 | |
|     // lib.optionalAttrs (config.services.ejabberd.enable) { ejabberd-dump = {
 | |
|       ejabberdUser = config.services.ejabberd.user;
 | |
|     }; }
 | |
|     // lib.optionalAttrs (config.services.mysql.enable) { mysql-database = {
 | |
|         mysqlPort = config.services.mysql.port;
 | |
|         mysqlSocket = "/run/mysqld/mysqld.sock";
 | |
|       } // lib.optionalAttrs cfg.enableAuthentication {
 | |
|         mysqlUsername = "root";
 | |
|       };
 | |
|     }
 | |
|     // lib.optionalAttrs (config.services.postgresql.enable) { postgresql-database = {
 | |
|       } // lib.optionalAttrs (cfg.enableAuthentication) {
 | |
|         postgresqlUsername = "postgres";
 | |
|       };
 | |
|     }
 | |
|     // lib.optionalAttrs (config.services.tomcat.enable) { tomcat-webapplication = {
 | |
|       tomcatPort = 8080;
 | |
|     }; }
 | |
|     // lib.optionalAttrs (config.services.mongodb.enable) { mongo-database = {}; }
 | |
|     // lib.optionalAttrs (config.services.influxdb.enable) {
 | |
|       influx-database = {
 | |
|         influxdbUsername = config.services.influxdb.user;
 | |
|         influxdbDataDir = "${config.services.influxdb.dataDir}/data";
 | |
|         influxdbMetaDir = "${config.services.influxdb.dataDir}/meta";
 | |
|       };
 | |
|     }
 | |
|     // lib.optionalAttrs (config.services.svnserve.enable) { subversion-repository = {
 | |
|       svnBaseDir = config.services.svnserve.svnBaseDir;
 | |
|     }; }) cfg.extraContainerProperties;
 | |
| 
 | |
|     system.activationScripts.dysnomia = ''
 | |
|       mkdir -p /etc/systemd-mutable/system
 | |
|       if [ ! -f /etc/systemd-mutable/system/dysnomia.target ]
 | |
|       then
 | |
|           ( echo "[Unit]"
 | |
|             echo "Description=Services that are activated and deactivated by Dysnomia"
 | |
|             echo "After=final.target"
 | |
|           ) > /etc/systemd-mutable/system/dysnomia.target
 | |
|       fi
 | |
|     '';
 | |
|   };
 | |
| }
 | 
