oslo.messaging/oslo/messaging/notify/_impl_messaging.py
Mark McLoughlin e67f409b87 Don't use common logging
It appears we don't actually need this - we don't, for example, use any
of the special formatting supported by ContextAdaptor.
2013-06-16 15:24:41 +01:00

48 lines
1.6 KiB
Python

# Copyright 2011 OpenStack Foundation.
# All Rights Reserved.
# Copyright 2013 Red Hat, Inc.
#
# Licensed 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.
import logging
from oslo import messaging
from oslo.messaging.notify import notifier
LOG = logging.getLogger(__name__)
class MessagingDriver(notifier._Driver):
def __init__(self, conf, topics, transport, envelope=False):
super(MessagingDriver, self).__init__(conf, topics, transport)
self.envelope = envelope
def notify(self, context, message, priority):
for topic in self.topics:
target = messaging.Target(topic='%s.%s' % (topic, priority))
try:
self.transport._send(target, context, message,
envelope=self.envelope)
except Exception:
LOG.exception("Could not send notification to %(topic)s. "
"Payload=%(message)s",
dict(topic=topic, message=message))
class MessagingV2Driver(MessagingDriver):
def __init__(self, conf, **kwargs):
super(MessagingDriver, self).__init__(conf, envelope=True, **kwargs)