witchie/toot/logging.py

62 lines
1.6 KiB
Python
Raw Normal View History

import json
import sys
2017-12-30 12:06:24 +00:00
from logging import getLogger
logger = getLogger('toot')
VERBOSE = "--verbose" in sys.argv
2017-12-30 12:06:24 +00:00
def censor_secrets(headers):
def _censor(k, v):
if k == "Authorization":
return (k, "***CENSORED***")
return k, v
return {_censor(k, v) for k, v in headers.items()}
def truncate(line):
if not VERBOSE and len(line) > 100:
return line[:100] + ""
return line
2017-12-30 12:06:24 +00:00
def log_request(request):
logger.debug(">>> \033[32m{} {}\033[0m".format(request.method, request.url))
if request.headers:
headers = censor_secrets(request.headers)
logger.debug(">>> HEADERS: \033[33m{}\033[0m".format(headers))
2017-12-30 12:06:24 +00:00
if request.data:
data = truncate(request.data)
logger.debug(">>> DATA: \033[33m{}\033[0m".format(data))
2017-12-30 12:06:24 +00:00
if request.json:
data = truncate(json.dumps(request.json))
logger.debug(">>> JSON: \033[33m{}\033[0m".format(data))
2017-12-30 12:06:24 +00:00
if request.files:
logger.debug(">>> FILES: \033[33m{}\033[0m".format(request.files))
if request.params:
logger.debug(">>> PARAMS: \033[33m{}\033[0m".format(request.params))
def log_response(response):
content = truncate(response.content.decode())
2017-12-30 12:06:24 +00:00
if response.ok:
logger.debug("<<< \033[32m{}\033[0m".format(response))
logger.debug("<<< \033[33m{}\033[0m".format(content))
2017-12-30 12:06:24 +00:00
else:
logger.debug("<<< \033[31m{}\033[0m".format(response))
logger.debug("<<< \033[31m{}\033[0m".format(content))
2018-01-14 14:34:41 +00:00
def log_debug(*msgs):
logger.debug(" ".join(str(m) for m in msgs))