HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //usr/lib/ruby/vendor_ruby/net/ssh/multi.rb
require 'net/ssh/multi/session'

module Net; module SSH
  # Net::SSH::Multi is a library for controlling multiple Net::SSH
  # connections via a single interface. It exposes an API similar to that of
  # Net::SSH::Connection::Session and Net::SSH::Connection::Channel, making it
  # simpler to adapt programs designed for single connections to be used with
  # multiple connections.
  #
  # This library is particularly useful for automating repetitive tasks that
  # must be performed on multiple machines. It executes the commands in
  # parallel, and allows commands to be executed on subsets of servers
  # (defined by groups).
  #
  #   require 'net/ssh/multi'
  # 
  #   Net::SSH::Multi.start do |session|
  #     # access servers via a gateway
  #     session.via 'gateway', 'gateway-user'
  # 
  #     # define the servers we want to use
  #     session.use 'user1@host1'
  #     session.use 'user2@host2'
  # 
  #     # define servers in groups for more granular access
  #     session.group :app do
  #       session.use 'user@app1'
  #       session.use 'user@app2'
  #     end
  # 
  #     # execute commands on all servers
  #     session.exec "uptime"
  # 
  #     # execute commands on a subset of servers
  #     session.with(:app).exec "hostname"
  # 
  #     # run the aggregated event loop
  #     session.loop
  #   end
  # 
  # See Net::SSH::Multi::Session for more documentation.
  module Multi
    # This is a convenience method for instantiating a new
    # Net::SSH::Multi::Session. If a block is given, the session will be
    # yielded to the block automatically closed (see Net::SSH::Multi::Session#close)
    # when the block finishes. Otherwise, the new session will be returned.
    #
    #   Net::SSH::Multi.start do |session|
    #     # ...
    #   end
    #
    #   session = Net::SSH::Multi.start
    #   # ...
    #   session.close
    #
    # Any options are passed directly to Net::SSH::Multi::Session.new (q.v.).
    def self.start(options={})
      session = Session.new(options)

      if block_given?
        begin
          yield session
          session.loop
          session.close
        end
      else
        return session
      end
    end
  end
end; end