33 lines
645 B
Nix
33 lines
645 B
Nix
{
|
|
pkgs,
|
|
lib,
|
|
config,
|
|
...
|
|
}:
|
|
with lib; let
|
|
cfg = config.home.security.gpg;
|
|
in {
|
|
options.home.security.gpg = {
|
|
enable = mkEnableOption "Enable GPG";
|
|
pinentry.package = mkOption {
|
|
type = types.package;
|
|
default =
|
|
if config.home.dev.editors.emacs.enable
|
|
then pkgs.pinentry-emacs
|
|
else pkgs.pinentry-gtk2;
|
|
};
|
|
};
|
|
config = mkIf cfg.enable {
|
|
programs.gpg = {
|
|
inherit (cfg) enable;
|
|
mutableKeys = true;
|
|
mutableTrust = true;
|
|
};
|
|
services.gpg-agent = {
|
|
enable = true;
|
|
enableSshSupport = true;
|
|
pinentry.package = cfg.pinentry.package;
|
|
};
|
|
};
|
|
}
|