Module: Loom::RunnerModule::SSHKitConnector
- Included in:
- Loom::Runner
- Defined in:
- lib/loom/runner/sshkit_connector.rb
Defined Under Namespace
Classes: SSHKitDSLShadow
Constant Summary collapse
Instance Method Summary collapse
-
#on_host(host_specs, &run_block) ⇒ Object
Runs the given patter_block on each host in
host_specs
.
Instance Method Details
#on_host(host_specs, &run_block) ⇒ Object
Runs the given patter_block on each host in host_specs
. host_specs
should be an array of String hostname/connection strings or SSHKitHost
instances.
&block should accept an SSHKit::Backend and SSHKit::Host
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
# File 'lib/loom/runner/sshkit_connector.rb', line 19 def on_host(host_specs, &run_block) host_specs.each do |spec| unless spec.is_a? Loom::HostSpec raise UnexpectedHostError "not a HostSpec => #{spec}" end end host_spec_map = host_specs.reduce({}) do |map, spec| map[spec.hostname] = spec map end execution_block = lambda do |sshkit_host| host_spec = host_spec_map[sshkit_host.hostname] Loom.log.debug1(self) { "connecting to host => #{host_spec.hostname}" } sshkit_backend = self begin # TODO: document the reciever of this yield yield sshkit_backend, host_spec rescue SocketError => e Loom.log.error "error connecting to host => #{host_spec.hostname}" raise SSHConnectionError, e end end local_specs = host_specs.select { |s| s.is_localhost? } unless local_specs.empty? Loom.log.debug1(self) do "local execution for host entry => #{local_specs.first}" end SSHKitDSLShadow.run_locally &execution_block end remote_specs = host_specs.select { |s| s.is_remote? }.map(&:sshkit_host) unless remote_specs.empty? Loom.log.debug1(self) { "remoted execution for #{remote_specs.size} hosts" } SSHKitDSLShadow.on remote_specs, &execution_block end end |