Add next_dates property to ScheduleProfile for upcoming schedule times

This commit is contained in:
Eduardo Silva
2026-02-04 14:15:30 -03:00
parent dc0a269af4
commit d3c54b4d26
3 changed files with 60 additions and 0 deletions

View File

@@ -1,6 +1,8 @@
import uuid
from datetime import datetime, timedelta
from django.db import models
from django.utils import timezone
from django.utils.translation import gettext_lazy as _
from wireguard.models import Peer
@@ -25,6 +27,51 @@ class ScheduleProfile(models.Model):
def __str__(self):
return self.name
@staticmethod
def _next_weekday_time(now, weekday, t):
tz = timezone.get_current_timezone()
today = timezone.localdate(now)
candidate_date = today + timedelta(days=(weekday - today.weekday()) % 7)
candidate = timezone.make_aware(
datetime.combine(candidate_date, t),
tz
)
if candidate <= now:
candidate_date += timedelta(days=7)
candidate = timezone.make_aware(
datetime.combine(candidate_date, t),
tz
)
return candidate
@property
def next_dates(self):
slots = list(self.time_interval.all())
if not slots:
return {'enable': None, 'disable': None}
now = timezone.now()
start_candidates = []
end_candidates = []
for slot in slots:
start_dt = ScheduleProfile._next_weekday_time(now, slot.start_weekday, slot.start_time)
end_dt = ScheduleProfile._next_weekday_time(now, slot.end_weekday, slot.end_time)
start_candidates.append(start_dt)
end_candidates.append(end_dt)
return {
'enable': min(start_candidates) if start_candidates else None,
'disable': min(end_candidates) if end_candidates else None,
}
class ScheduleSlot(models.Model):
profile = models.ForeignKey(ScheduleProfile, on_delete=models.CASCADE, related_name="time_interval")