Store providers as modules
This commit is contained in:
parent
52e6775be6
commit
ace62b0e4a
1 changed files with 68 additions and 75 deletions
|
@ -22,63 +22,8 @@ let
|
||||||
inherit default;
|
inherit default;
|
||||||
};
|
};
|
||||||
|
|
||||||
mkWebdavProvider = { vendor, vendorName }: (
|
mkProvider = (
|
||||||
{ providerOptions, ... }: {
|
{ config, ... }: {
|
||||||
displayName = vendorName;
|
|
||||||
|
|
||||||
options = {
|
|
||||||
vendor = lib.mkOption {
|
|
||||||
type = lib.types.str;
|
|
||||||
description = "The vendor of the WebDAV share.";
|
|
||||||
default = vendor;
|
|
||||||
};
|
|
||||||
|
|
||||||
url = lib.mkOption {
|
|
||||||
type = lib.types.str;
|
|
||||||
description = "The WebDAV URL of the ${vendorName} server to connect to.";
|
|
||||||
};
|
|
||||||
|
|
||||||
username = lib.mkOption {
|
|
||||||
type = lib.types.nullOr lib.types.str;
|
|
||||||
description = "The user name for logging in to the ${vendorName} server.";
|
|
||||||
default = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
obscuredPassword = lib.mkOption {
|
|
||||||
type = lib.types.nullOr lib.types.str;
|
|
||||||
description = "The password obscured using the `rclone obscure` command for logging in to the ${vendorName} server.";
|
|
||||||
default = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
obscuredPasswordFile = lib.mkOption {
|
|
||||||
type = lib.types.nullOr (lib.types.either lib.types.path lib.types.str);
|
|
||||||
description = "The path to a file containing the password obscured using the `rclone obscure` command for logging in to the ${vendorName} server.";
|
|
||||||
default = null;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = lib.mkMerge [
|
|
||||||
{
|
|
||||||
inherit vendor;
|
|
||||||
url = providerOptions.url;
|
|
||||||
}
|
|
||||||
(mkIfNotNull providerOptions.username { user = providerOptions.username; })
|
|
||||||
(mkIfNotNull providerOptions.obscuredPassword { pass = providerOptions.obscuredPassword; })
|
|
||||||
];
|
|
||||||
});
|
|
||||||
|
|
||||||
syncProviders = {
|
|
||||||
nextcloud = rec {
|
|
||||||
displayName = "Nextcloud";
|
|
||||||
provider = (mkWebdavProvider {
|
|
||||||
vendor = "nextcloud";
|
|
||||||
vendorName = displayName;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
mkSyncType = provider: lib.types.submodule (
|
|
||||||
{ config, name, ... }: {
|
|
||||||
options = {
|
options = {
|
||||||
path = lib.mkOption {
|
path = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
|
@ -91,12 +36,6 @@ let
|
||||||
default = true;
|
default = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
providerOptions = lib.mkOption {
|
|
||||||
description = "The options of the sync";
|
|
||||||
type = lib.types.submodule { inherit (provider config) options; };
|
|
||||||
default = { };
|
|
||||||
};
|
|
||||||
|
|
||||||
systemdDependencies = mkSystemdDependencyOption {
|
systemdDependencies = mkSystemdDependencyOption {
|
||||||
default = cfg.systemdDependencies;
|
default = cfg.systemdDependencies;
|
||||||
};
|
};
|
||||||
|
@ -119,15 +58,69 @@ let
|
||||||
visible = false;
|
visible = false;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
mkWebdavProvider = (
|
||||||
|
{ displayName, vendor, ... }: (
|
||||||
|
{ config, ... }: {
|
||||||
|
imports = [
|
||||||
|
mkProvider
|
||||||
|
];
|
||||||
|
|
||||||
|
options.providerOptions = {
|
||||||
|
vendor = lib.mkOption {
|
||||||
|
type = lib.types.str;
|
||||||
|
description = "The vendor of the WebDAV share.";
|
||||||
|
default = vendor;
|
||||||
|
};
|
||||||
|
|
||||||
|
url = lib.mkOption {
|
||||||
|
type = lib.types.str;
|
||||||
|
description = "The WebDAV URL of the ${displayName} server.";
|
||||||
|
default = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
username = lib.mkOption {
|
||||||
|
type = lib.types.nullOr lib.types.str;
|
||||||
|
description = "The user name for logging in to the ${displayName} server.";
|
||||||
|
default = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
obscuredPassword = lib.mkOption {
|
||||||
|
type = lib.types.nullOr lib.types.str;
|
||||||
|
description = "The password obscured using the `rclone obscure` command for logging in to the ${displayName} server.";
|
||||||
|
default = null;
|
||||||
|
};
|
||||||
|
|
||||||
|
obscuredPasswordFile = lib.mkOption {
|
||||||
|
type = lib.types.nullOr (lib.types.either lib.types.path lib.types.str);
|
||||||
|
description = "The path to a file containing the password obscured using the `rclone obscure` command for logging in to the ${displayName} server.";
|
||||||
|
default = null;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
inherit (provider (lib.debug.traceVal config))
|
config = lib.mkMerge [
|
||||||
environment
|
{
|
||||||
secretsScript
|
inherit vendor;
|
||||||
config
|
url = config.providerOptions.url;
|
||||||
;
|
}
|
||||||
|
(mkIfNotNull config.providerOptions.username { user = config.providerOptions.username; })
|
||||||
|
(mkIfNotNull config.providerOptions.obscuredPassword { pass = config.providerOptions.obscuredPassword; })
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}));
|
||||||
|
|
||||||
|
syncProviders = {
|
||||||
|
nextcloud = rec {
|
||||||
|
displayName = "Nextcloud";
|
||||||
|
|
||||||
|
module = mkWebdavProvider {
|
||||||
|
inherit displayName;
|
||||||
|
vendor = "nextcloud";
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
});
|
|
||||||
in {
|
in {
|
||||||
options = {
|
options = {
|
||||||
programs.rclone = {
|
programs.rclone = {
|
||||||
|
@ -139,9 +132,9 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
configs = (builtins.mapAttrs
|
configs = (builtins.mapAttrs
|
||||||
(name: providerDefinition: lib.mkOption {
|
(name: provider: lib.mkOption {
|
||||||
type = lib.types.attrsOf (mkSyncType providerDefinition.provider);
|
type = lib.types.attrsOf (lib.types.submodule provider.module);
|
||||||
description = "The ${providerDefinition.displayName} synchronizations to set up.";
|
description = "The ${provider.displayName} synchronizations to set up.";
|
||||||
default = { };
|
default = { };
|
||||||
})
|
})
|
||||||
syncProviders);
|
syncProviders);
|
||||||
|
|
Loading…
Reference in a new issue