1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
#
# 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 "thread"
require "qpid/peer"
require "qpid/queue"
module Qpid
class Client
def initialize(host, port, spec, vhost = nil)
@host = host
@port = port
@spec = spec
@vhost = if vhost.nil?; host else vhost end
@mechanism = nil
@response = nil
@locale = nil
@queues = {}
@mutex = Mutex.new()
@closed = false
@started = ConditionVariable.new()
@conn = Connection.new(@host, @port, @spec)
@peer = Peer.new(@conn, ClientDelegate.new(self))
end
attr_reader :mechanism, :response, :locale
def closed?; @closed end
def wait()
@mutex.synchronize do
@started.wait(@mutex)
end
raise EOFError.new() if closed?
end
def signal_start()
@started.broadcast()
end
def queue(key)
@mutex.synchronize do
q = @queues[key]
if q.nil?
q = Queue.new()
@queues[key] = q
end
return q
end
end
def start(response, mechanism="AMQPLAIN", locale="en_US")
@response = response
@mechanism = mechanism
@locale = locale
@conn.connect()
@conn.init()
@peer.start()
wait()
channel(0).connection_open(@vhost)
end
def channel(id)
return @peer.channel(id)
end
end
class ClientDelegate
include Delegate
def initialize(client)
@client = client
end
def connection_start(ch, msg)
ch.connection_start_ok(:mechanism => @client.mechanism,
:response => @client.response,
:locale => @client.locale)
end
def connection_tune(ch, msg)
ch.connection_tune_ok(*msg.fields)
@client.signal_start()
end
end
end
|