video_list.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. package v1
  2. import (
  3. "errors"
  4. "fmt"
  5. "net/http"
  6. "time"
  7. "github.com/allanpk716/ChineseSubFinder/internal/types/backend"
  8. "github.com/allanpk716/ChineseSubFinder/internal/types/common"
  9. TTaskqueue "github.com/allanpk716/ChineseSubFinder/internal/types/task_queue"
  10. "github.com/allanpk716/ChineseSubFinder/pkg/decode"
  11. "github.com/allanpk716/ChineseSubFinder/pkg/video_scan_and_refresh_helper"
  12. "github.com/gin-gonic/gin"
  13. )
  14. func (cb *ControllerBase) RefreshVideoListStatusHandler(c *gin.Context) {
  15. var err error
  16. defer func() {
  17. // 统一的异常处理
  18. cb.ErrorProcess(c, "RefreshVideoListStatusHandler", err)
  19. }()
  20. status := "running"
  21. if cb.videoScanAndRefreshHelperIsRunning == false {
  22. status = "stopped"
  23. }
  24. c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
  25. Status: status,
  26. ErrMessage: cb.videoScanAndRefreshHelperErrMessage})
  27. return
  28. }
  29. func (cb *ControllerBase) RefreshVideoListHandler(c *gin.Context) {
  30. var err error
  31. defer func() {
  32. // 统一的异常处理
  33. cb.ErrorProcess(c, "RefreshVideoListHandler", err)
  34. }()
  35. if cb.videoScanAndRefreshHelperLocker.Lock() == false {
  36. // 已经在执行,跳过
  37. c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
  38. Status: "running"})
  39. return
  40. }
  41. cb.videoScanAndRefreshHelper.NeedForcedScanAndDownSub = true
  42. cb.videoScanAndRefreshHelperIsRunning = true
  43. go func() {
  44. startT := time.Now()
  45. cb.log.Infoln("------------------------------------")
  46. cb.log.Infoln("Video Scan Started By webui...")
  47. defer func() {
  48. cb.videoScanAndRefreshHelperIsRunning = false
  49. cb.videoScanAndRefreshHelperLocker.Unlock()
  50. cb.log.Infoln("Video Scan Finished By webui, cost:", time.Since(startT).Minutes(), "min")
  51. cb.log.Infoln("------------------------------------")
  52. }()
  53. // 先进行扫描
  54. var err2 error
  55. var scanVideoResult *video_scan_and_refresh_helper.ScanVideoResult
  56. cb.videoScanAndRefreshHelperErrMessage = ""
  57. scanVideoResult, err2 = cb.videoScanAndRefreshHelper.ScanNormalMovieAndSeries()
  58. if err2 != nil {
  59. cb.log.Errorln("ScanNormalMovieAndSeries", err2)
  60. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  61. return
  62. }
  63. err2 = cb.videoScanAndRefreshHelper.ScanEmbyMovieAndSeries(scanVideoResult)
  64. if err2 != nil {
  65. cb.log.Errorln("ScanEmbyMovieAndSeries", err2)
  66. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  67. return
  68. }
  69. pathUrlMap := cb.StaticFileSystemBackEnd.GetPathUrlMap()
  70. MovieInfos, SeasonInfos := cb.videoScanAndRefreshHelper.ScrabbleUpVideoList(scanVideoResult, pathUrlMap)
  71. // 缓存视频列表
  72. cb.cronHelper.Downloader.SetMovieAndSeasonInfo(MovieInfos, SeasonInfos)
  73. }()
  74. c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
  75. Status: "running"})
  76. return
  77. }
  78. func (cb *ControllerBase) VideoListAddHandler(c *gin.Context) {
  79. var err error
  80. defer func() {
  81. // 统一的异常处理
  82. cb.ErrorProcess(c, "VideoListAddHandler", err)
  83. }()
  84. videoListAdd := backend.ReqVideoListAdd{}
  85. err = c.ShouldBindJSON(&videoListAdd)
  86. if err != nil {
  87. return
  88. }
  89. videoType := common.Movie
  90. if videoListAdd.VideoType == 1 {
  91. videoType = common.Series
  92. }
  93. oneJob := TTaskqueue.NewOneJob(
  94. videoType, videoListAdd.PhysicalVideoFileFullPath, videoListAdd.TaskPriorityLevel,
  95. videoListAdd.MediaServerInsideVideoID,
  96. )
  97. if videoType == common.Series {
  98. // 如果是连续剧,需要额外的读取这一个剧集的信息
  99. epsVideoNfoInfo, err := decode.GetVideoNfoInfo4OneSeriesEpisode(videoListAdd.PhysicalVideoFileFullPath)
  100. if err != nil {
  101. return
  102. }
  103. seriesInfoDirPath := decode.GetSeriesDirRootFPath(videoListAdd.PhysicalVideoFileFullPath)
  104. if seriesInfoDirPath == "" {
  105. err = errors.New(fmt.Sprintf("decode.GetSeriesDirRootFPath == Empty, %s", videoListAdd.PhysicalVideoFileFullPath))
  106. return
  107. }
  108. oneJob.Season = epsVideoNfoInfo.Season
  109. oneJob.Episode = epsVideoNfoInfo.Episode
  110. oneJob.SeriesRootDirPath = seriesInfoDirPath
  111. }
  112. bok, err := cb.cronHelper.DownloadQueue.Add(*oneJob)
  113. if err != nil {
  114. return
  115. }
  116. if bok == false {
  117. // 任务已经存在
  118. bok, err = cb.cronHelper.DownloadQueue.Update(*oneJob)
  119. if err != nil {
  120. return
  121. }
  122. if bok == false {
  123. c.JSON(http.StatusOK, backend.ReplyJobThings{
  124. JobID: oneJob.Id,
  125. Message: "update job status failed",
  126. })
  127. return
  128. }
  129. }
  130. c.JSON(http.StatusOK, backend.ReplyJobThings{
  131. JobID: oneJob.Id,
  132. Message: "ok",
  133. })
  134. }
  135. func (cb *ControllerBase) VideoListHandler(c *gin.Context) {
  136. var err error
  137. defer func() {
  138. // 统一的异常处理
  139. cb.ErrorProcess(c, "VideoListHandler", err)
  140. }()
  141. outMovieInfos, outSeasonInfo := cb.cronHelper.Downloader.GetMovieInfoAndSeasonInfo()
  142. c.JSON(http.StatusOK, backend.ReplyVideoList{
  143. MovieInfos: outMovieInfos,
  144. SeasonInfos: outSeasonInfo,
  145. })
  146. }