Add configurable blacklist filtering for python logger

This commit is contained in:
Matt Martz 2018-01-31 11:10:06 -06:00 committed by Brian Coca
parent 635036fb62
commit 7be8079bad
2 changed files with 18 additions and 0 deletions

View file

@ -710,6 +710,14 @@ DEFAULT_LOG_PATH:
ini:
- {key: log_path, section: defaults}
type: path
DEFAULT_LOG_FILTER:
name: Name filters for python logger
default: []
description: List of logger names to filter out of the log file
env: [{name: ANSIBLE_LOG_FILTER}]
ini:
- {key: log_filter, section: defaults}
type: list
DEFAULT_LOOKUP_PLUGIN_PATH:
name: Lookup Plugins Path
description: Colon separated paths in which Ansible will search for Lookup Plugins.

View file

@ -47,6 +47,14 @@ except NameError:
pass
class FilterBlackList(logging.Filter):
def __init__(self, blacklist):
self.blacklist = [logging.Filter(name) for name in blacklist]
def filter(self, record):
return not any(f.filter(record) for f in self.blacklist)
logger = None
# TODO: make this a logging callback instead
if C.DEFAULT_LOG_PATH:
@ -56,6 +64,8 @@ if C.DEFAULT_LOG_PATH:
mypid = str(os.getpid())
user = getpass.getuser()
logger = logging.getLogger("p=%s u=%s | " % (mypid, user))
for handler in logging.root.handlers:
handler.addFilter(FilterBlackList(C.DEFAULT_LOG_FILTER))
else:
print("[WARNING]: log file at %s is not writeable and we cannot create it, aborting\n" % path, file=sys.stderr)