core/homeassistant/components/logger.py

101 lines
2.6 KiB
Python
Raw Normal View History

2015-11-04 20:30:02 +00:00
"""
2015-11-12 17:04:48 +00:00
Component that will help set the level of logging for components.
2015-11-04 20:30:02 +00:00
For more details about this component, please refer to the documentation at
2015-11-09 12:12:18 +00:00
https://home-assistant.io/components/logger/
2015-11-04 20:30:02 +00:00
"""
import logging
2015-11-06 21:51:33 +00:00
from collections import OrderedDict
2015-11-04 20:30:02 +00:00
import voluptuous as vol
import homeassistant.helpers.config_validation as cv
2015-11-04 20:30:02 +00:00
DOMAIN = 'logger'
LOGSEVERITY = {
'CRITICAL': 50,
'FATAL': 50,
'ERROR': 40,
'WARNING': 30,
'WARN': 30,
'INFO': 20,
'DEBUG': 10,
'NOTSET': 0
}
LOGGER_DEFAULT = 'default'
LOGGER_LOGS = 'logs'
_LOGS_SCHEMA = vol.Schema({
cv.string: vol.In(vol.Lower(list(LOGSEVERITY))),
})
CONFIG_SCHEMA = vol.Schema({
DOMAIN: vol.Schema({
vol.Required(LOGGER_DEFAULT): vol.In(vol.Lower(list(LOGSEVERITY))),
vol.Required(LOGGER_LOGS): _LOGS_SCHEMA,
}),
}, extra=vol.ALLOW_EXTRA)
2015-11-04 20:30:02 +00:00
class HomeAssistantLogFilter(logging.Filter):
2016-03-07 17:49:31 +00:00
"""A log filter."""
2016-03-08 16:55:57 +00:00
2015-11-04 21:08:15 +00:00
# pylint: disable=no-init,too-few-public-methods
2015-11-04 20:30:02 +00:00
def __init__(self, logfilter):
2016-03-08 16:55:57 +00:00
"""Initialize the filter."""
2015-11-04 21:08:15 +00:00
super().__init__()
2015-11-04 20:30:02 +00:00
self.logfilter = logfilter
def filter(self, record):
2016-03-07 17:49:31 +00:00
"""A filter to use."""
2015-11-12 17:04:48 +00:00
# Log with filtered severity
2015-11-04 20:30:02 +00:00
if LOGGER_LOGS in self.logfilter:
2015-11-06 21:51:33 +00:00
for filtername in self.logfilter[LOGGER_LOGS]:
logseverity = self.logfilter[LOGGER_LOGS][filtername]
2015-11-04 20:30:02 +00:00
if record.name.startswith(filtername):
return record.levelno >= logseverity
# Log with default severity
default = self.logfilter[LOGGER_DEFAULT]
return record.levelno >= default
def setup(hass, config=None):
2016-03-07 17:49:31 +00:00
"""Setup the logger component."""
2015-11-04 20:30:02 +00:00
logfilter = dict()
# Set default log severity
2015-11-06 21:51:33 +00:00
logfilter[LOGGER_DEFAULT] = LOGSEVERITY['DEBUG']
if LOGGER_DEFAULT in config.get(DOMAIN):
2015-11-04 21:08:15 +00:00
logfilter[LOGGER_DEFAULT] = LOGSEVERITY[
2015-11-06 21:51:33 +00:00
config.get(DOMAIN)[LOGGER_DEFAULT].upper()
2015-11-04 21:08:15 +00:00
]
2015-11-04 20:30:02 +00:00
2015-11-12 17:04:48 +00:00
# Compute log severity for components
2015-11-06 21:51:33 +00:00
if LOGGER_LOGS in config.get(DOMAIN):
for key, value in config.get(DOMAIN)[LOGGER_LOGS].items():
config.get(DOMAIN)[LOGGER_LOGS][key] = LOGSEVERITY[value.upper()]
logs = OrderedDict(
sorted(
config.get(DOMAIN)[LOGGER_LOGS].items(),
key=lambda t: len(t[0]),
reverse=True
)
2015-11-04 21:08:15 +00:00
)
2015-11-06 21:51:33 +00:00
2015-11-04 20:30:02 +00:00
logfilter[LOGGER_LOGS] = logs
logger = logging.getLogger('')
logger.setLevel(logging.NOTSET)
2015-11-04 20:30:02 +00:00
# Set log filter for all log handler
for handler in logging.root.handlers:
handler.setLevel(logging.NOTSET)
2015-11-04 20:30:02 +00:00
handler.addFilter(HomeAssistantLogFilter(logfilter))
return True