task.py 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. from datetime import datetime, timezone
  2. from celery import states
  3. from extensions.ext_database import db
  4. class CeleryTask(db.Model):
  5. """Task result/status."""
  6. __tablename__ = "celery_taskmeta"
  7. id = db.Column(db.Integer, db.Sequence("task_id_sequence"), primary_key=True, autoincrement=True)
  8. task_id = db.Column(db.String(155), unique=True)
  9. status = db.Column(db.String(50), default=states.PENDING)
  10. result = db.Column(db.PickleType, nullable=True)
  11. date_done = db.Column(
  12. db.DateTime,
  13. default=lambda: datetime.now(timezone.utc).replace(tzinfo=None),
  14. onupdate=lambda: datetime.now(timezone.utc).replace(tzinfo=None),
  15. nullable=True,
  16. )
  17. traceback = db.Column(db.Text, nullable=True)
  18. name = db.Column(db.String(155), nullable=True)
  19. args = db.Column(db.LargeBinary, nullable=True)
  20. kwargs = db.Column(db.LargeBinary, nullable=True)
  21. worker = db.Column(db.String(155), nullable=True)
  22. retries = db.Column(db.Integer, nullable=True)
  23. queue = db.Column(db.String(155), nullable=True)
  24. class CeleryTaskSet(db.Model):
  25. """TaskSet result."""
  26. __tablename__ = "celery_tasksetmeta"
  27. id = db.Column(db.Integer, db.Sequence("taskset_id_sequence"), autoincrement=True, primary_key=True)
  28. taskset_id = db.Column(db.String(155), unique=True)
  29. result = db.Column(db.PickleType, nullable=True)
  30. date_done = db.Column(db.DateTime, default=lambda: datetime.now(timezone.utc).replace(tzinfo=None), nullable=True)