Browse Source

Log to root logger by default in on_error

Change the default implementation of on_error to log to the root logger
instead of discord.client and clarify that the exception is being
ignored.  This ensures that a message will be output to standard error
in case the logging module has not been configured.

Also removes the argument printing for the default on_error, this is due
to them often being too long, that they could cause another exception to
be thrown, and because it sometimes causes sensitive information to be
output such as Discord tokens and session ids.  It was also possible for
the length to get in the megabyte range with exceptions thrown by
on_socket_raw_receive in READY events.
pull/24/head
Hornwitser 10 years ago
parent
commit
9ab1d041d4
  1. 3
      discord/client.py
  2. 21
      docs/api.rst

3
discord/client.py

@ -478,8 +478,7 @@ class Client(object):
raise InvalidDestination('Destination must be Channel, PrivateChannel, User, or str')
def on_error(self, event_method, *args, **kwargs):
msg = 'Caught exception in {} with args (*{}, **{})'
log.exception(msg.format(event_method, args, kwargs))
logging.exception('Ignoring exception in {}'.format(event_method))
# Compatibility shim
def __getattr__(self, name):

21
docs/api.rst

@ -5,6 +5,14 @@ API Reference
The following section outlines the API of discord.py.
.. note::
This module uses the Python logging module to log diagnostic and errors
in an output independent way. If the logging module is not configured,
these logs will not be output anywhere. See :ref:`logging_setup` for
more information on how to set up and use the logging module with
discord.py.
Client
-------
@ -36,13 +44,6 @@ to handle it, which defaults to log a traceback and ignore the exception.
.. versionadded:: 0.7.0
Subclassing to listen to events.
.. note::
If the Python logging module is not configured, the logs will not be
output anywhere. Meaning that exceptions in handlers will be
silently ignored. See :ref:`logging_setup` for more information on how to
set up and use the logging module with discord.py.
.. function:: on_ready()
@ -57,6 +58,12 @@ to handle it, which defaults to log a traceback and ignore the exception.
this event can be overridden. Which, when done, will supress the
default logging done.
.. note::
The default ``on_error`` handler logs exception to the root logger
instead of a logger under the discord namespace. This is to ensure
that exceptions are output somewhere if logging is not configured.
The information of the exception rasied and the exception itself can
be retreived with a standard call to ``sys.exc_info()``.

Loading…
Cancel
Save