37 lines
1.2 KiB
Python
37 lines
1.2 KiB
Python
![]() |
from django.db.models import Count
|
||
|
from django.utils import timezone
|
||
|
from datetime import timedelta
|
||
|
|
||
|
from ..models import SubscriptionRequest
|
||
|
|
||
|
def get_latest_requests(limit=50):
|
||
|
requests = SubscriptionRequest.objects.order_by("-created_at")[:limit]
|
||
|
requests_dict = []
|
||
|
for request in requests:
|
||
|
requests_dict.append({
|
||
|
"request_id": request.request_id,
|
||
|
"pages": request.pages,
|
||
|
"doc_type": request.doc_type,
|
||
|
# "predict_result": request.predict_result,
|
||
|
"created_at": request.created_at,
|
||
|
})
|
||
|
return requests_dict
|
||
|
|
||
|
def count_requests_by_date(days_limit=5):
|
||
|
today = timezone.now().date()
|
||
|
start_date = today - timedelta(days=days_limit)
|
||
|
requests_by_date = SubscriptionRequest.objects.filter(created_at__gte=start_date).values('created_at__date').annotate(count=Count('id')).values('created_at__date', 'count').order_by('created_at__date')
|
||
|
count_dict = []
|
||
|
for rbd in requests_by_date:
|
||
|
count_dict.append({
|
||
|
"date": rbd["created_at__date"],
|
||
|
"count": rbd["count"],
|
||
|
})
|
||
|
return count_dict
|
||
|
|
||
|
|
||
|
def get_health_report():
|
||
|
return {
|
||
|
"latest_requests": get_latest_requests(),
|
||
|
"count_by_date": count_requests_by_date(),
|
||
|
}
|