52 lines
1.5 KiB
Python
Executable File
52 lines
1.5 KiB
Python
Executable File
import uuid
|
|
from django.db import models
|
|
|
|
from apps.utils.models import BaseModel
|
|
|
|
|
|
class DrfRequestLog(BaseModel):
|
|
"""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)
|