Coverage for apps/ptf/log_utils.py: 83%
22 statements
« prev ^ index » next coverage.py v7.3.2, created at 2024-09-11 14:34 +0000
« prev ^ index » next coverage.py v7.3.2, created at 2024-09-11 14:34 +0000
1"""
2See :
3 https://stackoverflow.com/questions/2052284/how-to-throttle-django-error-emails
4 https://github.com/jedie/django-tools/blob/main/django_tools/log_utils/throttle_admin_email_handler.py
5"""
6# -*- coding: utf-8 -*-
8from django.core.cache import cache
9from django.utils.log import AdminEmailHandler
12class ThrottledAdminEmailHandler(AdminEmailHandler):
13 PERIOD_LENGTH_IN_SECONDS = 60
14 MAX_EMAILS_IN_PERIOD = 25
15 COUNTER_CACHE_KEY = "email_admins_counter"
17 def __init__(self, include_html=False, email_backend=None, reporter_class=None):
18 super().__init__()
20 def increment_counter(self):
21 try:
22 cache.incr(self.COUNTER_CACHE_KEY)
23 except ValueError:
24 cache.set(self.COUNTER_CACHE_KEY, 1, self.PERIOD_LENGTH_IN_SECONDS)
25 return cache.get(self.COUNTER_CACHE_KEY)
27 def emit(self, record):
28 try:
29 counter = self.increment_counter()
30 except Exception:
31 pass
32 else:
33 if counter > self.MAX_EMAILS_IN_PERIOD: 33 ↛ 34line 33 didn't jump to line 34, because the condition on line 33 was never true
34 return
35 super().emit(record)