summaryrefslogtreecommitdiff
path: root/lib/chef
diff options
context:
space:
mode:
authorBryan McLellan <btm@loftninjas.org>2019-05-13 18:00:07 -0400
committerGitHub <noreply@github.com>2019-05-13 18:00:07 -0400
commit0924dfcd96ab9281f3b2eef73b48475a8ed190eb (patch)
treeed5b338f5b6b16912571a26280d804a6699857f9 /lib/chef
parent3287fb0805ee519bf5bf3d52e268518faa3401d6 (diff)
parent218bd7f031e8820d2e0a7a7bc6fcc3c16df99c60 (diff)
downloadchef-0924dfcd96ab9281f3b2eef73b48475a8ed190eb.tar.gz
Merge pull request #8521 from MsysTechnologiesllc/VSingh/bootstrap-session-timeout
Chef 15: Add --session-timeout bootstrap option for both ssh & winrm
Diffstat (limited to 'lib/chef')
-rw-r--r--lib/chef/knife/bootstrap.rb35
1 files changed, 29 insertions, 6 deletions
diff --git a/lib/chef/knife/bootstrap.rb b/lib/chef/knife/bootstrap.rb
index 04eabc3c83..477074fe49 100644
--- a/lib/chef/knife/bootstrap.rb
+++ b/lib/chef/knife/bootstrap.rb
@@ -58,6 +58,12 @@ class Chef
long: "--max-wait SECONDS",
description: "The maximum time to wait for the initial connection to be established."
+ option :session_timeout,
+ long: "--session-timeout SECONDS",
+ description: "The number of seconds to wait for each connection operation to be acknowledged while running bootstrap.",
+ proc: Proc.new { |protocol| Chef::Config[:knife][:session_timeout] = protocol },
+ default: 60
+
# WinRM Authentication
option :winrm_ssl_peer_fingerprint,
long: "--winrm-ssl-peer-fingerprint FINGERPRINT",
@@ -109,11 +115,6 @@ class Chef
description: "The Kerberos service used for authentication.",
proc: Proc.new { |protocol| Chef::Config[:knife][:kerberos_service] = protocol }
- option :winrm_session_timeout,
- long: "--winrm-session-timeout SECONDS",
- description: "The number of seconds to wait for each WinRM operation to be acknowledged while running bootstrap.",
- proc: Proc.new { |protocol| Chef::Config[:knife][:winrm_session_timeout] = protocol }
-
## SSH Authentication
option :ssh_gateway,
short: "-G GATEWAY",
@@ -373,6 +374,8 @@ class Chef
[:connection_port, "--winrm-port"],
winrm_authentication_protocol:
[:winrm_auth_method, "--winrm-authentication-protocol PROTOCOL"],
+ winrm_session_timeout:
+ [:session_timeout, "--winrm-session-timeout MINUTES"],
}.freeze
DEPRECATED_FLAGS.each do |deprecated_key, deprecation_entry|
@@ -538,6 +541,7 @@ class Chef
validate_policy_options!
winrm_warn_no_ssl_verification
+ warn_on_short_session_timeout
$stdout.sync = true
register_client
@@ -760,6 +764,24 @@ class Chef
true
end
+ # If session_timeout is too short, it is likely
+ # a holdover from "--winrm-session-timeout" which used
+ # minutes as its unit, instead of seconds.
+ # Warn the human so that they are not surprised.
+ #
+ # This will also erroneously warn if a string value is given,
+ # but argument type validation is something that needs addressing
+ # more broadly.
+ def warn_on_short_session_timeout
+ timeout = config_value(:session_timeout).to_i
+ if timeout <= 15
+ ui.warn <<~EOM
+ --session-timeout is set to #{config[:session_timeout]} minutes.
+ Did you mean "--session-timeout #{config[:session_timeout] * 60}" seconds?
+ EOM
+ end
+ end
+
def winrm_warn_no_ssl_verification
return unless winrm?
@@ -846,6 +868,7 @@ class Chef
return opts if winrm?
opts[:non_interactive] = true # Prevent password prompts from underlying net/ssh
opts[:forward_agent] = (config_value(:ssh_forward_agent) === true)
+ opts[:connection_timeout] = config_value(:session_timeout).to_i
opts
end
@@ -944,7 +967,7 @@ class Chef
opts[:ca_trust_file] = config_value(:ca_trust_file)
end
- opts[:operation_timeout] = config_value(:winrm_session_timeout) || 60
+ opts[:operation_timeout] = config_value(:session_timeout).to_i
opts
end