mirror of
https://github.com/1Panel-dev/MaxKB.git
synced 2025-12-26 18:32:48 +00:00
109 lines
2.9 KiB
Python
109 lines
2.9 KiB
Python
# coding=utf-8
|
||
"""
|
||
@project: MaxKB
|
||
@Author:虎虎
|
||
@file: log.py
|
||
@date:2025/6/4 14:13
|
||
@desc:
|
||
"""
|
||
|
||
from system_manage.models.log_management import Log
|
||
|
||
|
||
def _get_ip_address(request):
|
||
"""
|
||
获取ip地址
|
||
@param request:
|
||
@return:
|
||
"""
|
||
x_forwarded_for = request.META.get('HTTP_X_FORWARDED_FOR')
|
||
if x_forwarded_for:
|
||
ip = x_forwarded_for.split(',')[0]
|
||
else:
|
||
ip = request.META.get('REMOTE_ADDR')
|
||
return ip
|
||
|
||
|
||
def _get_user(request):
|
||
"""
|
||
获取用户
|
||
@param request:
|
||
@return:
|
||
"""
|
||
user = request.user
|
||
if user is None:
|
||
return {
|
||
|
||
}
|
||
user_info = {
|
||
"id": str(user.id),
|
||
"email": user.email,
|
||
"phone": user.phone,
|
||
"nick_name": user.nick_name,
|
||
"username": user.username,
|
||
}
|
||
# 如果是 User 模型且有 role 属性
|
||
if hasattr(user, 'role'):
|
||
user_info['role'] = user.role
|
||
return user_info
|
||
|
||
|
||
def _get_details(request):
|
||
path = request.path
|
||
body = request.data
|
||
query = request.query_params
|
||
return {
|
||
'path': path,
|
||
'body': body,
|
||
'query': query
|
||
}
|
||
|
||
|
||
def _get_workspace_id(request, kwargs):
|
||
return kwargs.get('workspace_id', 'None')
|
||
|
||
|
||
def log(menu: str, operate, get_user=_get_user, get_ip_address=_get_ip_address, get_details=_get_details,
|
||
get_operation_object=None, get_workspace_id=_get_workspace_id):
|
||
"""
|
||
记录审计日志
|
||
@param menu: 操作菜单 str
|
||
@param operate: 操作 str|func 如果是一个函数 入参将是一个request 响应为str def operate(request): return "操作菜单"
|
||
@param get_user: 获取用户
|
||
@param get_ip_address:获取IP地址
|
||
@param get_details: 获取执行详情
|
||
@param get_operation_object: 获取操作对象
|
||
@param get_workspace_id: 获取工作空间id
|
||
@return:
|
||
"""
|
||
|
||
def inner(func):
|
||
def run(view, request, **kwargs):
|
||
status = 200
|
||
operation_object = {}
|
||
try:
|
||
if get_operation_object is not None:
|
||
operation_object = get_operation_object(request, kwargs)
|
||
except Exception as e:
|
||
pass
|
||
try:
|
||
return func(view, request, **kwargs)
|
||
except Exception as e:
|
||
status = 500
|
||
raise e
|
||
finally:
|
||
ip = get_ip_address(request)
|
||
user = get_user(request)
|
||
details = get_details(request)
|
||
workspace_id = get_workspace_id(request, kwargs)
|
||
_operate = operate
|
||
if callable(operate):
|
||
_operate = operate(request)
|
||
# 插入审计日志
|
||
Log(menu=menu, operate=_operate, user=user, status=status, ip_address=ip, details=details,
|
||
operation_object=operation_object, workspace_id=workspace_id).save()
|
||
|
||
return run
|
||
|
||
return inner
|