# encoding: utf-8 # copyright: 2015, Vulcano Security GmbH # author: Christoph Hartmann # author: Dominik Richter # license: All rights reserved module Inspec::Resources class PowershellScript < Cmd name 'powershell' desc 'Use the powershell InSpec audit resource to test a Windows PowerShell script on the Microsoft Windows platform.' example " script = <<-EOH # you powershell script EOH describe powershell(script) do its('matcher') { should eq 'output' } end " def initialize(script) unless inspec.os.windows? return skip_resource 'The `script` resource is not supported on your OS yet.' end # 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 # we cannot determine if a command exists, because that does not work for scripts def exist? nil end # Removes leading and trailing whitespace from stdout def strip result.stdout.strip unless result.stdout.nil? end def to_s '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.' end end end