train-vsphere
is a Train plugin and is used as a Train Transport to connect to vsphere environments.
You will need InSpec v3.9 or later. Note that while it will probably run on earlier releases this is what i built it on.
Simply run:
$ inspec plugin install train-vsphere
Connect to the vsphere target as such:
inspec shell -t vsphere://vcenter.host.name --user 'username@sso.domain' --password 'supersecret' --insecure boolean
or
inspec exec -t vsphere://vcenter.host.name --user 'username@sso.domain' --password 'supersecret' --insecure boolean
Alternatively you can set all these as environment variables using the following variables and authenticate without the parameters in in the inspec command or the target
export VC_HOSTNAME='vcenter.host.name'
export VC_USERNAME='username@sso.domain'
export VC_PASSWORD='notVMware1!'
inspec exec -t vsphere://
When connected, you can consume vsphere in the following ways:
#This retrieves the class of name class
@api_client = inspec.backend.api_client(class)
#For example, the following will return the Console CLI status
@api_client = inspec.backend.api_client(VSphereAutomation::Appliance::AccessConsolecliApi)
status = @api_client.get.status
#Or directly
@status = inspec.backend.api_client(VSphereAutomation::Appliance::AccessConsolecliApi).get.status
#You can also use the rbvomi libraries by calling a method.
@vsphere_client = inspec.backend.vsphere_client(method)
#for example, the following will return the root folder which can then be consumed to find other objects such as VMs and hosts.
@dc = inspec.backend.vsphere_client('rootFolder').childEntity.grep(RbVmomi::VIM::Datacenter).find { |x| x.name == 'mydatacenter' }
@vm = dc.vmFolder.childEntity.grep(RbVmomi::VIM::VirtualMachine).find { |x| x.name == 'my_vm' }
An example of a resource
class Vcsa < Inspec.resource(1)
name 'vcsa'
supports platform: 'vsphere'
desc 'Use the vsphere audit resource to get information from the vSphere API'
def ssh
begin
return inspec.backend.api_client(VSphereAutomation::Appliance::AccessConsolecliApi).get.value
rescue VSphereAutomation::ApiError => e
fail Train::ClientError
end
end
def exists?
return true
end
def authenticate
end
end
And the matching control
control 'vcenter-appliance-VCSA-001-1' do # A unique ID for this control
impact 0.7 # The criticality, if this control fails.
title 'SSH should be disabled' # A human-readable title
desc 'SSH should be disabled by default'
# tag 'security'
# tag check: 'VCSA-001-1'
# ref 'https://docs.vmware.com/en/VMware-vSphere/6.7/com.vmware.vsphere.vcsa.doc/GUID-D58532F7-E48C-4BF2-87F9-99BA89BF659A.html'
describe vcsa do
it { should exist }
its('ssh') {should cmp 'false'}
end
end
Due to some unknown bug, libcurl4-gnutls-dev may be required on linux. I haven't tested this on various distributions yet. MacOS should work out of the box, but YMMV.
- Fork it
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -sam 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create new Pull Request against the development branch
| Author: | Sjors Robroek
| Copyright: | Copyright (c) 2019
| License: | Apache License, Version 2.0
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.