video_list.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package v1
  2. import (
  3. "github.com/allanpk716/ChineseSubFinder/internal/pkg/video_scan_and_refresh_helper"
  4. "github.com/allanpk716/ChineseSubFinder/internal/types/backend"
  5. "github.com/allanpk716/ChineseSubFinder/internal/types/common"
  6. TTaskqueue "github.com/allanpk716/ChineseSubFinder/internal/types/task_queue"
  7. "github.com/gin-gonic/gin"
  8. "net/http"
  9. )
  10. func (cb *ControllerBase) RefreshVideoListStatusHandler(c *gin.Context) {
  11. var err error
  12. defer func() {
  13. // 统一的异常处理
  14. cb.ErrorProcess(c, "RefreshVideoListStatusHandler", err)
  15. }()
  16. status := "running"
  17. if cb.videoScanAndRefreshHelperIsRunning == false {
  18. status = "stopped"
  19. }
  20. c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
  21. Status: status,
  22. ErrMessage: cb.videoScanAndRefreshHelperErrMessage})
  23. return
  24. }
  25. func (cb *ControllerBase) RefreshVideoListHandler(c *gin.Context) {
  26. var err error
  27. defer func() {
  28. // 统一的异常处理
  29. cb.ErrorProcess(c, "RefreshVideoListHandler", err)
  30. }()
  31. if cb.videoScanAndRefreshHelperLocker.Lock() == false {
  32. // 已经在执行,跳过
  33. c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
  34. Status: "running"})
  35. return
  36. }
  37. cb.videoScanAndRefreshHelper.NeedForcedScanAndDownSub = true
  38. cb.videoScanAndRefreshHelperIsRunning = true
  39. go func() {
  40. defer func() {
  41. cb.videoScanAndRefreshHelperIsRunning = false
  42. cb.videoScanAndRefreshHelperLocker.Unlock()
  43. cb.log.Infoln("Video Scan End By webui")
  44. cb.log.Infoln("------------------------------------")
  45. }()
  46. cb.log.Infoln("------------------------------------")
  47. cb.log.Infoln("Video Scan Started By webui...")
  48. // 先进行扫描
  49. var err2 error
  50. var scanVideoResult *video_scan_and_refresh_helper.ScanVideoResult
  51. cb.videoScanAndRefreshHelperErrMessage = ""
  52. scanVideoResult, err2 = cb.videoScanAndRefreshHelper.ScanNormalMovieAndSeries()
  53. if err2 != nil {
  54. cb.log.Errorln("ScanNormalMovieAndSeries", err2)
  55. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  56. return
  57. }
  58. err2 = cb.videoScanAndRefreshHelper.ScanEmbyMovieAndSeries(scanVideoResult)
  59. if err2 != nil {
  60. cb.log.Errorln("ScanEmbyMovieAndSeries", err2)
  61. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  62. return
  63. }
  64. pathUrlMap := cb.StaticFileSystemBackEnd.GetPathUrlMap()
  65. MovieInfos, SeasonInfos := cb.videoScanAndRefreshHelper.ScrabbleUpVideoList(scanVideoResult, pathUrlMap)
  66. // 缓存视频列表
  67. cb.cronHelper.SetMovieAndSeasonInfo(MovieInfos, SeasonInfos)
  68. }()
  69. c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
  70. Status: "running"})
  71. return
  72. }
  73. func (cb *ControllerBase) VideoListAddHandler(c *gin.Context) {
  74. var err error
  75. defer func() {
  76. // 统一的异常处理
  77. cb.ErrorProcess(c, "VideoListAddHandler", err)
  78. }()
  79. videoListAdd := backend.ReqVideoListAdd{}
  80. err = c.ShouldBindJSON(&videoListAdd)
  81. if err != nil {
  82. return
  83. }
  84. videoType := common.Movie
  85. if videoListAdd.VideoType == 1 {
  86. videoType = common.Series
  87. }
  88. bok, err := cb.cronHelper.DownloadQueue.Add(*TTaskqueue.NewOneJob(
  89. videoType, videoListAdd.PhysicalVideoFileFullPath, videoListAdd.TaskPriorityLevel,
  90. videoListAdd.MediaServerInsideVideoID,
  91. ))
  92. if err != nil {
  93. return
  94. }
  95. if bok == false {
  96. c.JSON(http.StatusOK, backend.ReplyCommon{
  97. Message: "job is already in queue",
  98. })
  99. } else {
  100. c.JSON(http.StatusOK, backend.ReplyCommon{
  101. Message: "ok",
  102. })
  103. }
  104. }
  105. func (cb *ControllerBase) VideoListHandler(c *gin.Context) {
  106. var err error
  107. defer func() {
  108. // 统一的异常处理
  109. cb.ErrorProcess(c, "VideoListHandler", err)
  110. }()
  111. outMovieInfos, outSeasonInfo := cb.cronHelper.GetMovieInfoAndSeasonInfo()
  112. c.JSON(http.StatusOK, backend.ReplyVideoList{
  113. MovieInfos: outMovieInfos,
  114. SeasonInfos: outSeasonInfo,
  115. })
  116. }