2021-08-17 17:00:34 +08:00
|
|
|
from abc import ABC, abstractmethod
|
|
|
|
import datetime
|
|
|
|
import functools
|
|
|
|
import json
|
|
|
|
|
|
|
|
from flask import current_app, g, request
|
|
|
|
|
2023-09-03 19:34:55 +08:00
|
|
|
|
2021-08-17 17:00:34 +08:00
|
|
|
# @pysnooper.snoop(depth=2)
|
|
|
|
class AbstractEventLogger(ABC):
|
|
|
|
@abstractmethod
|
2023-09-03 19:34:55 +08:00
|
|
|
def log(self, user_id, action, duration_ms, *args, **kwargs):
|
2021-08-17 17:00:34 +08:00
|
|
|
pass
|
|
|
|
|
|
|
|
def log_this(self, f):
|
|
|
|
@functools.wraps(f)
|
|
|
|
def wrapper(*args, **kwargs):
|
|
|
|
user_id = None
|
|
|
|
if g.user:
|
|
|
|
user_id = g.user.get_id()
|
|
|
|
d = request.form.to_dict() or {}
|
|
|
|
|
|
|
|
# request parameters can overwrite post body
|
|
|
|
request_params = request.args.to_dict()
|
|
|
|
d.update(request_params)
|
|
|
|
d.update(kwargs)
|
|
|
|
|
2023-12-11 13:23:35 +08:00
|
|
|
d.update(request.get_json(silent=True) or {})
|
2021-08-17 17:00:34 +08:00
|
|
|
|
|
|
|
self.stats_logger.incr(f.__name__)
|
|
|
|
start_dttm = datetime.datetime.now()
|
|
|
|
value = f(*args, **kwargs)
|
|
|
|
duration_ms = (datetime.datetime.now() - start_dttm).total_seconds() * 1000
|
|
|
|
|
|
|
|
if user_id:
|
|
|
|
self.log(
|
|
|
|
user_id,
|
|
|
|
f.__name__,
|
|
|
|
duration_ms=duration_ms,
|
|
|
|
**d
|
|
|
|
)
|
|
|
|
return value
|
|
|
|
|
|
|
|
return wrapper
|
|
|
|
|
|
|
|
@property
|
|
|
|
def stats_logger(self):
|
|
|
|
return current_app.config.get("STATS_LOGGER")
|
|
|
|
|
2023-09-03 19:34:55 +08:00
|
|
|
|
2021-08-17 17:00:34 +08:00
|
|
|
# @pysnooper.snoop(depth=2)
|
|
|
|
class DBEventLogger(AbstractEventLogger):
|
|
|
|
|
2023-09-03 19:34:55 +08:00
|
|
|
def log(self, user_id, action, duration_ms, *args, **kwargs):
|
2021-08-17 17:00:34 +08:00
|
|
|
from myapp.models.log import Log
|
|
|
|
referrer = request.referrer[:1000] if request.referrer else None
|
|
|
|
|
|
|
|
log = Log(
|
|
|
|
action=action,
|
2023-09-03 19:34:55 +08:00
|
|
|
json=json.dumps(kwargs, indent=4, ensure_ascii=False),
|
2021-08-17 17:00:34 +08:00
|
|
|
duration_ms=duration_ms,
|
|
|
|
referrer=referrer,
|
|
|
|
user_id=user_id,
|
|
|
|
method=request.method,
|
|
|
|
path=request.path,
|
|
|
|
dttm=datetime.datetime.now()
|
|
|
|
)
|
|
|
|
|
|
|
|
sesh = current_app.appbuilder.get_session
|
|
|
|
sesh.add(log)
|
|
|
|
sesh.commit()
|