blob: 9de27c0fa5fee100fcbff0078cddb8a65a513f47 (
plain) (
tree)
|
|
{
lib,
config,
pkgs,
sysLib,
...
}: let
cfg = config.soispha.services.unison;
script = import ./shellScript.nix {inherit sysLib lib pkgs cfg;};
in {
options.soispha.services.unison = let
homePath = lib.types.strMatching "^~.*";
in {
enable = lib.mkEnableOption "a unison home sync script";
dataDir = lib.mkOption {
type = lib.types.path;
description = ''
This directory is used by unison to store it's data.
'';
};
foreign = {
address = lib.mkOption {
type = lib.types.str;
description = ''
The address to contact via ssh, when syncing.
'';
};
userName = lib.mkOption {
type = lib.types.str;
description = ''
The user name to try to login with at the foreign host.
'';
};
};
userSourceDir = lib.mkOption {
description = ''
The directory to replace the `~` in the relative user paths with.
If using `impermanence`, this should be the path to the persistent home directory.
'';
};
pathsToIgnore = lib.mkOption {
type = lib.types.listOf homePath;
default = [];
description = ''
A list of the paths that should not be synced.
Beware that this applies not only to this path, but also to all paths under it.
'';
};
pathsToSync = lib.mkOption {
type = lib.types.listOf homePath;
default = [];
description = ''
A list of the paths that should be synced.
Beware that this applies not only to this path, but also to all paths under it.
'';
};
unisonOptions = lib.mkOption {
internal = true;
default = {
sshcmd = "ssh";
ui = "text";
auto = "true";
backupdir = "${cfg.dataDir}/backups";
backuploc = "central";
};
type = lib.types.attrsOf lib.types.str;
description = "The options passed to every unison call.";
};
};
config = lib.mkIf cfg.enable {
home-manager.users.soispha = {
home.sessionVariables = {
UNISON = cfg.dataDir;
};
home.packages = [
pkgs.unison
script
];
};
};
}
|