Added execution_time_limit for WinRM.
Adds a configurable value for WinRm and the elevated permission shell ExecutionTimeLimit. Please see mitchellh/vagrant#5506 Ex: config.winrm.execution_time_limit = "P1D"
This commit is contained in:
parent
f3b31c8c9c
commit
18d229ca82
|
@ -210,7 +210,8 @@ module VagrantPlugins
|
||||||
|
|
||||||
"powershell -executionpolicy bypass -file \"#{guest_script_path}\" " +
|
"powershell -executionpolicy bypass -file \"#{guest_script_path}\" " +
|
||||||
"-username \"#{shell.username}\" -password \"#{shell.password}\" " +
|
"-username \"#{shell.username}\" -password \"#{shell.password}\" " +
|
||||||
"-encoded_command \"#{wrapped_encoded_command}\""
|
"-encoded_command \"#{wrapped_encoded_command}\" " +
|
||||||
|
"-execution_time_limit \"#{shell.execution_time_limit}\""
|
||||||
end
|
end
|
||||||
|
|
||||||
# Handles the raw WinRM shell result and converts it to a
|
# Handles the raw WinRM shell result and converts it to a
|
||||||
|
|
|
@ -11,6 +11,7 @@ module VagrantPlugins
|
||||||
attr_accessor :timeout
|
attr_accessor :timeout
|
||||||
attr_accessor :transport
|
attr_accessor :transport
|
||||||
attr_accessor :ssl_peer_verification
|
attr_accessor :ssl_peer_verification
|
||||||
|
attr_accessor :execution_time_limit
|
||||||
|
|
||||||
def initialize
|
def initialize
|
||||||
@username = UNSET_VALUE
|
@username = UNSET_VALUE
|
||||||
|
@ -23,6 +24,7 @@ module VagrantPlugins
|
||||||
@timeout = UNSET_VALUE
|
@timeout = UNSET_VALUE
|
||||||
@transport = UNSET_VALUE
|
@transport = UNSET_VALUE
|
||||||
@ssl_peer_verification = UNSET_VALUE
|
@ssl_peer_verification = UNSET_VALUE
|
||||||
|
@execution_time_limit = UNSET_VALUE
|
||||||
end
|
end
|
||||||
|
|
||||||
def finalize!
|
def finalize!
|
||||||
|
@ -37,6 +39,7 @@ module VagrantPlugins
|
||||||
@retry_delay = 2 if @retry_delay == UNSET_VALUE
|
@retry_delay = 2 if @retry_delay == UNSET_VALUE
|
||||||
@timeout = 1800 if @timeout == UNSET_VALUE
|
@timeout = 1800 if @timeout == UNSET_VALUE
|
||||||
@ssl_peer_verification = true if @ssl_peer_verification == UNSET_VALUE
|
@ssl_peer_verification = true if @ssl_peer_verification == UNSET_VALUE
|
||||||
|
@execution_time_limit = "PT2H" if @execution_time_limit == UNSET_VALUE
|
||||||
end
|
end
|
||||||
|
|
||||||
def validate(machine)
|
def validate(machine)
|
||||||
|
@ -49,6 +52,7 @@ module VagrantPlugins
|
||||||
errors << "winrm.max_tries cannot be nil." if @max_tries.nil?
|
errors << "winrm.max_tries cannot be nil." if @max_tries.nil?
|
||||||
errors << "winrm.retry_delay cannot be nil." if @max_tries.nil?
|
errors << "winrm.retry_delay cannot be nil." if @max_tries.nil?
|
||||||
errors << "winrm.timeout cannot be nil." if @timeout.nil?
|
errors << "winrm.timeout cannot be nil." if @timeout.nil?
|
||||||
|
errors << "winrm.execution_time_limit cannot be nil." if @execution_time_limit.nil?
|
||||||
unless @ssl_peer_verification == true || @ssl_peer_verification == false
|
unless @ssl_peer_verification == true || @ssl_peer_verification == false
|
||||||
errors << "winrm.ssl_peer_verification must be a boolean."
|
errors << "winrm.ssl_peer_verification must be a boolean."
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
param([String]$username, [String]$password, [String]$encoded_command)
|
param([String]$username, [String]$password, [String]$encoded_command, [String]$execution_time_limit)
|
||||||
|
|
||||||
$task_name = "WinRM_Elevated_Shell"
|
$task_name = "WinRM_Elevated_Shell"
|
||||||
$out_file = "$env:SystemRoot\Temp\WinRM_Elevated_Shell.log"
|
$out_file = "$env:SystemRoot\Temp\WinRM_Elevated_Shell.log"
|
||||||
|
@ -33,7 +33,7 @@ $task_xml = @'
|
||||||
<Hidden>false</Hidden>
|
<Hidden>false</Hidden>
|
||||||
<RunOnlyIfIdle>false</RunOnlyIfIdle>
|
<RunOnlyIfIdle>false</RunOnlyIfIdle>
|
||||||
<WakeToRun>false</WakeToRun>
|
<WakeToRun>false</WakeToRun>
|
||||||
<ExecutionTimeLimit>PT2H</ExecutionTimeLimit>
|
<ExecutionTimeLimit>{execution_time_limit}</ExecutionTimeLimit>
|
||||||
<Priority>4</Priority>
|
<Priority>4</Priority>
|
||||||
</Settings>
|
</Settings>
|
||||||
<Actions Context="Author">
|
<Actions Context="Author">
|
||||||
|
@ -49,6 +49,7 @@ $arguments = "/c powershell.exe -EncodedCommand $encoded_command > $out_file
|
||||||
|
|
||||||
$task_xml = $task_xml.Replace("{arguments}", $arguments)
|
$task_xml = $task_xml.Replace("{arguments}", $arguments)
|
||||||
$task_xml = $task_xml.Replace("{username}", $username)
|
$task_xml = $task_xml.Replace("{username}", $username)
|
||||||
|
$task_xml = $task_xml.Replace("{execution_time_limit}", $execution_time_limit)
|
||||||
|
|
||||||
$schedule = New-Object -ComObject "Schedule.Service"
|
$schedule = New-Object -ComObject "Schedule.Service"
|
||||||
$schedule.Connect()
|
$schedule.Connect()
|
||||||
|
|
|
@ -37,6 +37,7 @@ module VagrantPlugins
|
||||||
attr_reader :port
|
attr_reader :port
|
||||||
attr_reader :username
|
attr_reader :username
|
||||||
attr_reader :password
|
attr_reader :password
|
||||||
|
attr_reader :execution_time_limit
|
||||||
attr_reader :config
|
attr_reader :config
|
||||||
|
|
||||||
def initialize(host, port, config)
|
def initialize(host, port, config)
|
||||||
|
@ -47,6 +48,7 @@ module VagrantPlugins
|
||||||
@port = port
|
@port = port
|
||||||
@username = config.username
|
@username = config.username
|
||||||
@password = config.password
|
@password = config.password
|
||||||
|
@execution_time_limit = config.execution_time_limit
|
||||||
@config = config
|
@config = config
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue