mirror of
https://github.com/ihabunek/toot
synced 2025-01-26 17:24:59 +01:00
b15cb85a23
This allows setting either json or data. Until now we were always using data and this is not enough for some endpoints.
48 lines
1.3 KiB
Python
48 lines
1.3 KiB
Python
import json
|
|
|
|
from logging import getLogger
|
|
|
|
logger = getLogger('toot')
|
|
|
|
|
|
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 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))
|
|
|
|
if request.data:
|
|
logger.debug(">>> DATA: \033[33m{}\033[0m".format(request.data))
|
|
|
|
if request.json:
|
|
logger.debug(">>> JSON: \033[33m{}\033[0m".format(json.dumps(request.json)))
|
|
|
|
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):
|
|
if response.ok:
|
|
logger.debug("<<< \033[32m{}\033[0m".format(response))
|
|
logger.debug("<<< \033[33m{}\033[0m".format(response.content.decode()))
|
|
else:
|
|
logger.debug("<<< \033[31m{}\033[0m".format(response))
|
|
logger.debug("<<< \033[31m{}\033[0m".format(response.content.decode()))
|
|
|
|
|
|
def log_debug(*msgs):
|
|
logger.debug(" ".join(str(m) for m in msgs))
|