/
logger.py
96 lines (69 loc) · 2.77 KB
/
logger.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
# Author: Nic Wolfe <nic@wolfeden.ca>
# URL: http://code.google.com/p/sickbeard/
#
# This file is part of Sick Beard.
#
# Sick Beard is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Sick Beard is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Sick Beard. If not, see <http://www.gnu.org/licenses/>.
import os.path
import threading
import logging
import logging.handlers
from exceptions import *
import sickbeard
from sickbeard import classes
ERROR = logging.ERROR
WARNING = logging.WARNING
MESSAGE = logging.INFO
DEBUG = logging.DEBUG
reverseNames = {u'ERROR': ERROR,
u'WARNING': WARNING,
u'INFO': MESSAGE,
u'DEBUG': DEBUG}
logFile = ''
def initLogging(consoleLogging=True):
global logFile
logFile = os.path.join(sickbeard.LOG_DIR, 'sickbeard.log')
fileHandler = logging.handlers.RotatingFileHandler(
logFile,
maxBytes=25000000,
backupCount=5)
fileHandler.setLevel(logging.DEBUG)
fileHandler.setFormatter(logging.Formatter('%(asctime)s %(levelname)-8s %(message)s', '%b-%d %H:%M:%S'))
logging.getLogger('sickbeard').addHandler(fileHandler)
# define a Handler which writes INFO messages or higher to the sys.stderr
if consoleLogging:
console = logging.StreamHandler()
console.setLevel(logging.INFO)
# set a format which is simpler for console use
console.setFormatter(logging.Formatter('%(asctime)s %(levelname)s::%(message)s', '%H:%M:%S'))
# add the handler to the root logger
logging.getLogger('sickbeard').addHandler(console)
logging.getLogger('sickbeard').setLevel(logging.DEBUG)
def log(toLog, logLevel=MESSAGE):
meThread = threading.currentThread().getName()
message = meThread + " :: " + toLog
outLine = message.encode('utf-8')
sbLogger = logging.getLogger('sickbeard')
if logLevel == DEBUG:
sbLogger.debug(outLine)
elif logLevel == MESSAGE:
sbLogger.info(outLine)
elif logLevel == WARNING:
sbLogger.warning(outLine)
elif logLevel == ERROR:
sbLogger.error(outLine)
# add errors to the UI logger
classes.ErrorViewer.add(classes.UIError(message))
else:
sbLogger.log(logLevel, outLine)