-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
-
34
-
35
-
36
-
37
-
38
-
39
-
40
-
41
-
42
-
43
-
44
-
45
-
46
-
47
-
48
-
49
-
50
-
51
-
52
-
53
-
54
-
55
-
56
-
57
-
58
-
59
-
60
-
61
-
62
-
63
-
64
-
65
{ lib, pkgs, config, ... }:
let
cfg = config.features.identity;
in
{
options = {
features.identity = {
name = lib.mkOption {
type = lib.types.nullOr lib.types.nonEmptyStr;
default = null;
description = ''
Your name, prefebly publicly distinguishable.
'';
};
email = lib.mkOption {
type = lib.types.nullOr lib.types.nonEmptyStr;
default = null;
description = ''
Email address.
'';
};
gpgSigningKeyId = lib.mkOption {
type = lib.types.nullOr lib.types.nonEmptyStr;
default = null;
description = ''
A key ID of a signing key (primary or subkey).
This is a **key ID**, which is visible to public.
Do not put key signature here.
'';
};
};
};
config = {
programs = {
gpg = {
enable = cfg.gpgSigningKeyId != null;
};
};
services.gpg-agent = {
enable = cfg.gpgSigningKeyId != null && pkgs.stdenv.isLinux;
enableZshIntegration = config.programs.zsh.enable;
# 1day
defaultCacheTtl = 86400;
defaultCacheTtlSsh = 86400;
# 30days
maxCacheTtl = 2592000;
maxCacheTtlSsh = 2592000;
pinentryFlavor = "curses";
};
};
}