nixos: dysnomia: move into services
subtree
This commit is contained in:
parent
302c170e1c
commit
02da27de52
@ -4,6 +4,7 @@ with lib;
|
|||||||
|
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
(mkRenamedOptionModule [ "dysnomia" ] [ "services" "dysnomia" ])
|
||||||
(mkRenamedOptionModule [ "environment" "x11Packages" ] [ "environment" "systemPackages" ])
|
(mkRenamedOptionModule [ "environment" "x11Packages" ] [ "environment" "systemPackages" ])
|
||||||
(mkRenamedOptionModule [ "environment" "enableBashCompletion" ] [ "programs" "bash" "enableCompletion" ])
|
(mkRenamedOptionModule [ "environment" "enableBashCompletion" ] [ "programs" "bash" "enableCompletion" ])
|
||||||
(mkRenamedOptionModule [ "environment" "nix" ] [ "nix" "package" ])
|
(mkRenamedOptionModule [ "environment" "nix" ] [ "nix" "package" ])
|
||||||
|
@ -57,7 +57,7 @@ in
|
|||||||
###### implementation
|
###### implementation
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
dysnomia.enable = true;
|
services.dysnomia.enable = true;
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.disnix ] ++ optional cfg.useWebServiceInterface pkgs.DisnixWebService;
|
environment.systemPackages = [ pkgs.disnix ] ++ optional cfg.useWebServiceInterface pkgs.DisnixWebService;
|
||||||
|
|
||||||
|
@ -3,8 +3,8 @@
|
|||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
cfg = config.dysnomia;
|
cfg = config.services.dysnomia;
|
||||||
|
|
||||||
printProperties = properties:
|
printProperties = properties:
|
||||||
concatMapStrings (propertyName:
|
concatMapStrings (propertyName:
|
||||||
let
|
let
|
||||||
@ -13,7 +13,7 @@ let
|
|||||||
if isList property then "${propertyName}=(${lib.concatMapStrings (elem: "\"${toString elem}\" ") (properties."${propertyName}")})\n"
|
if isList property then "${propertyName}=(${lib.concatMapStrings (elem: "\"${toString elem}\" ") (properties."${propertyName}")})\n"
|
||||||
else "${propertyName}=\"${toString property}\"\n"
|
else "${propertyName}=\"${toString property}\"\n"
|
||||||
) (builtins.attrNames properties);
|
) (builtins.attrNames properties);
|
||||||
|
|
||||||
properties = pkgs.stdenv.mkDerivation {
|
properties = pkgs.stdenv.mkDerivation {
|
||||||
name = "dysnomia-properties";
|
name = "dysnomia-properties";
|
||||||
buildCommand = ''
|
buildCommand = ''
|
||||||
@ -22,13 +22,13 @@ let
|
|||||||
EOF
|
EOF
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
containersDir = pkgs.stdenv.mkDerivation {
|
containersDir = pkgs.stdenv.mkDerivation {
|
||||||
name = "dysnomia-containers";
|
name = "dysnomia-containers";
|
||||||
buildCommand = ''
|
buildCommand = ''
|
||||||
mkdir -p $out
|
mkdir -p $out
|
||||||
cd $out
|
cd $out
|
||||||
|
|
||||||
${concatMapStrings (containerName:
|
${concatMapStrings (containerName:
|
||||||
let
|
let
|
||||||
containerProperties = cfg.containers."${containerName}";
|
containerProperties = cfg.containers."${containerName}";
|
||||||
@ -42,11 +42,11 @@ let
|
|||||||
) (builtins.attrNames cfg.containers)}
|
) (builtins.attrNames cfg.containers)}
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
linkMutableComponents = {containerName}:
|
linkMutableComponents = {containerName}:
|
||||||
''
|
''
|
||||||
mkdir ${containerName}
|
mkdir ${containerName}
|
||||||
|
|
||||||
${concatMapStrings (componentName:
|
${concatMapStrings (componentName:
|
||||||
let
|
let
|
||||||
component = cfg.components."${containerName}"."${componentName}";
|
component = cfg.components."${containerName}"."${componentName}";
|
||||||
@ -54,13 +54,13 @@ let
|
|||||||
"ln -s ${component} ${containerName}/${componentName}\n"
|
"ln -s ${component} ${containerName}/${componentName}\n"
|
||||||
) (builtins.attrNames (cfg.components."${containerName}" or {}))}
|
) (builtins.attrNames (cfg.components."${containerName}" or {}))}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
componentsDir = pkgs.stdenv.mkDerivation {
|
componentsDir = pkgs.stdenv.mkDerivation {
|
||||||
name = "dysnomia-components";
|
name = "dysnomia-components";
|
||||||
buildCommand = ''
|
buildCommand = ''
|
||||||
mkdir -p $out
|
mkdir -p $out
|
||||||
cd $out
|
cd $out
|
||||||
|
|
||||||
${concatMapStrings (containerName:
|
${concatMapStrings (containerName:
|
||||||
let
|
let
|
||||||
components = cfg.components."${containerName}";
|
components = cfg.components."${containerName}";
|
||||||
@ -72,59 +72,59 @@ let
|
|||||||
in
|
in
|
||||||
{
|
{
|
||||||
options = {
|
options = {
|
||||||
dysnomia = {
|
services.dysnomia = {
|
||||||
|
|
||||||
enable = mkOption {
|
enable = mkOption {
|
||||||
type = types.bool;
|
type = types.bool;
|
||||||
default = false;
|
default = false;
|
||||||
description = "Whether to enable Dysnomia";
|
description = "Whether to enable Dysnomia";
|
||||||
};
|
};
|
||||||
|
|
||||||
enableAuthentication = mkOption {
|
enableAuthentication = mkOption {
|
||||||
type = types.bool;
|
type = types.bool;
|
||||||
default = false;
|
default = false;
|
||||||
description = "Whether to publish privacy-sensitive authentication credentials";
|
description = "Whether to publish privacy-sensitive authentication credentials";
|
||||||
};
|
};
|
||||||
|
|
||||||
package = mkOption {
|
package = mkOption {
|
||||||
type = types.path;
|
type = types.path;
|
||||||
description = "The Dysnomia package";
|
description = "The Dysnomia package";
|
||||||
};
|
};
|
||||||
|
|
||||||
properties = mkOption {
|
properties = mkOption {
|
||||||
description = "An attribute set in which each attribute represents a machine property. Optionally, these values can be shell substitutions.";
|
description = "An attribute set in which each attribute represents a machine property. Optionally, these values can be shell substitutions.";
|
||||||
default = {};
|
default = {};
|
||||||
};
|
};
|
||||||
|
|
||||||
containers = mkOption {
|
containers = mkOption {
|
||||||
description = "An attribute set in which each key represents a container and each value an attribute set providing its configuration properties";
|
description = "An attribute set in which each key represents a container and each value an attribute set providing its configuration properties";
|
||||||
default = {};
|
default = {};
|
||||||
};
|
};
|
||||||
|
|
||||||
components = mkOption {
|
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";
|
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 = {};
|
default = {};
|
||||||
};
|
};
|
||||||
|
|
||||||
extraContainerProperties = mkOption {
|
extraContainerProperties = mkOption {
|
||||||
description = "An attribute set providing additional container settings in addition to the default properties";
|
description = "An attribute set providing additional container settings in addition to the default properties";
|
||||||
default = {};
|
default = {};
|
||||||
};
|
};
|
||||||
|
|
||||||
extraContainerPaths = mkOption {
|
extraContainerPaths = mkOption {
|
||||||
description = "A list of paths containing additional container configurations that are added to the search folders";
|
description = "A list of paths containing additional container configurations that are added to the search folders";
|
||||||
default = [];
|
default = [];
|
||||||
};
|
};
|
||||||
|
|
||||||
extraModulePaths = mkOption {
|
extraModulePaths = mkOption {
|
||||||
description = "A list of paths containing additional modules that are added to the search folders";
|
description = "A list of paths containing additional modules that are added to the search folders";
|
||||||
default = [];
|
default = [];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
|
|
||||||
environment.etc = {
|
environment.etc = {
|
||||||
"dysnomia/containers" = {
|
"dysnomia/containers" = {
|
||||||
source = containersDir;
|
source = containersDir;
|
||||||
@ -136,16 +136,16 @@ in
|
|||||||
source = properties;
|
source = properties;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
environment.variables = {
|
environment.variables = {
|
||||||
DYSNOMIA_STATEDIR = "/var/state/dysnomia-nixos";
|
DYSNOMIA_STATEDIR = "/var/state/dysnomia-nixos";
|
||||||
DYSNOMIA_CONTAINERS_PATH = "${lib.concatMapStrings (containerPath: "${containerPath}:") cfg.extraContainerPaths}/etc/dysnomia/containers";
|
DYSNOMIA_CONTAINERS_PATH = "${lib.concatMapStrings (containerPath: "${containerPath}:") cfg.extraContainerPaths}/etc/dysnomia/containers";
|
||||||
DYSNOMIA_MODULES_PATH = "${lib.concatMapStrings (modulePath: "${modulePath}:") cfg.extraModulePaths}/etc/dysnomia/modules";
|
DYSNOMIA_MODULES_PATH = "${lib.concatMapStrings (modulePath: "${modulePath}:") cfg.extraModulePaths}/etc/dysnomia/modules";
|
||||||
};
|
};
|
||||||
|
|
||||||
environment.systemPackages = [ cfg.package ];
|
environment.systemPackages = [ cfg.package ];
|
||||||
|
|
||||||
dysnomia.package = pkgs.dysnomia.override (origArgs: {
|
services.dysnomia.package = pkgs.dysnomia.override (origArgs: {
|
||||||
enableApacheWebApplication = config.services.httpd.enable;
|
enableApacheWebApplication = config.services.httpd.enable;
|
||||||
enableAxis2WebService = config.services.tomcat.axis2.enable;
|
enableAxis2WebService = config.services.tomcat.axis2.enable;
|
||||||
enableEjabberdDump = config.services.ejabberd.enable;
|
enableEjabberdDump = config.services.ejabberd.enable;
|
||||||
@ -155,8 +155,8 @@ in
|
|||||||
enableTomcatWebApplication = config.services.tomcat.enable;
|
enableTomcatWebApplication = config.services.tomcat.enable;
|
||||||
enableMongoDatabase = config.services.mongodb.enable;
|
enableMongoDatabase = config.services.mongodb.enable;
|
||||||
});
|
});
|
||||||
|
|
||||||
dysnomia.properties = {
|
services.dysnomia.properties = {
|
||||||
hostname = config.networking.hostName;
|
hostname = config.networking.hostName;
|
||||||
system = if config.nixpkgs.system == "" then builtins.currentSystem else config.nixpkgs.system;
|
system = if config.nixpkgs.system == "" then builtins.currentSystem else config.nixpkgs.system;
|
||||||
|
|
||||||
@ -173,8 +173,8 @@ in
|
|||||||
'';
|
'';
|
||||||
}}");
|
}}");
|
||||||
};
|
};
|
||||||
|
|
||||||
dysnomia.containers = lib.recursiveUpdate ({
|
services.dysnomia.containers = lib.recursiveUpdate ({
|
||||||
process = {};
|
process = {};
|
||||||
wrapper = {};
|
wrapper = {};
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user