2015-10-07 11:04:40 +00:00
|
|
|
# encoding: utf-8
|
|
|
|
# copyright: 2015, Vulcano Security GmbH
|
|
|
|
# author: Christoph Hartmann
|
|
|
|
# author: Dominik Richter
|
|
|
|
# license: All rights reserved
|
|
|
|
|
2016-03-08 18:06:55 +00:00
|
|
|
module Inspec::Resources
|
2016-03-18 11:29:36 +00:00
|
|
|
class PowershellScript < Cmd
|
|
|
|
name 'powershell'
|
|
|
|
desc 'Use the powershell InSpec audit resource to test a Windows PowerShell script on the Microsoft Windows platform.'
|
2016-03-08 18:06:55 +00:00
|
|
|
example "
|
|
|
|
script = <<-EOH
|
|
|
|
# you powershell script
|
|
|
|
EOH
|
2015-11-27 13:02:38 +00:00
|
|
|
|
2016-03-18 11:29:36 +00:00
|
|
|
describe powershell(script) do
|
2016-03-08 18:06:55 +00:00
|
|
|
its('matcher') { should eq 'output' }
|
|
|
|
end
|
|
|
|
"
|
2015-10-07 11:13:37 +00:00
|
|
|
|
2016-03-08 18:06:55 +00:00
|
|
|
def initialize(script)
|
|
|
|
unless inspec.os.windows?
|
|
|
|
return skip_resource 'The `script` resource is not supported on your OS yet.'
|
|
|
|
end
|
2016-02-09 10:04:50 +00:00
|
|
|
|
2016-03-08 18:06:55 +00:00
|
|
|
# encodes a script as base64 to run as powershell encodedCommand
|
|
|
|
# this comes with performance issues: @see https://gist.github.com/fnichol/7b20596b950e65fb96f9
|
|
|
|
require 'winrm'
|
|
|
|
script = WinRM::PowershellScript.new(script)
|
|
|
|
cmd = "powershell -encodedCommand #{script.encoded}"
|
|
|
|
super(cmd)
|
|
|
|
end
|
2015-10-07 11:04:40 +00:00
|
|
|
|
2016-03-08 18:06:55 +00:00
|
|
|
# we cannot determine if a command exists, because that does not work for scripts
|
|
|
|
def exist?
|
|
|
|
nil
|
|
|
|
end
|
2015-10-12 11:01:58 +00:00
|
|
|
|
2016-03-26 21:25:53 +00:00
|
|
|
# Removes leading and trailing whitespace from stdout
|
|
|
|
def strip
|
|
|
|
result.stdout.strip unless result.stdout.nil?
|
|
|
|
end
|
|
|
|
|
2016-03-08 18:06:55 +00:00
|
|
|
def to_s
|
2016-03-18 11:29:36 +00:00
|
|
|
'Powershell'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# this is deprecated syntax and will be removed in future versions
|
|
|
|
class LegacyPowershellScript < PowershellScript
|
|
|
|
name 'script'
|
|
|
|
|
|
|
|
def initialize(script)
|
|
|
|
deprecated
|
|
|
|
super(script)
|
|
|
|
end
|
|
|
|
|
|
|
|
def deprecated
|
|
|
|
warn '[DEPRECATION] `script(script)` is deprecated. Please use `powershell(script)` instead.'
|
2016-03-08 18:06:55 +00:00
|
|
|
end
|
2015-10-12 11:01:58 +00:00
|
|
|
end
|
2015-10-07 11:04:40 +00:00
|
|
|
end
|