ssh: move options to end of configuration file
This is needed to support overriding these options inside match blocks. A new option `programs.ssh.extraOptionOverrides` has been added to allow global overrides.
This commit is contained in:
parent
75c4075345
commit
4205c91609
2 changed files with 42 additions and 11 deletions
|
@ -587,6 +587,24 @@ in
|
||||||
A new module is available: 'programs.fzf'.
|
A new module is available: 'programs.fzf'.
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
time = "2018-03-25T06:49:57+00:00";
|
||||||
|
condition = with config.programs.ssh; enable && matchBlocks != {};
|
||||||
|
message = ''
|
||||||
|
Options set through the 'programs.ssh' module are now placed
|
||||||
|
at the end of the SSH configuration file. This was done to
|
||||||
|
make it possible to override global options such as
|
||||||
|
'ForwardAgent' or 'Compression' inside a host match block.
|
||||||
|
|
||||||
|
If you truly need to override an SSH option across all match
|
||||||
|
blocks then the new option
|
||||||
|
|
||||||
|
programs.ssh.extraOptionOverrides
|
||||||
|
|
||||||
|
can be used.
|
||||||
|
'';
|
||||||
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -220,9 +220,18 @@ in
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
extraOptionOverrides = mkOption {
|
||||||
|
type = types.attrsOf types.str;
|
||||||
|
default = {};
|
||||||
|
description = ''
|
||||||
|
Extra SSH configuration options that take precedence over any
|
||||||
|
host specific configuration.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
matchBlocks = mkOption {
|
matchBlocks = mkOption {
|
||||||
type = types.loaOf matchBlockModule;
|
type = types.loaOf matchBlockModule;
|
||||||
default = [];
|
default = {};
|
||||||
example = literalExample ''
|
example = literalExample ''
|
||||||
{
|
{
|
||||||
"john.example.com" = {
|
"john.example.com" = {
|
||||||
|
@ -248,6 +257,14 @@ in
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
home.file.".ssh/config".text = ''
|
home.file.".ssh/config".text = ''
|
||||||
|
${concatStringsSep "\n" (
|
||||||
|
mapAttrsToList (n: v: "${n} ${v}") cfg.extraOptionOverrides)}
|
||||||
|
|
||||||
|
${concatStringsSep "\n\n" (
|
||||||
|
map matchBlockStr (
|
||||||
|
builtins.attrValues cfg.matchBlocks))}
|
||||||
|
|
||||||
|
Host *
|
||||||
ForwardAgent ${yn cfg.forwardAgent}
|
ForwardAgent ${yn cfg.forwardAgent}
|
||||||
Compression ${yn cfg.compression}
|
Compression ${yn cfg.compression}
|
||||||
ServerAliveInterval ${toString cfg.serverAliveInterval}
|
ServerAliveInterval ${toString cfg.serverAliveInterval}
|
||||||
|
@ -257,11 +274,7 @@ in
|
||||||
ControlPath ${cfg.controlPath}
|
ControlPath ${cfg.controlPath}
|
||||||
ControlPersist ${cfg.controlPersist}
|
ControlPersist ${cfg.controlPersist}
|
||||||
|
|
||||||
${cfg.extraConfig}
|
${replaceStrings ["\n"] ["\n "] cfg.extraConfig}
|
||||||
|
|
||||||
${concatStringsSep "\n\n" (
|
|
||||||
map matchBlockStr (
|
|
||||||
builtins.attrValues cfg.matchBlocks))}
|
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue