task.py 1.4 KB

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