# HG changeset patch # User Laurent Peuch # Date 1564620712 -7200 # Node ID 7df6c6048bc8f9a19a057bc700810dca9c0bf721 # Parent 22ece66dcd4721898ebc17abf8d6b8007a7c3caf [debug] add a new channel events mechanism for debugging diff -r 22ece66dcd47 -r 7df6c6048bc8 cubicweb/debug.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/cubicweb/debug.py Thu Aug 01 02:51:52 2019 +0200 @@ -0,0 +1,54 @@ +# copyright 2019 LOGILAB S.A. (Paris, FRANCE), all rights reserved. +# contact http://www.logilab.fr/ -- mailto:contact@logilab.fr +# +# This file is part of CubicWeb. +# +# CubicWeb is free software: you can redistribute it and/or modify it under the +# terms of the GNU Lesser General Public License as published by the Free +# Software Foundation, either version 2.1 of the License, or (at your option) +# any later version. +# +# CubicWeb is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more +# details. +# +# You should have received a copy of the GNU Lesser General Public License along +# with CubicWeb. If not, see . + +from logging import getLogger + +logger = getLogger('cubicweb') + + +SUBSCRIBERS = { + "rql": [], +} + + +def subscribe_to_debug_channel(channel, subscriber): + if channel not in SUBSCRIBERS.keys(): + raise Exception("debug channel '%s' doesn't exist" % channel) + + SUBSCRIBERS[channel].append(subscriber) + + +def unsubscribe_to_debug_channel(channel, subscriber): + if channel not in SUBSCRIBERS.keys(): + raise Exception("debug channel '%s' doesn't exist" % channel) + + if subscriber not in SUBSCRIBERS[channel]: + raise Exception("subscriber '%s' is not in debug channel '%s'" % (subscriber, channel)) + + SUBSCRIBERS[channel].remove(subscriber) + + +def emit_to_debug_channel(channel, message): + if channel not in SUBSCRIBERS.keys(): + raise Exception("debug channel '%s' doesn't exist" % channel) + + for subscriber in SUBSCRIBERS[channel]: + try: + subscriber(message) + except Exception: + logger.error("Failed to send debug message '%s' to subscriber '%s'", message, subscriber, exc_info=True)