Fix metrics

pull/1/head
Luca 2 years ago
parent 4a3f7adbee
commit ae82b26644

@ -1,65 +1,56 @@
from django.http import HttpResponse from django.http import HttpResponse
from shiftregister.app.models import Helper, ShiftRegistration, Message, Shift from shiftregister.app.models import Helper, ShiftRegistration, Message
from django.db.models import F, Count, Q, ExpressionWrapper, Case, When, Sum from django.db.models import Count, Case, When, Sum
from django.db import models from django.db import models
def metrics(request): def metrics(request):
help_wanted = Q(required_helpers__gt=F("reg_count")) | Q(required_helpers=0) & Q( response = HttpResponse(
room__required_helpers__gt=F("reg_count") "\n".join(
) (
team_shifts = ( f"shiftregister_{name} {value}"
Shift.with_reg_count() for name, value in (
.annotate(team_count=Count("teambackup")) ("helpers_total", Helper.objects.count()),
.filter( (
help_wanted, "helpers_confirmed_total",
team_count__gt=0, Helper.objects.filter(number_validated=True).count(),
deleted=False, ),
) (
) "helpers_helped_total",
Helper.objects.annotate(
helping_helpers = Helper.objects.annotate(
shift_count=Count( shift_count=Count(
Case( Case(
When( When(
shiftregistration__state__in=[ shiftregistration__state__in=[
ShiftRegistration.RegState.CHECKED_IN, ShiftRegistration.RegState.CHECKED_IN
], ],
then=1, then=1,
), ),
output_field=models.IntegerField(), output_field=models.IntegerField(),
) )
) )
).filter(number_validated=True, shift_count__gte=1) )
.filter(number_validated=True, shift_count__gte=1)
response = HttpResponse( .count(),
"\n".join(
(
f"shiftregister_{name} {value}"
for name, value in (
("helpers_total", Helper.objects.count()),
(
"helpers_confirmed_total",
Helper.objects.filter(number_validated=True).count(),
), ),
("helpers_helped", helping_helpers.count()),
( (
"worked_shifts", "worked_shifts_total",
ShiftRegistration.objects.filter( ShiftRegistration.objects.filter(
state=ShiftRegistration.RegState.CHECKED_IN state=ShiftRegistration.RegState.CHECKED_IN
).count(), ).count(),
), ),
( (
"messages_sent", "messages_sent_total",
Message.objects.all().count(), Message.objects.all().count(),
), ),
( (
"hours_worked", "worked_seconds_total",
ShiftRegistration.objects.filter( ShiftRegistration.objects.filter(
state=ShiftRegistration.RegState.CHECKED_IN state=ShiftRegistration.RegState.CHECKED_IN
).aggregate(sum=Sum("shift__duration"))["sum"], )
.aggregate(sum=Sum("shift__duration"))["sum"]
.total_seconds(),
), ),
("team_shifts", team_shifts.count()),
) )
) )
) )

Loading…
Cancel
Save