job_info.py 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import time
  2. from typing import List
  3. from app import models, schemas
  4. from sqlalchemy.orm import Session
  5. from app.utils.cron_utils import *
  6. def create_job_info(db: Session, item: schemas.JobInfoCreate):
  7. create_time: int = int(time.time())
  8. item_dict = item.dict()
  9. cron_expression_dict = item_dict.pop('cron_expression')
  10. cron_expression = joint_cron_expression(schemas.CronExpression(**cron_expression_dict))
  11. cron_select_type = cron_expression_dict["cron_select_type"]
  12. item_dict.update({
  13. 'cron_select_type': cron_select_type,
  14. 'job_cron': cron_expression,
  15. })
  16. db_item = models.JobInfo(**item_dict, **{
  17. 'trigger_status': 0,
  18. 'create_time': create_time,
  19. 'update_time': create_time,
  20. 'user_id': 1, # TODO 用户
  21. 'trigger_status': 0,
  22. 'delete_status': 1,
  23. })
  24. db.add(db_item)
  25. db.commit()
  26. db.refresh(db_item)
  27. return db_item
  28. def get_job_infos(db: Session, skip: int = 0, limit: int = 20):
  29. res: List[models.JobInfo] = db.query(models.JobInfo).filter(models.JobInfo.delete_status == 1).all() # TODO: 排序
  30. return res
  31. def update_job_info(db: Session, id: int, update_item: schemas.JobInfoUpdate):
  32. db_item = db.query(models.JobInfo).filter(models.JobInfo.id == id).first()
  33. if not db_item:
  34. raise Exception('未找到该任务')
  35. update_dict = update_item.dict(exclude_unset=True)
  36. for k, v in update_dict.items():
  37. setattr(db_item, k, v)
  38. db_item.update_time = int(time.time())
  39. db.commit()
  40. db.flush()
  41. db.refresh(db_item)
  42. return db_item
  43. def delete_job_info(db: Session, job_id: int):
  44. job_item = db.query(models.JobInfo).filter(models.JobInfo.id == job_id).first()
  45. if not job_item:
  46. raise Exception('未找到该任务')
  47. job_item.delete_status = 0
  48. db.commit()
  49. db.flush()
  50. db.refresh(job_item)
  51. return job_item