diff options
author | Richard Kettlewell <rjk@greenend.org.uk> | 2014-02-09 16:09:52 +0000 |
---|---|---|
committer | Colin Watson <cjwatson@debian.org> | 2014-02-09 16:17:41 +0000 |
commit | affb41e3cf23b79a3d165ae0d97689a46a965b6f (patch) | |
tree | 337885e65ffaaed7fec83af52dafb6c92f198954 /readconf.c | |
parent | 4c7ed5c80e5f67277620ac973317cc516b67d0e7 (diff) |
Various keepalive extensions
Add compatibility aliases for ProtocolKeepAlives and SetupTimeOut, supported
in previous versions of Debian's OpenSSH package but since superseded by
ServerAliveInterval. (We're probably stuck with this bit for
compatibility.)
In batch mode, default ServerAliveInterval to five minutes.
Adjust documentation to match and to give some more advice on use of
keepalives.
Author: Ian Jackson <ian@chiark.greenend.org.uk>
Author: Matthew Vernon <matthew@debian.org>
Author: Colin Watson <cjwatson@debian.org>
Last-Update: 2013-09-14
Patch-Name: keepalive-extensions.patch
Diffstat (limited to 'readconf.c')
-rw-r--r-- | readconf.c | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/readconf.c b/readconf.c index 22e5a3a61..2dcbf3187 100644 --- a/readconf.c +++ b/readconf.c | |||
@@ -141,6 +141,7 @@ typedef enum { | |||
141 | oTunnel, oTunnelDevice, oLocalCommand, oPermitLocalCommand, | 141 | oTunnel, oTunnelDevice, oLocalCommand, oPermitLocalCommand, |
142 | oVisualHostKey, oUseRoaming, oZeroKnowledgePasswordAuthentication, | 142 | oVisualHostKey, oUseRoaming, oZeroKnowledgePasswordAuthentication, |
143 | oKexAlgorithms, oIPQoS, oRequestTTY, oIgnoreUnknown, | 143 | oKexAlgorithms, oIPQoS, oRequestTTY, oIgnoreUnknown, |
144 | oProtocolKeepAlives, oSetupTimeOut, | ||
144 | oIgnoredUnknownOption, oDeprecated, oUnsupported | 145 | oIgnoredUnknownOption, oDeprecated, oUnsupported |
145 | } OpCodes; | 146 | } OpCodes; |
146 | 147 | ||
@@ -263,6 +264,8 @@ static struct { | |||
263 | { "ipqos", oIPQoS }, | 264 | { "ipqos", oIPQoS }, |
264 | { "requesttty", oRequestTTY }, | 265 | { "requesttty", oRequestTTY }, |
265 | { "ignoreunknown", oIgnoreUnknown }, | 266 | { "ignoreunknown", oIgnoreUnknown }, |
267 | { "protocolkeepalives", oProtocolKeepAlives }, | ||
268 | { "setuptimeout", oSetupTimeOut }, | ||
266 | 269 | ||
267 | { NULL, oBadOption } | 270 | { NULL, oBadOption } |
268 | }; | 271 | }; |
@@ -939,6 +942,8 @@ parse_int: | |||
939 | goto parse_flag; | 942 | goto parse_flag; |
940 | 943 | ||
941 | case oServerAliveInterval: | 944 | case oServerAliveInterval: |
945 | case oProtocolKeepAlives: /* Debian-specific compatibility alias */ | ||
946 | case oSetupTimeOut: /* Debian-specific compatibility alias */ | ||
942 | intptr = &options->server_alive_interval; | 947 | intptr = &options->server_alive_interval; |
943 | goto parse_time; | 948 | goto parse_time; |
944 | 949 | ||
@@ -1404,8 +1409,13 @@ fill_default_options(Options * options) | |||
1404 | options->rekey_interval = 0; | 1409 | options->rekey_interval = 0; |
1405 | if (options->verify_host_key_dns == -1) | 1410 | if (options->verify_host_key_dns == -1) |
1406 | options->verify_host_key_dns = 0; | 1411 | options->verify_host_key_dns = 0; |
1407 | if (options->server_alive_interval == -1) | 1412 | if (options->server_alive_interval == -1) { |
1408 | options->server_alive_interval = 0; | 1413 | /* in batch mode, default is 5mins */ |
1414 | if (options->batch_mode == 1) | ||
1415 | options->server_alive_interval = 300; | ||
1416 | else | ||
1417 | options->server_alive_interval = 0; | ||
1418 | } | ||
1409 | if (options->server_alive_count_max == -1) | 1419 | if (options->server_alive_count_max == -1) |
1410 | options->server_alive_count_max = 3; | 1420 | options->server_alive_count_max = 3; |
1411 | if (options->control_master == -1) | 1421 | if (options->control_master == -1) |