diff options
Diffstat (limited to 'lib/oxidized/input/ssh.rb')
| -rw-r--r-- | lib/oxidized/input/ssh.rb | 39 | 
1 files changed, 24 insertions, 15 deletions
| diff --git a/lib/oxidized/input/ssh.rb b/lib/oxidized/input/ssh.rb index 9a5c508..6e86d13 100644 --- a/lib/oxidized/input/ssh.rb +++ b/lib/oxidized/input/ssh.rb @@ -24,17 +24,27 @@ module Oxidized        secure = Oxidized.config.input.ssh.secure        @log = File.open(Oxidized::Config::Log + "/#{@node.ip}-ssh", 'w') if Oxidized.config.input.debug?        port = vars(:ssh_port) || 22 -      if proxy_host = vars(:ssh_proxy) -        proxy =  Net::SSH::Proxy::Command.new("ssh #{proxy_host} -W %h:%p") -      end +        ssh_opts = { -        :port => port.to_i, -        :password => @node.auth[:password], :timeout => Oxidized.config.timeout, -        :paranoid => secure, -        :auth_methods => %w(none publickey password keyboard-interactive), -        :number_of_password_prompts => 0, -        :proxy => proxy, +        port:         port.to_i, +        paranoid:     secure, +        keepalive:    true, +        password:     @node.auth[:password], :timeout => Oxidized.config.timeout, +        number_of_password_prompts: 0,        } + +      auth_methods = vars(:auth_methods) || %w(none publickey password) +      ssh_opts[:auth_methods] = auth_methods +      Oxidized.logger.info "AUTH METHODS::#{auth_methods}" + +      if proxy_host = vars(:ssh_proxy) +        proxy_command =  "ssh " +        proxy_command += "-o StrictHostKeyChecking=no " unless secure +        proxy_command += "#{proxy_host} -W %h:%p" +        proxy = Net::SSH::Proxy::Command.new(proxy_command) +        ssh_opts[:proxy] = proxy +      end +        ssh_opts[:keys] = vars(:ssh_keys).is_a?(Array) ? vars(:ssh_keys) : [vars(:ssh_keys)] if vars(:ssh_keys)        ssh_opts[:kex]  = vars(:ssh_kex).split(/,\s*/) if vars(:ssh_kex)        ssh_opts[:encryption] = vars(:ssh_encryption).split(/,\s*/) if vars(:ssh_encryption) @@ -46,7 +56,7 @@ module Oxidized          begin            login          rescue Timeout::Error -          raise PromptUndetect, [ @output, 'not matching configured prompt', @node.prompt ].join(' ') +          raise PromptUndetect, [@output, 'not matching configured prompt', @node.prompt].join(' ')          end        end        connected? @@ -56,7 +66,7 @@ module Oxidized        @ssh and not @ssh.closed?      end -    def cmd cmd, expect=node.prompt +    def cmd cmd, expect = node.prompt        Oxidized.logger.debug "lib/oxidized/input/ssh.rb #{cmd} @ #{node.name} with expect: #{expect.inspect}"        if @exec          @ssh.exec! cmd @@ -94,7 +104,7 @@ module Oxidized          ch.on_data do |_ch, data|            if Oxidized.config.input.debug?              @log.print data -            @log.fsync +            @log.flush            end            @output << data            @output = @node.model.expects @output @@ -122,8 +132,8 @@ module Oxidized        end      end -    def exec state=nil -      state == nil ? @exec : (@exec=state) unless vars :ssh_no_exec +    def exec state = nil +      state == nil ? @exec : (@exec = state) unless vars :ssh_no_exec      end      def cmd_shell(cmd, expect_re) @@ -146,6 +156,5 @@ module Oxidized          end        end      end -    end  end | 
