blob: 09dc3f9c6d8076173e3a53844fd2a73b08b91d38 [file] [log] [blame]
#!/usr/bin/env ruby
#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you 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.
require 'qpid_proton'
require 'optparse'
Thread.new do
print "This is a side thread:\n"
loop do
print "The time is now #{Time.new.strftime('%I:%M:%S')}.\n"
sleep 1
end
end
addresses = []
OptionParser.new do |opts|
opts.banner = "Usage: recv.rb <addr1> ... <addrn>"
opts.parse!
addresses = ARGV
end
addresses = ["~0.0.0.0"] if addresses.empty?
messenger = Qpid::Proton::Messenger::Messenger.new
messenger.passive = true
begin
messenger.start
rescue ProtonError => error
print "ERROR: #{error.message}\n"
print error.backtrace.join("\n")
exit
end
addresses.each do |address|
begin
messenger.subscribe(address)
rescue Qpid::Proton::ProtonError => error
print "ERROR: #{error.message}\n"
exit
end
end
msg = Qpid::Proton::Message.new
read_array = []
write_array = []
selectables = {}
loop do
# wait for incoming messages
sel = messenger.selectable
while !sel.nil?
if sel.terminal?
selectables.delete(sel.fileno)
read_array.delete(sel)
write_array.delete(sel)
sel.free
else
if !sel.registered?
read_array << sel
write_array << sel
selectables[sel.fileno] = sel
sel.registered = true
end
end
sel = messenger.selectable
end
unless selectables.empty?
rarray = []; read_array.each {|fd| rarray << fd.to_io }
warray = []; write_array.each {|fd| warray << fd.to_io }
if messenger.deadline > 0.0
result = IO.select(rarray, warray, nil, messenger.deadline)
else
result = IO.select(rarray, warray)
end
unless result.nil? && result.empty?
result.flatten.each do |io|
sel = selectables[io.fileno]
sel.writable
sel.readable
end
end
begin
messenger.receive(10)
rescue Qpid::Proton::ProtonError => error
print "ERROR: #{error.message}\n"
exit
end
while messenger.incoming.nonzero?
begin
messenger.get(msg)
rescue Qpid::Proton::Error => error
print "ERROR: #{error.message}\n"
exit
end
print "Address: #{msg.address}\n"
subject = msg.subject || "(no subject)"
print "Subject: #{subject}\n"
print "Body: #{msg.body}\n"
print "Properties: #{msg.properties}\n"
print "Instructions: #{msg.instructions}\n"
print "Annotations: #{msg.annotations}\n"
if msg.reply_to
print "=== Sending a reply to #{msg.reply_to}\n"
reply = Qpid::Proton::Message.new
reply.address = msg.reply_to
reply.subject = "RE: #{msg.subject}"
reply.body = "Thanks for the message!"
messenger.put(reply)
messenger.send
end
end
end
end
messenger.stop