# -*- coding: utf-8 -*- # import uuid import os from django.utils.translation import gettext_lazy as _ from django.conf import settings from django.db import models from ops.celery import app class CeleryTask(models.Model): id = models.UUIDField(primary_key=True, default=uuid.uuid4) name = models.CharField(max_length=1024) last_published_time = models.DateTimeField(null=True) @property def meta(self): task = app.tasks.get(self.name, None) return { "verbose_name": getattr(task, 'verbose_name', None), "comment": getattr(task, 'comment', None), "queue": getattr(task, 'queue', 'default') } @property def state(self): last_five_executions = CeleryTaskExecution.objects.filter(name=self.name).order_by('-date_published')[:5] if len(last_five_executions) > 0: if last_five_executions[0].state == 'FAILURE': return "red" for execution in last_five_executions: if execution.state == 'FAILURE': return "yellow" return "green" class CeleryTaskExecution(models.Model): LOG_DIR = os.path.join(settings.PROJECT_DIR, 'data', 'celery') id = models.UUIDField(primary_key=True, default=uuid.uuid4) name = models.CharField(max_length=1024) args = models.JSONField(verbose_name=_("Args")) kwargs = models.JSONField(verbose_name=_("Kwargs")) state = models.CharField(max_length=16, verbose_name=_("State")) is_finished = models.BooleanField(default=False, verbose_name=_("Finished")) date_published = models.DateTimeField(auto_now_add=True) date_start = models.DateTimeField(null=True) date_finished = models.DateTimeField(null=True) def __str__(self): return "{}: {}".format(self.name, self.id)