video_list.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. package v1
  2. import (
  3. "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_folder"
  4. "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_util"
  5. "github.com/allanpk716/ChineseSubFinder/internal/pkg/strcut_json"
  6. "github.com/allanpk716/ChineseSubFinder/internal/pkg/video_scan_and_refresh_helper"
  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/gin-gonic/gin"
  11. "net/http"
  12. "path/filepath"
  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. defer func() {
  45. cb.videoScanAndRefreshHelperIsRunning = false
  46. cb.videoScanAndRefreshHelperLocker.Unlock()
  47. cb.log.Infoln("Video Scan End By webui")
  48. cb.log.Infoln("------------------------------------")
  49. }()
  50. cb.log.Infoln("------------------------------------")
  51. cb.log.Infoln("Video Scan Started By webui...")
  52. // 先进行扫描
  53. var err2 error
  54. var scanVideoResult *video_scan_and_refresh_helper.ScanVideoResult
  55. cb.videoScanAndRefreshHelperErrMessage = ""
  56. scanVideoResult, err2 = cb.videoScanAndRefreshHelper.ScanNormalMovieAndSeries()
  57. if err2 != nil {
  58. cb.log.Errorln("ScanNormalMovieAndSeries", err2)
  59. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  60. return
  61. }
  62. err2 = cb.videoScanAndRefreshHelper.ScanEmbyMovieAndSeries(scanVideoResult)
  63. if err2 != nil {
  64. cb.log.Errorln("ScanEmbyMovieAndSeries", err2)
  65. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  66. return
  67. }
  68. pathUrlMap := cb.StaticFileSystemBackEnd.GetPathUrlMap()
  69. cb.MovieInfos = make([]backend.MovieInfo, 0)
  70. cb.SeasonInfos = make([]backend.SeasonInfo, 0)
  71. MovieInfos, SeasonInfos := cb.videoScanAndRefreshHelper.ScrabbleUpVideoList(scanVideoResult, pathUrlMap)
  72. cb.MovieInfos = append(cb.MovieInfos, MovieInfos...)
  73. cb.SeasonInfos = append(cb.SeasonInfos, SeasonInfos...)
  74. // 缓存到本地
  75. err = cb.saveVideoListCache()
  76. if err != nil {
  77. cb.log.Errorln("saveVideoListCache", err)
  78. return
  79. }
  80. }()
  81. c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
  82. Status: "running"})
  83. return
  84. }
  85. func (cb *ControllerBase) VideoListAddHandler(c *gin.Context) {
  86. var err error
  87. defer func() {
  88. // 统一的异常处理
  89. cb.ErrorProcess(c, "VideoListAddHandler", err)
  90. }()
  91. videoListAdd := backend.ReqVideoListAdd{}
  92. err = c.ShouldBindJSON(&videoListAdd)
  93. if err != nil {
  94. return
  95. }
  96. videoType := common.Movie
  97. if videoListAdd.VideoType == 1 {
  98. videoType = common.Series
  99. }
  100. bok, err := cb.cronHelper.DownloadQueue.Add(*TTaskqueue.NewOneJob(
  101. videoType, videoListAdd.PhysicalVideoFileFullPath, videoListAdd.TaskPriorityLevel,
  102. videoListAdd.MediaServerInsideVideoID,
  103. ))
  104. if err != nil {
  105. return
  106. }
  107. if bok == false {
  108. c.JSON(http.StatusOK, backend.ReplyCommon{
  109. Message: "job is already in queue",
  110. })
  111. } else {
  112. c.JSON(http.StatusOK, backend.ReplyCommon{
  113. Message: "ok",
  114. })
  115. }
  116. }
  117. func (cb *ControllerBase) VideoListHandler(c *gin.Context) {
  118. var err error
  119. defer func() {
  120. // 统一的异常处理
  121. cb.ErrorProcess(c, "VideoListHandler", err)
  122. }()
  123. c.JSON(http.StatusOK, backend.ReplyVideoList{
  124. MovieInfos: cb.MovieInfos,
  125. SeasonInfos: cb.SeasonInfos,
  126. })
  127. }
  128. func (cb *ControllerBase) saveVideoListCache() error {
  129. // 缓存下来
  130. cacheCenterFolder, err := my_folder.GetRootCacheCenterFolder()
  131. if err != nil {
  132. return err
  133. }
  134. movieInfosFileName := filepath.Join(cacheCenterFolder, "movie_infos.json")
  135. seasonInfosFileName := filepath.Join(cacheCenterFolder, "season_infos.json")
  136. err = strcut_json.ToFile(movieInfosFileName, cb.MovieInfos)
  137. if err != nil {
  138. return err
  139. }
  140. err = strcut_json.ToFile(seasonInfosFileName, cb.SeasonInfos)
  141. if err != nil {
  142. return err
  143. }
  144. return nil
  145. }
  146. func (cb *ControllerBase) loadVideoListCache() error {
  147. // 缓存下来
  148. cacheCenterFolder, err := my_folder.GetRootCacheCenterFolder()
  149. if err != nil {
  150. return err
  151. }
  152. movieInfosFileName := filepath.Join(cacheCenterFolder, "movie_infos.json")
  153. seasonInfosFileName := filepath.Join(cacheCenterFolder, "season_infos.json")
  154. if my_util.IsFile(movieInfosFileName) == true {
  155. err = strcut_json.ToStruct(movieInfosFileName, &cb.MovieInfos)
  156. if err != nil {
  157. return err
  158. }
  159. }
  160. if my_util.IsFile(seasonInfosFileName) == true {
  161. err = strcut_json.ToStruct(seasonInfosFileName, &cb.SeasonInfos)
  162. if err != nil {
  163. return err
  164. }
  165. }
  166. return nil
  167. }