67 lines
2.2 KiB
Python
Executable File
67 lines
2.2 KiB
Python
Executable File
import uuid
|
|
from django.db import models
|
|
|
|
from apps.utils.models import BaseModel
|
|
|
|
|
|
class AuditLog(models.Model):
|
|
"""TN:审计表"""
|
|
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
|
|
action = models.CharField('动作', max_length=20)
|
|
model_name = models.CharField('模型名', max_length=20)
|
|
instance_id = models.CharField('记录ID', max_length=20, editable=False)
|
|
change_reason = models.CharField('变更原因', default='', max_length=50)
|
|
change_user = models.ForeignKey(
|
|
'system.user', on_delete=models.SET_NULL, verbose_name='操作人', null=True, blank=True)
|
|
change_time = models.DateTimeField('变更时间')
|
|
val_new = models.JSONField('变更后完整数据', default=dict)
|
|
difference = models.JSONField('变更情况', default=list)
|
|
|
|
|
|
class DrfRequestLog(BaseModel):
|
|
"""TN:Logs Django rest framework API requests"""
|
|
|
|
id = models.UUIDField(primary_key=True, default=uuid.uuid4)
|
|
user = models.ForeignKey(
|
|
'system.user',
|
|
on_delete=models.SET_NULL,
|
|
null=True,
|
|
blank=True,
|
|
)
|
|
requested_at = models.DateTimeField(db_index=True)
|
|
response_ms = models.PositiveIntegerField(default=0)
|
|
path = models.CharField(
|
|
max_length=400,
|
|
db_index=True,
|
|
help_text="请求地址",
|
|
)
|
|
view = models.CharField(
|
|
max_length=400,
|
|
null=True,
|
|
blank=True,
|
|
db_index=True,
|
|
help_text="执行视图",
|
|
)
|
|
view_method = models.CharField(
|
|
max_length=50,
|
|
null=True,
|
|
blank=True,
|
|
db_index=True,
|
|
)
|
|
remote_addr = models.GenericIPAddressField()
|
|
host = models.URLField()
|
|
method = models.CharField(max_length=10)
|
|
query_params = models.TextField(null=True, blank=True)
|
|
data = models.TextField(null=True, blank=True)
|
|
response = models.TextField(null=True, blank=True)
|
|
errors = models.TextField(null=True, blank=True)
|
|
agent = models.TextField(null=True, blank=True)
|
|
status_code = models.PositiveIntegerField(
|
|
null=True, blank=True, db_index=True)
|
|
|
|
class Meta:
|
|
verbose_name = "DRF请求日志"
|
|
|
|
def __str__(self):
|
|
return "{} {}".format(self.method, self.path)
|