programme.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. import time
  2. from typing import List
  3. from app import models, schemas
  4. from sqlalchemy.orm import Session
  5. import app.utils.send_util as send_util
  6. from configs.globals import g
  7. from configs.settings import DefaultOption, config
  8. special_project_id = config.get('PERMISSIONS', 'special_project_id')
  9. namespace = config.get('PROGRAMME', 'namespace')
  10. super_image = config.get('PROGRAMME', 'super_image')
  11. ordinary_image = config.get('PROGRAMME', 'ordinary_image')
  12. tag = config.get('PROGRAMME', 'tag')
  13. host = config.get('PROGRAMME', 'host')
  14. chart = config.get('PROGRAMME', 'chart')
  15. path_type = config.get('PROGRAMME', 'path_type')
  16. def create_programme(db: Session, item: schemas.ProgrammeCreate):
  17. db_item = db.query(models.Programme).filter(models.Programme.project_id == g.project_id).first()
  18. if db_item:
  19. raise Exception("该项目已存在编程,不可重复创建")
  20. p_res = send_util.get_jupyter_password({"password": item.password})
  21. password = p_res['data']
  22. db_item = models.Programme(**{
  23. 'name': item.name,
  24. 'password': password,
  25. 'workspace': f"workspace_{g.project_id}",
  26. 'base_url': f"/nbss_{g.project_id}",
  27. 'image': super_image if g.project_id == special_project_id else ordinary_image,
  28. 'path': f"/nbss_{g.project_id}",
  29. 'release_name': f"aihub-dag-jpt-{g.project_id}",
  30. 'status': 0,
  31. 'user_id': g.user_id,
  32. 'user_name': item.user_name,
  33. 'project_id': g.project_id,
  34. 'create_time': int(time.time())
  35. })
  36. db.add(db_item)
  37. db.commit()
  38. db.refresh(db_item)
  39. return db_item
  40. def start_jupyter(db: Session, item: schemas.ProgrammeId):
  41. db_item: models.Programme = db.query(models.Programme).filter(models.Programme.id == item.programme_id).first()
  42. if not db_item:
  43. raise Exception("未找到该编程")
  44. jupyter_create_data = {
  45. 'password': db_item.password,
  46. 'namespace': namespace,
  47. 'workspace': db_item.workspace,
  48. 'base_url': db_item.base_url,
  49. 'image': db_item.image,
  50. 'tag': tag,
  51. 'path': db_item.path,
  52. 'host': host,
  53. 'release_name': db_item.release_name,
  54. 'chart': chart,
  55. 'path_type': path_type
  56. }
  57. c_res = send_util.create_jupyter(jupyter_create_data)
  58. j_data = c_res['data'] if 'data' in c_res.keys() else None
  59. if not j_data:
  60. send_util.stop_jupyter({'namespace': namespace,'release_name': db_item.release_name})
  61. raise Exception("创建Jupyter失败")
  62. url = f"http://{j_data['host']}{j_data['base_url']}/lab"
  63. db_item.status = 1
  64. db.commit()
  65. db.flush()
  66. db.refresh(db_item)
  67. return url
  68. def stop_jupyter(db: Session, item: schemas.ProgrammeId):
  69. db_item: models.Programme = db.query(models.Programme).filter(models.Programme.id == item.programme_id).first()
  70. if not db_item:
  71. raise Exception("未找到该编程")
  72. send_util.stop_jupyter({'namespace': namespace,'release_name': db_item.release_name})
  73. db_item.status = 0
  74. db.commit()
  75. db.flush()
  76. db.refresh(db_item)
  77. return db_item
  78. def update_jupyter_password(db: Session, item: schemas.ProgrammeUpdate):
  79. db_item: models.Programme = db.query(models.Programme).filter(models.Programme.id == item.programme_id).first()
  80. if not db_item:
  81. raise Exception("未找到该编程")
  82. print()
  83. if db_item.status == 1:
  84. raise Exception("程序正在运行,请先停止再修改密码")
  85. p_res = send_util.get_jupyter_password({"password": item.password})
  86. password = p_res['data']
  87. db_item.password = password
  88. db.commit()
  89. db.flush()
  90. db.refresh(db_item)
  91. return db_item
  92. def get_programme(db: Session):
  93. db_items: List[models.Programme] = db.query(models.Programme).filter(models.Programme.project_id == g.project_id).all()
  94. return db_items