models.py 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. from datetime import datetime
  2. import sqlalchemy as sa
  3. from celery import states
  4. from celery.db.session import ResultModelBase
  5. # See docstring of a805d4bd for an explanation for this workaround ;)
  6. if sa.__version__.startswith('0.5'):
  7. from celery.db.dfd042c7 import PickleType
  8. else:
  9. from celery.db.a805d4bd import PickleType
  10. class Task(ResultModelBase):
  11. """Task result/status."""
  12. __tablename__ = "celery_taskmeta"
  13. __table_args__ = {"sqlite_autoincrement": True}
  14. id = sa.Column(sa.Integer, sa.Sequence("task_id_sequence"),
  15. primary_key=True,
  16. autoincrement=True)
  17. task_id = sa.Column(sa.String(255))
  18. status = sa.Column(sa.String(50), default=states.PENDING)
  19. result = sa.Column(PickleType, nullable=True)
  20. date_done = sa.Column(sa.DateTime, default=datetime.now,
  21. onupdate=datetime.now, nullable=True)
  22. traceback = sa.Column(sa.Text, nullable=True)
  23. def __init__(self, task_id):
  24. self.task_id = task_id
  25. def to_dict(self):
  26. return {"task_id": self.task_id,
  27. "status": self.status,
  28. "result": self.result,
  29. "traceback": self.traceback}
  30. def __repr__(self):
  31. return "<Task %s state: %s>" % (self.task_id, self.status)
  32. class TaskSet(ResultModelBase):
  33. """TaskSet result"""
  34. __tablename__ = "celery_tasksetmeta"
  35. __table_args__ = {"sqlite_autoincrement": True}
  36. id = sa.Column(sa.Integer, sa.Sequence("taskset_id_sequence"),
  37. autoincrement=True, primary_key=True)
  38. taskset_id = sa.Column(sa.String(255))
  39. result = sa.Column(sa.PickleType, nullable=True)
  40. date_done = sa.Column(sa.DateTime, default=datetime.now,
  41. nullable=True)
  42. def __init__(self, taskset_id, result):
  43. self.taskset_id = taskset_id
  44. self.result = result
  45. def to_dict(self):
  46. return {"taskset_id": self.taskset_id,
  47. "result": self.result}
  48. def __repr__(self):
  49. return u"<TaskSet: %s>" % (self.taskset_id, )