-
-
Notifications
You must be signed in to change notification settings - Fork 11
Expand file tree
/
Copy pathmodels.py
More file actions
74 lines (66 loc) · 2.62 KB
/
models.py
File metadata and controls
74 lines (66 loc) · 2.62 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
# -*- coding: utf-8 -*-
#
# Django error tracker default model
#
# :copyright: 2019 Sonu Kumar
# :license: BSD-3-Clause
#
from django.core.paginator import Paginator, EmptyPage
from django.db import models
from error_tracker.libs.mixins import ModelMixin
from django.utils.timezone import now
from traceback import print_exc
from .settings import EXCEPTION_APP_DEFAULT_LIST_SIZE
from collections import namedtuple
Page = namedtuple("Page", "has_next, next_num, has_prev, prev_num, items ")
class ErrorModel(models.Model, ModelMixin):
"""
Model to track exceptions
"""
hash = models.CharField(max_length=64, primary_key=True)
host = models.CharField(max_length=1024)
path = models.CharField(max_length=4096)
method = models.CharField(max_length=64)
request_data = models.TextField()
exception_name = models.CharField(max_length=256)
traceback = models.TextField()
count = models.IntegerField(default=0)
created_on = models.DateTimeField(auto_now=True)
last_seen = models.DateTimeField(auto_now=True, db_index=True)
@classmethod
def get_exceptions_per_page(cls, page_number=1):
records = cls.objects.all().order_by('last_seen')
paginator = Paginator(records, EXCEPTION_APP_DEFAULT_LIST_SIZE)
try:
page = paginator.page(page_number)
return Page(page.has_next(),
page.next_page_number() if page.has_next() else None,
page.has_previous(),
page.previous_page_number() if page.has_previous() else None,
page.object_list)
except EmptyPage:
return Page(False, None, True, paginator.num_pages, [])
@classmethod
def get_entity(cls, rhash):
return cls.objects.get(pk=rhash)
@classmethod
def create_or_update_entity(cls, rhash, host, path, method, request_data, exception_name, traceback):
try:
obj, created = cls.objects.get_or_create(hash=rhash)
if created:
obj.host, obj.path, obj.method, obj.request_data, obj.exception_name, obj.traceback = \
host, path, method, request_data, exception_name, traceback
obj.count = 1
obj.save()
else:
obj.count += 1
obj.last_seen = now()
obj.save(update_fields=['count', 'last_seen'])
except Exception:
print_exc()
@classmethod
def delete_entity(cls, rhash):
return cls.objects.filter(pk=rhash).delete()
class Meta:
db_table = 'exceptions'
swappable = 'APP_ERROR_DB_MODEL'