Merge pull request #1094 from tahoe-lafs/3708.bytes-logging

Remove bytes from Foolscap logging

Fixes ticket:3708
This commit is contained in:
Itamar Turner-Trauring 2021-07-09 14:27:48 -07:00 committed by GitHub
commit 8e28a9d0e0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 21 additions and 9 deletions

0
newsfragments/3708.minor Normal file
View File

View File

@ -28,8 +28,8 @@ if PY2:
codecs.register_error("backslashreplace_tahoe_py2", backslashreplace_py2) codecs.register_error("backslashreplace_tahoe_py2", backslashreplace_py2)
def _bytes_to_unicode(any_bytes, obj): def bytes_to_unicode(any_bytes, obj):
"""Create a function that recursively converts bytes to unicode. """Convert bytes to unicode.
:param any_bytes: If True, also support non-UTF-8-encoded bytes. :param any_bytes: If True, also support non-UTF-8-encoded bytes.
:param obj: Object to de-byte-ify. :param obj: Object to de-byte-ify.
@ -63,11 +63,11 @@ class UTF8BytesJSONEncoder(json.JSONEncoder):
""" """
def encode(self, o, **kwargs): def encode(self, o, **kwargs):
return json.JSONEncoder.encode( return json.JSONEncoder.encode(
self, _bytes_to_unicode(False, o), **kwargs) self, bytes_to_unicode(False, o), **kwargs)
def iterencode(self, o, **kwargs): def iterencode(self, o, **kwargs):
return json.JSONEncoder.iterencode( return json.JSONEncoder.iterencode(
self, _bytes_to_unicode(False, o), **kwargs) self, bytes_to_unicode(False, o), **kwargs)
class AnyBytesJSONEncoder(json.JSONEncoder): class AnyBytesJSONEncoder(json.JSONEncoder):
@ -79,11 +79,11 @@ class AnyBytesJSONEncoder(json.JSONEncoder):
""" """
def encode(self, o, **kwargs): def encode(self, o, **kwargs):
return json.JSONEncoder.encode( return json.JSONEncoder.encode(
self, _bytes_to_unicode(True, o), **kwargs) self, bytes_to_unicode(True, o), **kwargs)
def iterencode(self, o, **kwargs): def iterencode(self, o, **kwargs):
return json.JSONEncoder.iterencode( return json.JSONEncoder.iterencode(
self, _bytes_to_unicode(True, o), **kwargs) self, bytes_to_unicode(True, o), **kwargs)
def dumps(obj, *args, **kwargs): def dumps(obj, *args, **kwargs):

View File

@ -18,6 +18,16 @@ from pyutil import nummedobj
from foolscap.logging import log from foolscap.logging import log
from twisted.python import log as tw_log from twisted.python import log as tw_log
if PY2:
def bytes_to_unicode(ign, obj):
return obj
else:
# We want to convert bytes keys to Unicode, otherwise JSON serialization
# inside foolscap will fail (for details see
# https://github.com/warner/foolscap/issues/88)
from .jsonbytes import bytes_to_unicode
NOISY = log.NOISY # 10 NOISY = log.NOISY # 10
OPERATIONAL = log.OPERATIONAL # 20 OPERATIONAL = log.OPERATIONAL # 20
UNUSUAL = log.UNUSUAL # 23 UNUSUAL = log.UNUSUAL # 23
@ -28,7 +38,8 @@ SCARY = log.SCARY # 35
BAD = log.BAD # 40 BAD = log.BAD # 40
msg = log.msg def msg(*args, **kwargs):
return log.msg(*args, **bytes_to_unicode(True, kwargs))
# If log.err() happens during a unit test, the unit test should fail. We # If log.err() happens during a unit test, the unit test should fail. We
# accomplish this by sending it to twisted.log too. When a WEIRD/SCARY/BAD # accomplish this by sending it to twisted.log too. When a WEIRD/SCARY/BAD
@ -39,7 +50,7 @@ def err(failure=None, _why=None, **kwargs):
tw_log.err(failure, _why, **kwargs) tw_log.err(failure, _why, **kwargs)
if 'level' not in kwargs: if 'level' not in kwargs:
kwargs['level'] = log.UNUSUAL kwargs['level'] = log.UNUSUAL
return log.err(failure, _why, **kwargs) return log.err(failure, _why, **bytes_to_unicode(True, kwargs))
class LogMixin(object): class LogMixin(object):
""" I remember a msg id and a facility and pass them to log.msg() """ """ I remember a msg id and a facility and pass them to log.msg() """
@ -57,7 +68,8 @@ class LogMixin(object):
if pmsgid is None: if pmsgid is None:
pmsgid = self._grandparentmsgid pmsgid = self._grandparentmsgid
kwargs = {ensure_str(k): v for (k, v) in kwargs.items()} kwargs = {ensure_str(k): v for (k, v) in kwargs.items()}
msgid = log.msg(msg, facility=facility, parent=pmsgid, *args, **kwargs) msgid = log.msg(msg, facility=facility, parent=pmsgid, *args,
**bytes_to_unicode(True, kwargs))
if self._parentmsgid is None: if self._parentmsgid is None:
self._parentmsgid = msgid self._parentmsgid = msgid
return msgid return msgid