rana-cli/wakatime/log.py

104 lines
2.9 KiB
Python
Raw Normal View History

2013-07-06 07:51:09 +00:00
# -*- coding: utf-8 -*-
"""
wakatime.log
~~~~~~~~~~~~
Provides the configured logger for writing JSON to the log file.
:copyright: (c) 2013 Alan Hamlett.
:license: BSD, see LICENSE for more details.
"""
import logging
import os
import sys
2013-07-06 07:51:09 +00:00
2013-09-07 05:46:52 +00:00
from .packages import simplejson as json
2013-07-06 07:51:09 +00:00
try:
from collections import OrderedDict
except ImportError:
from .packages.ordereddict import OrderedDict
class CustomEncoder(json.JSONEncoder):
def default(self, obj):
2013-07-30 06:04:43 +00:00
if isinstance(obj, bytes):
obj = bytes.decode(obj)
return json.dumps(obj)
try:
encoded = super(CustomEncoder, self).default(obj)
except UnicodeDecodeError:
encoding = sys.getfilesystemencoding()
obj = obj.decode(encoding, 'ignore').encode('utf-8')
encoded = super(CustomEncoder, self).default(obj)
return encoded
2013-07-06 07:51:09 +00:00
class JsonFormatter(logging.Formatter):
2013-09-22 21:56:30 +00:00
def setup(self, timestamp, isWrite, targetFile, version, plugin):
2013-07-06 07:51:09 +00:00
self.timestamp = timestamp
self.isWrite = isWrite
2013-12-03 01:36:52 +00:00
self.targetFile = targetFile
2013-07-06 07:51:09 +00:00
self.version = version
self.plugin = plugin
def format(self, record):
data = OrderedDict([
2013-12-03 01:36:52 +00:00
('now', self.formatTime(record, self.datefmt)),
2013-07-06 07:51:09 +00:00
('version', self.version),
('plugin', self.plugin),
('time', self.timestamp),
2013-07-06 07:51:09 +00:00
('isWrite', self.isWrite),
('file', self.targetFile),
('level', record.levelname),
('message', record.msg),
])
if not self.plugin:
del data['plugin']
if not self.isWrite:
del data['isWrite']
return CustomEncoder().encode(data)
def formatException(self, exc_info):
return exec_info[2].format_exc()
def set_log_level(logger, args):
level = logging.WARN
if args.verbose:
level = logging.DEBUG
logger.setLevel(level)
2013-07-06 07:51:09 +00:00
def setup_logging(args, version):
logger = logging.getLogger('WakaTime')
set_log_level(logger, args)
if len(logger.handlers) > 0:
formatter = JsonFormatter(datefmt='%Y/%m/%d %H:%M:%S %z')
formatter.setup(
timestamp=args.timestamp,
isWrite=args.isWrite,
targetFile=args.targetFile,
version=version,
plugin=args.plugin,
)
logger.handlers[0].setFormatter(formatter)
return logger
2013-07-06 07:51:09 +00:00
logfile = args.logfile
if not logfile:
logfile = '~/.wakatime.log'
handler = logging.FileHandler(os.path.expanduser(logfile))
formatter = JsonFormatter(datefmt='%Y/%m/%d %H:%M:%S %z')
formatter.setup(
2013-07-06 07:51:09 +00:00
timestamp=args.timestamp,
isWrite=args.isWrite,
targetFile=args.targetFile,
version=version,
plugin=args.plugin,
)
handler.setFormatter(formatter)
logger.addHandler(handler)
return logger