mirror of
https://github.com/inspec/inspec
synced 2025-01-04 09:18:59 +00:00
54 lines
1.4 KiB
Ruby
54 lines
1.4 KiB
Ruby
|
# encoding: utf-8
|
||
|
|
||
|
class Vulcano::Backends::SpecinfraHelper
|
||
|
module Ssh
|
||
|
def self.validate_options(ssh_opts)
|
||
|
unless ssh_opts[:port] > 0
|
||
|
fail "Port must be > 0 (not #{ssh_opts[:port]})"
|
||
|
end
|
||
|
|
||
|
if ssh_opts[:user].to_s.empty?
|
||
|
fail 'User must not be empty.'
|
||
|
end
|
||
|
|
||
|
unless ssh_opts[:keys].empty?
|
||
|
ssh_opts[:auth_methods].push('publickey')
|
||
|
ssh_opts[:keys_only] = true if ssh_opts[:password].nil?
|
||
|
end
|
||
|
|
||
|
unless ssh_opts[:password].nil?
|
||
|
ssh_opts[:auth_methods].push('password')
|
||
|
end
|
||
|
|
||
|
if ssh_opts[:keys].empty? and ssh_opts[:password].nil?
|
||
|
fail 'You must configure at least one authentication method' \
|
||
|
': Password or key.'
|
||
|
end
|
||
|
end
|
||
|
|
||
|
def self.configure(conf)
|
||
|
si = Specinfra.configuration
|
||
|
si.backend = :ssh
|
||
|
si.request_pty = true
|
||
|
|
||
|
host = conf['host'].to_s
|
||
|
fail 'You must configure a target host.' if host.empty?
|
||
|
si.host = host
|
||
|
|
||
|
ssh_opts = {
|
||
|
port: conf['port'] || 22,
|
||
|
auth_methods: ['none'],
|
||
|
user_known_hosts_file: '/dev/null',
|
||
|
global_known_hosts_file: '/dev/null',
|
||
|
number_of_password_prompts: 0,
|
||
|
user: conf['user'] || 'root',
|
||
|
password: conf['password'],
|
||
|
keys: [conf['key_file']].compact,
|
||
|
}
|
||
|
|
||
|
validate_options(ssh_opts)
|
||
|
si.ssh_options = ssh_opts
|
||
|
end
|
||
|
end
|
||
|
end
|