mirror of
https://github.com/nix-community/home-manager
synced 2024-12-31 22:29:47 +01:00
9f9e277b60
These (and the `*MD` functions apart from `literalMD`) are now no-ops in nixpkgs and serve no purpose other than to add additional noise and potentially mislead people into thinking unmarked DocBook documentation will still be accepted. Note that if backporting changes including documentation to 23.05, the `mdDoc` calls will need to be re-added. To reproduce this commit, run: $ NIX_PATH=nixpkgs=flake:nixpkgs/e7e69199f0372364a6106a1e735f68604f4c5a25 \ nix shell nixpkgs#coreutils \ -c find . -name '*.nix' \ -exec nix run -- github:emilazy/nix-doc-munge/98dadf1f77351c2ba5dcb709a2a171d655f15099 \ --strip {} + $ ./format
134 lines
3.3 KiB
Nix
134 lines
3.3 KiB
Nix
{ config, lib, pkgs, ... }:
|
||
|
||
with lib;
|
||
|
||
let
|
||
|
||
cfg = config.accounts.contact;
|
||
|
||
localModule = name:
|
||
types.submodule {
|
||
options = {
|
||
path = mkOption {
|
||
type = types.str;
|
||
default = "${cfg.basePath}/${name}";
|
||
defaultText = "‹accounts.contact.basePath›/‹name›";
|
||
description = "The path of the storage.";
|
||
};
|
||
|
||
type = mkOption {
|
||
type = types.enum [ "filesystem" "singlefile" ];
|
||
description = "The type of the storage.";
|
||
};
|
||
|
||
fileExt = mkOption {
|
||
type = types.nullOr types.str;
|
||
default = null;
|
||
description = "The file extension to use.";
|
||
};
|
||
|
||
encoding = mkOption {
|
||
type = types.nullOr types.str;
|
||
default = null;
|
||
description = ''
|
||
File encoding for items, both content and file name.
|
||
Defaults to UTF-8.
|
||
'';
|
||
};
|
||
};
|
||
};
|
||
|
||
remoteModule = types.submodule {
|
||
options = {
|
||
type = mkOption {
|
||
type = types.enum [ "carddav" "http" "google_contacts" ];
|
||
description = "The type of the storage.";
|
||
};
|
||
|
||
url = mkOption {
|
||
type = types.nullOr types.str;
|
||
default = null;
|
||
description = "The URL of the storage.";
|
||
};
|
||
|
||
userName = mkOption {
|
||
type = types.nullOr types.str;
|
||
default = null;
|
||
description = "User name for authentication.";
|
||
};
|
||
|
||
# userNameCommand = mkOption {
|
||
# type = types.nullOr (types.listOf types.str);
|
||
# default = null;
|
||
# example = [ "~/get-username.sh" ];
|
||
# description = ''
|
||
# A command that prints the user name to standard output.
|
||
# '';
|
||
# };
|
||
|
||
passwordCommand = mkOption {
|
||
type = types.nullOr (types.listOf types.str);
|
||
default = null;
|
||
example = [ "pass" "caldav" ];
|
||
description = ''
|
||
A command that prints the password to standard output.
|
||
'';
|
||
};
|
||
};
|
||
};
|
||
|
||
contactOpts = { name, config, ... }: {
|
||
options = {
|
||
name = mkOption {
|
||
type = types.str;
|
||
readOnly = true;
|
||
description = ''
|
||
Unique identifier of the contact account. This is set to the
|
||
attribute name of the contact configuration.
|
||
'';
|
||
};
|
||
|
||
local = mkOption {
|
||
type = types.nullOr (localModule name);
|
||
default = null;
|
||
description = ''
|
||
Local configuration for the contacts.
|
||
'';
|
||
};
|
||
|
||
remote = mkOption {
|
||
type = types.nullOr remoteModule;
|
||
default = null;
|
||
description = ''
|
||
Remote configuration for the contacts.
|
||
'';
|
||
};
|
||
};
|
||
|
||
config = { name = name; };
|
||
};
|
||
|
||
in {
|
||
options.accounts.contact = {
|
||
basePath = mkOption {
|
||
type = types.str;
|
||
apply = p:
|
||
if hasPrefix "/" p then p else "${config.home.homeDirectory}/${p}";
|
||
description = ''
|
||
The base directory in which to save contacts. May be a
|
||
relative path, in which case it is relative the home
|
||
directory.
|
||
'';
|
||
};
|
||
|
||
accounts = mkOption {
|
||
type = types.attrsOf (types.submodule [
|
||
contactOpts
|
||
(import ../programs/vdirsyncer-accounts.nix)
|
||
(import ../programs/khal-accounts.nix)
|
||
]);
|
||
default = { };
|
||
description = "List of contacts.";
|
||
};
|
||
};
|
||
}
|