video_list.go 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. package v1
  2. import (
  3. "errors"
  4. "fmt"
  5. "net/http"
  6. "time"
  7. backend2 "github.com/allanpk716/ChineseSubFinder/pkg/types/backend"
  8. "github.com/allanpk716/ChineseSubFinder/pkg/types/common"
  9. TTaskqueue "github.com/allanpk716/ChineseSubFinder/pkg/types/task_queue"
  10. vsh "github.com/allanpk716/ChineseSubFinder/pkg/video_scan_and_refresh_helper"
  11. "github.com/allanpk716/ChineseSubFinder/pkg/decode"
  12. "github.com/allanpk716/ChineseSubFinder/pkg/video_scan_and_refresh_helper"
  13. "github.com/gin-gonic/gin"
  14. )
  15. func (cb *ControllerBase) RefreshVideoListStatusHandler(c *gin.Context) {
  16. var err error
  17. defer func() {
  18. // 统一的异常处理
  19. cb.ErrorProcess(c, "RefreshVideoListStatusHandler", err)
  20. }()
  21. status := "running"
  22. if cb.videoScanAndRefreshHelperIsRunning == false {
  23. status = "stopped"
  24. }
  25. c.JSON(http.StatusOK, backend2.ReplyRefreshVideoList{
  26. Status: status,
  27. ErrMessage: cb.videoScanAndRefreshHelperErrMessage})
  28. return
  29. }
  30. func (cb *ControllerBase) RefreshVideoListHandler(c *gin.Context) {
  31. var err error
  32. defer func() {
  33. // 统一的异常处理
  34. cb.ErrorProcess(c, "RefreshVideoListHandler", err)
  35. }()
  36. if cb.videoScanAndRefreshHelperLocker.Lock() == false {
  37. // 已经在执行,跳过
  38. c.JSON(http.StatusOK, backend2.ReplyRefreshVideoList{
  39. Status: "running"})
  40. return
  41. }
  42. cb.videoScanAndRefreshHelper.NeedForcedScanAndDownSub = true
  43. cb.videoScanAndRefreshHelperIsRunning = true
  44. go func() {
  45. startT := time.Now()
  46. cb.log.Infoln("------------------------------------")
  47. cb.log.Infoln("Video Scan Started By webui...")
  48. pathUrlMap := cb.GetPathUrlMap()
  49. cb.log.Infoln("---------------------------------")
  50. cb.log.Infoln("GetPathUrlMap")
  51. for s, s2 := range pathUrlMap {
  52. cb.log.Infoln("pathUrlMap", s, s2)
  53. }
  54. cb.log.Infoln("---------------------------------")
  55. defer func() {
  56. cb.videoScanAndRefreshHelperIsRunning = false
  57. cb.videoScanAndRefreshHelperLocker.Unlock()
  58. cb.log.Infoln("Video Scan Finished By webui, cost:", time.Since(startT).Minutes(), "min")
  59. cb.log.Infoln("------------------------------------")
  60. }()
  61. // 先进行扫描
  62. var err2 error
  63. var scanVideoResult *video_scan_and_refresh_helper.ScanVideoResult
  64. cb.videoScanAndRefreshHelperErrMessage = ""
  65. scanVideoResult, err2 = cb.videoScanAndRefreshHelper.ScanNormalMovieAndSeries()
  66. if err2 != nil {
  67. cb.log.Errorln("ScanNormalMovieAndSeries", err2)
  68. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  69. return
  70. }
  71. err2 = cb.videoScanAndRefreshHelper.ScanEmbyMovieAndSeries(scanVideoResult)
  72. if err2 != nil {
  73. cb.log.Errorln("ScanEmbyMovieAndSeries", err2)
  74. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  75. return
  76. }
  77. MovieInfos, SeasonInfos := cb.videoScanAndRefreshHelper.ScrabbleUpVideoList(scanVideoResult, pathUrlMap)
  78. cb.log.Debugln("---------------------------------")
  79. for i, i2 := range MovieInfos {
  80. cb.log.Debugln("MovieInfos", i, i2.VideoFPath)
  81. }
  82. cb.log.Debugln("---------------------------------")
  83. for i, seasonInfo := range SeasonInfos {
  84. cb.log.Debugln("SeasonInfos.RootDirPath", i, seasonInfo.RootDirPath)
  85. for i2, i3 := range seasonInfo.OneVideoInfos {
  86. cb.log.Debugln("SeasonInfos.SeasonInfos", i2, i3.VideoFPath)
  87. }
  88. }
  89. cb.log.Debugln("---------------------------------")
  90. // 缓存视频列表
  91. cb.cronHelper.Downloader.SetMovieAndSeasonInfo(MovieInfos, SeasonInfos)
  92. }()
  93. c.JSON(http.StatusOK, backend2.ReplyRefreshVideoList{
  94. Status: "running"})
  95. return
  96. }
  97. func (cb *ControllerBase) VideoListAddHandler(c *gin.Context) {
  98. var err error
  99. defer func() {
  100. // 统一的异常处理
  101. cb.ErrorProcess(c, "VideoListAddHandler", err)
  102. }()
  103. videoListAdd := backend2.ReqVideoListAdd{}
  104. err = c.ShouldBindJSON(&videoListAdd)
  105. if err != nil {
  106. return
  107. }
  108. videoType := common.Movie
  109. if videoListAdd.VideoType == 1 {
  110. videoType = common.Series
  111. }
  112. oneJob := TTaskqueue.NewOneJob(
  113. videoType, videoListAdd.PhysicalVideoFileFullPath, videoListAdd.TaskPriorityLevel,
  114. videoListAdd.MediaServerInsideVideoID,
  115. )
  116. if videoType == common.Series {
  117. // 如果是连续剧,需要额外的读取这一个剧集的信息
  118. epsVideoNfoInfo, err := decode.GetVideoNfoInfo4OneSeriesEpisode(videoListAdd.PhysicalVideoFileFullPath)
  119. if err != nil {
  120. return
  121. }
  122. seriesInfoDirPath := decode.GetSeriesDirRootFPath(videoListAdd.PhysicalVideoFileFullPath)
  123. if seriesInfoDirPath == "" {
  124. err = errors.New(fmt.Sprintf("decode.GetSeriesDirRootFPath == Empty, %s", videoListAdd.PhysicalVideoFileFullPath))
  125. return
  126. }
  127. oneJob.Season = epsVideoNfoInfo.Season
  128. oneJob.Episode = epsVideoNfoInfo.Episode
  129. oneJob.SeriesRootDirPath = seriesInfoDirPath
  130. }
  131. bok, err := cb.cronHelper.DownloadQueue.Add(*oneJob)
  132. if err != nil {
  133. return
  134. }
  135. if bok == false {
  136. // 任务已经存在
  137. bok, err = cb.cronHelper.DownloadQueue.Update(*oneJob)
  138. if err != nil {
  139. return
  140. }
  141. if bok == false {
  142. c.JSON(http.StatusOK, backend2.ReplyJobThings{
  143. JobID: oneJob.Id,
  144. Message: "update job status failed",
  145. })
  146. return
  147. }
  148. }
  149. c.JSON(http.StatusOK, backend2.ReplyJobThings{
  150. JobID: oneJob.Id,
  151. Message: "ok",
  152. })
  153. }
  154. func (cb *ControllerBase) VideoListHandler(c *gin.Context) {
  155. var err error
  156. defer func() {
  157. // 统一的异常处理
  158. cb.ErrorProcess(c, "VideoListHandler", err)
  159. }()
  160. outMovieInfos, outSeasonInfo := cb.cronHelper.Downloader.GetMovieInfoAndSeasonInfo()
  161. c.JSON(http.StatusOK, backend2.ReplyVideoList{
  162. MovieInfos: outMovieInfos,
  163. SeasonInfos: outSeasonInfo,
  164. })
  165. }
  166. func (cb *ControllerBase) RefreshMainList(c *gin.Context) {
  167. var err error
  168. defer func() {
  169. // 统一的异常处理
  170. cb.ErrorProcess(c, "RefreshMainList", err)
  171. }()
  172. if cb.videoScanAndRefreshHelperLocker.Lock() == false {
  173. // 已经在执行,跳过
  174. c.JSON(http.StatusOK, backend2.ReplyRefreshVideoList{
  175. Status: "running"})
  176. return
  177. }
  178. cb.videoScanAndRefreshHelperIsRunning = true
  179. go func() {
  180. startT := time.Now()
  181. cb.log.Infoln("------------------------------------")
  182. cb.log.Infoln("Video Scan Started By webui...")
  183. pathUrlMap := cb.GetPathUrlMap()
  184. cb.log.Infoln("---------------------------------")
  185. cb.log.Infoln("GetPathUrlMap")
  186. for s, s2 := range pathUrlMap {
  187. cb.log.Infoln("pathUrlMap", s, s2)
  188. }
  189. cb.log.Infoln("---------------------------------")
  190. defer func() {
  191. cb.videoScanAndRefreshHelperIsRunning = false
  192. cb.videoScanAndRefreshHelperLocker.Unlock()
  193. cb.log.Infoln("Video Scan Finished By webui, cost:", time.Since(startT).Minutes(), "min")
  194. cb.log.Infoln("------------------------------------")
  195. }()
  196. var err2 error
  197. cb.videoScanAndRefreshHelperErrMessage = ""
  198. var mainList *vsh.NormalScanVideoResult
  199. mainList, err2 = cb.videoListHelper.RefreshMainList()
  200. if err2 != nil {
  201. cb.log.Errorln("RefreshMainList", err2)
  202. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  203. return
  204. }
  205. err2 = cb.cronHelper.Downloader.SetMovieAndSeasonInfoV2(mainList)
  206. if err2 != nil {
  207. cb.log.Errorln("SetMovieAndSeasonInfoV2", err2)
  208. cb.videoScanAndRefreshHelperErrMessage = err2.Error()
  209. return
  210. }
  211. }()
  212. c.JSON(http.StatusOK, backend2.ReplyRefreshVideoList{
  213. Status: "running"})
  214. return
  215. }