2020-04-24 23:36:52 +00:00
|
|
|
|
# Global configuration for the SSH client.
|
|
|
|
|
|
|
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
|
|
let
|
|
|
|
|
|
|
|
|
|
cfg = config.programs.ssh;
|
|
|
|
|
|
|
|
|
|
askPasswordWrapper = pkgs.writeScript "ssh-askpass-wrapper"
|
|
|
|
|
''
|
|
|
|
|
#! ${pkgs.runtimeShell} -e
|
|
|
|
|
export DISPLAY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^DISPLAY=\(.*\)/\1/; t; d')"
|
2024-01-25 14:12:00 +00:00
|
|
|
|
export XAUTHORITY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^XAUTHORITY=\(.*\)/\1/; t; d')"
|
2022-10-21 18:38:19 +00:00
|
|
|
|
export WAYLAND_DISPLAY="$(systemctl --user show-environment | ${pkgs.gnused}/bin/sed 's/^WAYLAND_DISPLAY=\(.*\)/\1/; t; d')"
|
2024-01-02 11:29:13 +00:00
|
|
|
|
exec ${cfg.askPassword} "$@"
|
2020-04-24 23:36:52 +00:00
|
|
|
|
'';
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
knownHosts = builtins.attrValues cfg.knownHosts;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
knownHostsText = (lib.flip (lib.concatMapStringsSep "\n") knownHosts
|
2020-04-24 23:36:52 +00:00
|
|
|
|
(h: assert h.hostNames != [];
|
2024-05-15 15:35:15 +00:00
|
|
|
|
lib.optionalString h.certAuthority "@cert-authority " + builtins.concatStringsSep "," h.hostNames + " "
|
|
|
|
|
+ (if h.publicKey != null then h.publicKey else builtins.readFile h.publicKeyFile)
|
2020-04-24 23:36:52 +00:00
|
|
|
|
)) + "\n";
|
|
|
|
|
|
2023-04-29 16:46:19 +00:00
|
|
|
|
knownHostsFiles = [ "/etc/ssh/ssh_known_hosts" ]
|
2024-05-15 15:35:15 +00:00
|
|
|
|
++ builtins.map pkgs.copyPathToStore cfg.knownHostsFiles;
|
2022-01-13 20:06:32 +00:00
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
|
in
|
|
|
|
|
{
|
|
|
|
|
###### interface
|
|
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
|
|
|
|
programs.ssh = {
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
enableAskPassword = lib.mkOption {
|
|
|
|
|
type = lib.types.bool;
|
2021-12-19 01:06:50 +00:00
|
|
|
|
default = config.services.xserver.enable;
|
2024-05-15 15:35:15 +00:00
|
|
|
|
defaultText = lib.literalExpression "config.services.xserver.enable";
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = "Whether to configure SSH_ASKPASS in the environment.";
|
2021-12-19 01:06:50 +00:00
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
askPassword = lib.mkOption {
|
|
|
|
|
type = lib.types.str;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = "${pkgs.x11_ssh_askpass}/libexec/x11-ssh-askpass";
|
2024-05-15 15:35:15 +00:00
|
|
|
|
defaultText = lib.literalExpression ''"''${pkgs.x11_ssh_askpass}/libexec/x11-ssh-askpass"'';
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = "Program used by SSH to ask for passwords.";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
forwardX11 = lib.mkOption {
|
2024-01-02 11:29:13 +00:00
|
|
|
|
type = with lib.types; nullOr bool;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = false;
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
Whether to request X11 forwarding on outgoing connections by default.
|
2024-01-02 11:29:13 +00:00
|
|
|
|
If set to null, the option is not set at all.
|
2020-04-24 23:36:52 +00:00
|
|
|
|
This is useful for running graphical programs on the remote machine and have them display to your local X11 server.
|
|
|
|
|
Historically, this value has depended on the value used by the local sshd daemon, but there really isn't a relation between the two.
|
|
|
|
|
Note: there are some security risks to forwarding an X11 connection.
|
|
|
|
|
NixOS's X server is built with the SECURITY extension, which prevents some obvious attacks.
|
|
|
|
|
To enable or disable forwarding on a per-connection basis, see the -X and -x options to ssh.
|
|
|
|
|
The -Y option to ssh enables trusted forwarding, which bypasses the SECURITY extension.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
setXAuthLocation = lib.mkOption {
|
|
|
|
|
type = lib.types.bool;
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2022-08-12 12:06:08 +00:00
|
|
|
|
Whether to set the path to {command}`xauth` for X11-forwarded connections.
|
2020-04-24 23:36:52 +00:00
|
|
|
|
This causes a dependency on X11 packages.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
pubkeyAcceptedKeyTypes = lib.mkOption {
|
|
|
|
|
type = lib.types.listOf lib.types.str;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = [];
|
|
|
|
|
example = [ "ssh-ed25519" "ssh-rsa" ];
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2024-05-15 15:35:15 +00:00
|
|
|
|
Specifies the key lib.types that will be used for public key authentication.
|
2020-04-24 23:36:52 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
hostKeyAlgorithms = lib.mkOption {
|
|
|
|
|
type = lib.types.listOf lib.types.str;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = [];
|
|
|
|
|
example = [ "ssh-ed25519" "ssh-rsa" ];
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
Specifies the host key algorithms that the client wants to use in order of preference.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
extraConfig = lib.mkOption {
|
|
|
|
|
type = lib.types.lines;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = "";
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2022-08-21 13:32:41 +00:00
|
|
|
|
Extra configuration text prepended to {file}`ssh_config`. Other generated
|
|
|
|
|
options will be added after a `Host *` pattern.
|
|
|
|
|
See {manpage}`ssh_config(5)`
|
2020-04-24 23:36:52 +00:00
|
|
|
|
for help.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
startAgent = lib.mkOption {
|
|
|
|
|
type = lib.types.bool;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = false;
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
Whether to start the OpenSSH agent when you log in. The OpenSSH agent
|
|
|
|
|
remembers private keys for you so that you don't have to type in
|
|
|
|
|
passphrases every time you make an SSH connection. Use
|
2022-08-12 12:06:08 +00:00
|
|
|
|
{command}`ssh-add` to add a key to the agent.
|
2020-04-24 23:36:52 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
agentTimeout = lib.mkOption {
|
|
|
|
|
type = lib.types.nullOr lib.types.str;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = null;
|
|
|
|
|
example = "1h";
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
How long to keep the private keys in memory. Use null to keep them forever.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
agentPKCS11Whitelist = lib.mkOption {
|
|
|
|
|
type = lib.types.nullOr lib.types.str;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = null;
|
2024-05-15 15:35:15 +00:00
|
|
|
|
example = lib.literalExpression ''"''${pkgs.opensc}/lib/opensc-pkcs11.so"'';
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
A pattern-list of acceptable paths for PKCS#11 shared libraries
|
|
|
|
|
that may be used with the -s option to ssh-add.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
package = lib.mkPackageOption pkgs "openssh" { };
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
knownHosts = lib.mkOption {
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = {};
|
2024-05-15 15:35:15 +00:00
|
|
|
|
type = lib.types.attrsOf (lib.types.submodule ({ name, config, options, ... }: {
|
2020-04-24 23:36:52 +00:00
|
|
|
|
options = {
|
2024-05-15 15:35:15 +00:00
|
|
|
|
certAuthority = lib.mkOption {
|
|
|
|
|
type = lib.types.bool;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = false;
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
This public key is an SSH certificate authority, rather than an
|
|
|
|
|
individual host's key.
|
|
|
|
|
'';
|
|
|
|
|
};
|
2024-05-15 15:35:15 +00:00
|
|
|
|
hostNames = lib.mkOption {
|
|
|
|
|
type = lib.types.listOf lib.types.str;
|
2022-01-22 01:22:15 +00:00
|
|
|
|
default = [ name ] ++ config.extraHostNames;
|
2024-05-15 15:35:15 +00:00
|
|
|
|
defaultText = lib.literalExpression "[ ${name} ] ++ config.${options.extraHostNames}";
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
A list of host names and/or IP numbers used for accessing
|
2022-04-15 01:41:22 +00:00
|
|
|
|
the host's ssh service. This list includes the name of the
|
2022-08-12 12:06:08 +00:00
|
|
|
|
containing `knownHosts` attribute by default
|
2022-04-15 01:41:22 +00:00
|
|
|
|
for convenience. If you wish to configure multiple host keys
|
2022-08-12 12:06:08 +00:00
|
|
|
|
for the same host use multiple `knownHosts`
|
2022-04-15 01:41:22 +00:00
|
|
|
|
entries with different attribute names and the same
|
2022-08-12 12:06:08 +00:00
|
|
|
|
`hostNames` list.
|
2020-04-24 23:36:52 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
2024-05-15 15:35:15 +00:00
|
|
|
|
extraHostNames = lib.mkOption {
|
|
|
|
|
type = lib.types.listOf lib.types.str;
|
2022-01-22 01:22:15 +00:00
|
|
|
|
default = [];
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2022-01-22 01:22:15 +00:00
|
|
|
|
A list of additional host names and/or IP numbers used for
|
2022-04-15 01:41:22 +00:00
|
|
|
|
accessing the host's ssh service. This list is ignored if
|
2022-08-12 12:06:08 +00:00
|
|
|
|
`hostNames` is set explicitly.
|
2022-01-22 01:22:15 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
2024-05-15 15:35:15 +00:00
|
|
|
|
publicKey = lib.mkOption {
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = null;
|
2024-05-15 15:35:15 +00:00
|
|
|
|
type = lib.types.nullOr lib.types.str;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
example = "ecdsa-sha2-nistp521 AAAAE2VjZHN...UEPg==";
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
The public key data for the host. You can fetch a public key
|
2022-08-12 12:06:08 +00:00
|
|
|
|
from a running SSH server with the {command}`ssh-keyscan`
|
2020-04-24 23:36:52 +00:00
|
|
|
|
command. The public key should not include any host names, only
|
|
|
|
|
the key type and the key itself.
|
|
|
|
|
'';
|
|
|
|
|
};
|
2024-05-15 15:35:15 +00:00
|
|
|
|
publicKeyFile = lib.mkOption {
|
2020-04-24 23:36:52 +00:00
|
|
|
|
default = null;
|
2024-05-15 15:35:15 +00:00
|
|
|
|
type = lib.types.nullOr lib.types.path;
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
The path to the public key file for the host. The public
|
|
|
|
|
key file is read at build time and saved in the Nix store.
|
|
|
|
|
You can fetch a public key file from a running SSH server
|
2022-08-12 12:06:08 +00:00
|
|
|
|
with the {command}`ssh-keyscan` command. The content
|
2020-04-24 23:36:52 +00:00
|
|
|
|
of the file should follow the same format as described for
|
2022-08-12 12:06:08 +00:00
|
|
|
|
the `publicKey` option. Only a single key
|
2022-01-13 20:06:32 +00:00
|
|
|
|
is supported. If a host has multiple keys, use
|
2022-08-12 12:06:08 +00:00
|
|
|
|
{option}`programs.ssh.knownHostsFiles` instead.
|
2020-04-24 23:36:52 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
}));
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2022-04-15 01:41:22 +00:00
|
|
|
|
The set of system-wide known SSH hosts. To make simple setups more
|
|
|
|
|
convenient the name of an attribute in this set is used as a host name
|
|
|
|
|
for the entry. This behaviour can be disabled by setting
|
2022-08-12 12:06:08 +00:00
|
|
|
|
`hostNames` explicitly. You can use
|
|
|
|
|
`extraHostNames` to add additional host names without
|
2022-04-15 01:41:22 +00:00
|
|
|
|
disabling this default.
|
2020-04-24 23:36:52 +00:00
|
|
|
|
'';
|
2024-05-15 15:35:15 +00:00
|
|
|
|
example = lib.literalExpression ''
|
2020-04-24 23:36:52 +00:00
|
|
|
|
{
|
|
|
|
|
myhost = {
|
2022-01-22 01:22:15 +00:00
|
|
|
|
extraHostNames = [ "myhost.mydomain.com" "10.10.1.4" ];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
publicKeyFile = ./pubkeys/myhost_ssh_host_dsa_key.pub;
|
|
|
|
|
};
|
2022-01-22 01:22:15 +00:00
|
|
|
|
"myhost2.net".publicKey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILIRuJ8p1Fi+m6WkHV0KWnRfpM1WxoW8XAS+XvsSKsTK";
|
2022-04-15 01:41:22 +00:00
|
|
|
|
"myhost2.net/dsa" = {
|
|
|
|
|
hostNames = [ "myhost2.net" ];
|
|
|
|
|
publicKeyFile = ./pubkeys/myhost2_ssh_host_dsa_key.pub;
|
|
|
|
|
};
|
2020-04-24 23:36:52 +00:00
|
|
|
|
}
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
knownHostsFiles = lib.mkOption {
|
2022-01-13 20:06:32 +00:00
|
|
|
|
default = [];
|
2024-05-15 15:35:15 +00:00
|
|
|
|
type = with lib.types; listOf path;
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2022-01-13 20:06:32 +00:00
|
|
|
|
Files containing SSH host keys to set as global known hosts.
|
2022-08-12 12:06:08 +00:00
|
|
|
|
`/etc/ssh/ssh_known_hosts` (which is
|
2023-04-29 16:46:19 +00:00
|
|
|
|
generated by {option}`programs.ssh.knownHosts`) is
|
|
|
|
|
always included.
|
2022-01-13 20:06:32 +00:00
|
|
|
|
'';
|
2024-05-15 15:35:15 +00:00
|
|
|
|
example = lib.literalExpression ''
|
2022-01-13 20:06:32 +00:00
|
|
|
|
[
|
|
|
|
|
./known_hosts
|
|
|
|
|
(writeText "github.keys" '''
|
2023-03-27 19:17:25 +00:00
|
|
|
|
github.com ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCj7ndNxQowgcQnjshcLrqPEiiphnt+VTTvDP6mHBL9j1aNUkY4Ue1gvwnGLVlOhGeYrnZaMgRK6+PKCUXaDbC7qtbW8gIkhL7aGCsOr/C56SJMy/BCZfxd1nWzAOxSDPgVsmerOBYfNqltV9/hWCqBywINIR+5dIg6JTJ72pcEpEjcYgXkE2YEFXV1JHnsKgbLWNlhScqb2UmyRkQyytRLtL+38TGxkxCflmO+5Z8CSSNY7GidjMIZ7Q4zMjA2n1nGrlTDkzwDCsw+wqFPGQA179cnfGWOWRVruj16z6XyvxvjJwbz0wQZ75XK5tKSb7FNyeIEs4TT4jk+S4dhPeAUC5y+bDYirYgM4GC7uEnztnZyaVWQ7B381AK4Qdrwt51ZqExKbQpTUNn+EjqoTwvqNj4kqx5QUCI0ThS/YkOxJCXmPUWZbhjpCg56i+2aB6CmK2JGhn57K5mj0MNdBXA4/WnwH6XoPWJzK5Nyu2zB3nAZp+S5hpQs+p1vN1/wsjk=
|
2022-01-13 20:06:32 +00:00
|
|
|
|
github.com ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBEmKSENjQEezOmxkZMy7opKgwFB9nkt5YRrYMjNuG5N87uRgg6CLrbo5wAdT/y6v0mKV0U2w0WZ2YB/++Tpockg=
|
|
|
|
|
github.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOMqqnkVzrm0SdG6UOoqKLsabgH5C9okWi0dh2l9GKJl
|
|
|
|
|
''')
|
|
|
|
|
]
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
kexAlgorithms = lib.mkOption {
|
|
|
|
|
type = lib.types.nullOr (lib.types.listOf lib.types.str);
|
2020-06-18 07:06:33 +00:00
|
|
|
|
default = null;
|
|
|
|
|
example = [ "curve25519-sha256@libssh.org" "diffie-hellman-group-exchange-sha256" ];
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-06-18 07:06:33 +00:00
|
|
|
|
Specifies the available KEX (Key Exchange) algorithms.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
ciphers = lib.mkOption {
|
|
|
|
|
type = lib.types.nullOr (lib.types.listOf lib.types.str);
|
2020-06-18 07:06:33 +00:00
|
|
|
|
default = null;
|
|
|
|
|
example = [ "chacha20-poly1305@openssh.com" "aes256-gcm@openssh.com" ];
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-06-18 07:06:33 +00:00
|
|
|
|
Specifies the ciphers allowed and their order of preference.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
macs = lib.mkOption {
|
|
|
|
|
type = lib.types.nullOr (lib.types.listOf lib.types.str);
|
2020-06-18 07:06:33 +00:00
|
|
|
|
default = null;
|
|
|
|
|
example = [ "hmac-sha2-512-etm@openssh.com" "hmac-sha1" ];
|
2024-04-21 15:54:59 +00:00
|
|
|
|
description = ''
|
2020-06-18 07:06:33 +00:00
|
|
|
|
Specifies the MAC (message authentication code) algorithms in order of preference. The MAC algorithm is used
|
|
|
|
|
for data integrity protection.
|
|
|
|
|
'';
|
|
|
|
|
};
|
2020-04-24 23:36:52 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
config = {
|
|
|
|
|
|
|
|
|
|
programs.ssh.setXAuthLocation =
|
2024-05-15 15:35:15 +00:00
|
|
|
|
lib.mkDefault (config.services.xserver.enable || config.programs.ssh.forwardX11 == true || config.services.openssh.settings.X11Forwarding);
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
|
|
assertions =
|
2024-01-02 11:29:13 +00:00
|
|
|
|
[ { assertion = cfg.forwardX11 == true -> cfg.setXAuthLocation;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
message = "cannot enable X11 forwarding without setting XAuth location";
|
|
|
|
|
}
|
2024-05-15 15:35:15 +00:00
|
|
|
|
] ++ lib.flip lib.mapAttrsToList cfg.knownHosts (name: data: {
|
2020-04-24 23:36:52 +00:00
|
|
|
|
assertion = (data.publicKey == null && data.publicKeyFile != null) ||
|
|
|
|
|
(data.publicKey != null && data.publicKeyFile == null);
|
|
|
|
|
message = "knownHost ${name} must contain either a publicKey or publicKeyFile";
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
# SSH configuration. Slight duplication of the sshd_config
|
|
|
|
|
# generation in the sshd service.
|
|
|
|
|
environment.etc."ssh/ssh_config".text =
|
|
|
|
|
''
|
|
|
|
|
# Custom options from `extraConfig`, to override generated options
|
|
|
|
|
${cfg.extraConfig}
|
|
|
|
|
|
|
|
|
|
# Generated options from other settings
|
|
|
|
|
Host *
|
2024-05-15 15:35:15 +00:00
|
|
|
|
GlobalKnownHostsFile ${builtins.concatStringsSep " " knownHostsFiles}
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
2024-07-27 06:49:29 +00:00
|
|
|
|
${lib.optionalString (!config.networking.enableIPv6) "AddressFamily inet"}
|
2024-05-15 15:35:15 +00:00
|
|
|
|
${lib.optionalString cfg.setXAuthLocation "XAuthLocation ${pkgs.xorg.xauth}/bin/xauth"}
|
2024-01-02 11:29:13 +00:00
|
|
|
|
${lib.optionalString (cfg.forwardX11 != null) "ForwardX11 ${if cfg.forwardX11 then "yes" else "no"}"}
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
${lib.optionalString (cfg.pubkeyAcceptedKeyTypes != []) "PubkeyAcceptedKeyTypes ${builtins.concatStringsSep "," cfg.pubkeyAcceptedKeyTypes}"}
|
|
|
|
|
${lib.optionalString (cfg.hostKeyAlgorithms != []) "HostKeyAlgorithms ${builtins.concatStringsSep "," cfg.hostKeyAlgorithms}"}
|
|
|
|
|
${lib.optionalString (cfg.kexAlgorithms != null) "KexAlgorithms ${builtins.concatStringsSep "," cfg.kexAlgorithms}"}
|
|
|
|
|
${lib.optionalString (cfg.ciphers != null) "Ciphers ${builtins.concatStringsSep "," cfg.ciphers}"}
|
|
|
|
|
${lib.optionalString (cfg.macs != null) "MACs ${builtins.concatStringsSep "," cfg.macs}"}
|
2020-04-24 23:36:52 +00:00
|
|
|
|
'';
|
|
|
|
|
|
|
|
|
|
environment.etc."ssh/ssh_known_hosts".text = knownHostsText;
|
|
|
|
|
|
|
|
|
|
# FIXME: this should really be socket-activated for über-awesomeness.
|
2024-05-15 15:35:15 +00:00
|
|
|
|
systemd.user.services.ssh-agent = lib.mkIf cfg.startAgent
|
2020-04-24 23:36:52 +00:00
|
|
|
|
{ description = "SSH Agent";
|
|
|
|
|
wantedBy = [ "default.target" ];
|
|
|
|
|
unitConfig.ConditionUser = "!@system";
|
|
|
|
|
serviceConfig =
|
|
|
|
|
{ ExecStartPre = "${pkgs.coreutils}/bin/rm -f %t/ssh-agent";
|
|
|
|
|
ExecStart =
|
|
|
|
|
"${cfg.package}/bin/ssh-agent " +
|
2024-05-15 15:35:15 +00:00
|
|
|
|
lib.optionalString (cfg.agentTimeout != null) ("-t ${cfg.agentTimeout} ") +
|
|
|
|
|
lib.optionalString (cfg.agentPKCS11Whitelist != null) ("-P ${cfg.agentPKCS11Whitelist} ") +
|
2020-04-24 23:36:52 +00:00
|
|
|
|
"-a %t/ssh-agent";
|
|
|
|
|
StandardOutput = "null";
|
|
|
|
|
Type = "forking";
|
|
|
|
|
Restart = "on-failure";
|
|
|
|
|
SuccessExitStatus = "0 2";
|
|
|
|
|
};
|
|
|
|
|
# Allow ssh-agent to ask for confirmation. This requires the
|
|
|
|
|
# unit to know about the user's $DISPLAY (via ‘systemctl
|
|
|
|
|
# import-environment’).
|
2024-05-15 15:35:15 +00:00
|
|
|
|
environment.SSH_ASKPASS = lib.optionalString cfg.enableAskPassword askPasswordWrapper;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
environment.DISPLAY = "fake"; # required to make ssh-agent start $SSH_ASKPASS
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
environment.extraInit = lib.optionalString cfg.startAgent
|
2020-04-24 23:36:52 +00:00
|
|
|
|
''
|
|
|
|
|
if [ -z "$SSH_AUTH_SOCK" -a -n "$XDG_RUNTIME_DIR" ]; then
|
|
|
|
|
export SSH_AUTH_SOCK="$XDG_RUNTIME_DIR/ssh-agent"
|
|
|
|
|
fi
|
|
|
|
|
'';
|
|
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
|
environment.variables.SSH_ASKPASS = lib.optionalString cfg.enableAskPassword cfg.askPassword;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
}
|