* Generate common/djangoapps import shims for LMS * Generate common/djangoapps import shims for Studio * Stop appending project root to sys.path * Stop appending common/djangoapps to sys.path * Import from common.djangoapps.course_action_state instead of course_action_state * Import from common.djangoapps.course_modes instead of course_modes * Import from common.djangoapps.database_fixups instead of database_fixups * Import from common.djangoapps.edxmako instead of edxmako * Import from common.djangoapps.entitlements instead of entitlements * Import from common.djangoapps.pipline_mako instead of pipeline_mako * Import from common.djangoapps.static_replace instead of static_replace * Import from common.djangoapps.student instead of student * Import from common.djangoapps.terrain instead of terrain * Import from common.djangoapps.third_party_auth instead of third_party_auth * Import from common.djangoapps.track instead of track * Import from common.djangoapps.util instead of util * Import from common.djangoapps.xblock_django instead of xblock_django * Add empty common/djangoapps/__init__.py to fix pytest collection * Fix pylint formatting violations * Exclude import_shims/ directory tree from linting
50 lines
1.5 KiB
Python
50 lines
1.5 KiB
Python
"""Event tracker backend that saves events to a python logger."""
|
|
|
|
|
|
import json
|
|
import logging
|
|
|
|
from django.conf import settings
|
|
|
|
from common.djangoapps.track.backends import BaseBackend
|
|
from common.djangoapps.track.utils import DateTimeJSONEncoder
|
|
|
|
log = logging.getLogger('common.djangoapps.track.backends.logger')
|
|
application_log = logging.getLogger('common.djangoapps.track.backends.application_log') # pylint: disable=invalid-name
|
|
|
|
|
|
class LoggerBackend(BaseBackend):
|
|
"""Event tracker backend that uses a python logger.
|
|
|
|
Events are logged to the INFO level as JSON strings.
|
|
|
|
"""
|
|
|
|
def __init__(self, name, **kwargs):
|
|
"""Event tracker backend that uses a python logger.
|
|
|
|
:Parameters:
|
|
- `name`: identifier of the logger, which should have
|
|
been configured using the default python mechanisms.
|
|
|
|
"""
|
|
super(LoggerBackend, self).__init__(**kwargs)
|
|
|
|
self.event_logger = logging.getLogger(name)
|
|
|
|
def send(self, event):
|
|
try:
|
|
event_str = json.dumps(event, cls=DateTimeJSONEncoder)
|
|
except UnicodeDecodeError:
|
|
application_log.exception(
|
|
"UnicodeDecodeError Event_data: %r", event
|
|
)
|
|
raise
|
|
|
|
# TODO: remove trucation of the serialized event, either at a
|
|
# higher level during the emittion of the event, or by
|
|
# providing warnings when the events exceed certain size.
|
|
event_str = event_str[:settings.TRACK_MAX_EVENT]
|
|
|
|
self.event_logger.info(event_str)
|