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
|
#!/usr/bin/env python
import qpid
from qpid.connection import Connection, listen
from qpid.delegate import Delegate
from qpid.peer import Peer
from qpid import Struct
class Server(Delegate):
def __init__(self):
Delegate.__init__(self)
self.queues = {}
self.bindings = {}
def connection_open(self, ch, msg):
msg.open_ok()
def session_open(self, ch, msg):
print "session open on channel %s" % ch.id
msg.attached()
def execution_flush(self, ch, msg):
pass
def queue_declare(self, ch, msg):
self.queues[msg.queue] = []
print "queue declared: %s" % msg.queue
msg.complete()
def queue_bind(self, ch, msg):
if self.bindings.has_key(msg.exchange):
queues = self.bindings[msg.exchange]
else:
queues = set()
self.bindings[msg.exchange] = queues
queues.add((msg.routing_key, msg.queue))
msg.complete()
def queue_query(self, ch, msg):
st = Struct(msg.method.result)
ch.execution_result(msg.command_id, st)
msg.complete()
def message_subscribe(self, ch, msg):
print msg
msg.complete()
def message_transfer(self, ch, msg):
print msg.content
msg.complete()
spec = qpid.spec.load("../specs/amqp.0-10-preview.xml")
for io in listen("0.0.0.0", 5672):
c = Connection(io, spec)
p = Peer(c, Server())
c.tini()
p.start()
ch = p.channel(0)
ch.connection_start()
ch.connection_tune()
|