Added ExchangeType.type for the name of the exchange type

This commit is contained in:
Ask Solem 2011-01-17 16:32:20 +01:00
parent 12808079ba
commit 61eb2a0fb4
1 changed files with 4 additions and 0 deletions

View File

@ -18,6 +18,7 @@ class ExchangeType(object):
:param channel: AMQ Channel :param channel: AMQ Channel
""" """
type = None
def __init__(self, channel): def __init__(self, channel):
self.channel = channel self.channel = channel
@ -46,6 +47,7 @@ class ExchangeType(object):
class DirectExchange(ExchangeType): class DirectExchange(ExchangeType):
"""The `direct` exchange routes based on exact routing keys.""" """The `direct` exchange routes based on exact routing keys."""
type = "direct"
def lookup(self, table, exchange, routing_key, default): def lookup(self, table, exchange, routing_key, default):
return [queue for rkey, _, queue in table return [queue for rkey, _, queue in table
@ -55,6 +57,7 @@ class DirectExchange(ExchangeType):
class TopicExchange(ExchangeType): class TopicExchange(ExchangeType):
"""The `topic` exchanges routes based on words separated by dots, and """The `topic` exchanges routes based on words separated by dots, and
wildcard characters `*` (any single word), and `#` (one or more words).""" wildcard characters `*` (any single word), and `#` (one or more words)."""
type = "topic"
#: map of wildcard to regex conversions #: map of wildcard to regex conversions
wildcards = {"*": r".*?[^\.]", wildcards = {"*": r".*?[^\.]",
@ -96,6 +99,7 @@ class FanoutExchange(ExchangeType):
for an example implementation of these methods. for an example implementation of these methods.
""" """
type = "fanout"
def lookup(self, table, exchange, routing_key, default): def lookup(self, table, exchange, routing_key, default):
return [queue for _, _, queue in table] return [queue for _, _, queue in table]