86 lines
2.3 KiB
Python
86 lines
2.3 KiB
Python
|
# -*- 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 json
|
||
|
import logging
|
||
|
import os
|
||
|
|
||
|
try:
|
||
|
from collections import OrderedDict
|
||
|
except ImportError:
|
||
|
from .packages.ordereddict import OrderedDict
|
||
|
|
||
|
|
||
|
class CustomEncoder(json.JSONEncoder):
|
||
|
|
||
|
def default(self, obj):
|
||
|
return super(CustomEncoder, self).default(obj)
|
||
|
|
||
|
|
||
|
class JsonFormatter(logging.Formatter):
|
||
|
|
||
|
def __init__(self, timestamp, endtime, isWrite, targetFile, version,
|
||
|
plugin, datefmt=None):
|
||
|
self.timestamp = timestamp
|
||
|
self.endtime = endtime
|
||
|
self.isWrite = isWrite
|
||
|
self.targetFile = targetFile
|
||
|
self.version = version
|
||
|
self.plugin = plugin
|
||
|
super(JsonFormatter, self).__init__(datefmt=datefmt)
|
||
|
|
||
|
def format(self, record):
|
||
|
data = OrderedDict([
|
||
|
('now', self.formatTime(record, self.datefmt)),
|
||
|
('version', self.version),
|
||
|
('plugin', self.plugin),
|
||
|
('time', self.timestamp),
|
||
|
('endtime', self.endtime),
|
||
|
('isWrite', self.isWrite),
|
||
|
('file', self.targetFile),
|
||
|
('level', record.levelname),
|
||
|
('message', record.msg),
|
||
|
])
|
||
|
if not self.endtime:
|
||
|
del data['endtime']
|
||
|
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 setup_logging(args, version):
|
||
|
logfile = args.logfile
|
||
|
if not logfile:
|
||
|
logfile = '~/.wakatime.log'
|
||
|
handler = logging.FileHandler(os.path.expanduser(logfile))
|
||
|
formatter = JsonFormatter(
|
||
|
timestamp=args.timestamp,
|
||
|
endtime=args.endtime,
|
||
|
isWrite=args.isWrite,
|
||
|
targetFile=args.targetFile,
|
||
|
version=version,
|
||
|
plugin=args.plugin,
|
||
|
datefmt='%Y-%m-%dT%H:%M:%SZ',
|
||
|
)
|
||
|
handler.setFormatter(formatter)
|
||
|
logger = logging.getLogger()
|
||
|
logger.addHandler(handler)
|
||
|
level = logging.INFO
|
||
|
if args.verbose:
|
||
|
level = logging.DEBUG
|
||
|
logger.setLevel(level)
|
||
|
return logger
|