video_list.go 4.5 KB

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