| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 |
- package v1
- import (
- "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_folder"
- "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_util"
- "github.com/allanpk716/ChineseSubFinder/internal/pkg/strcut_json"
- "github.com/allanpk716/ChineseSubFinder/internal/pkg/video_scan_and_refresh_helper"
- "github.com/allanpk716/ChineseSubFinder/internal/types/backend"
- "github.com/allanpk716/ChineseSubFinder/internal/types/common"
- TTaskqueue "github.com/allanpk716/ChineseSubFinder/internal/types/task_queue"
- "github.com/gin-gonic/gin"
- "net/http"
- "path/filepath"
- )
- func (cb *ControllerBase) RefreshVideoListStatusHandler(c *gin.Context) {
- var err error
- defer func() {
- // 统一的异常处理
- cb.ErrorProcess(c, "RefreshVideoListStatusHandler", err)
- }()
- status := "running"
- if cb.videoScanAndRefreshHelperIsRunning == false {
- status = "stopped"
- }
- c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
- Status: status,
- ErrMessage: cb.videoScanAndRefreshHelperErrMessage})
- return
- }
- func (cb *ControllerBase) RefreshVideoListHandler(c *gin.Context) {
- var err error
- defer func() {
- // 统一的异常处理
- cb.ErrorProcess(c, "RefreshVideoListHandler", err)
- }()
- if cb.videoScanAndRefreshHelperLocker.Lock() == false {
- // 已经在执行,跳过
- c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
- Status: "running"})
- return
- }
- cb.videoScanAndRefreshHelper.NeedForcedScanAndDownSub = true
- cb.videoScanAndRefreshHelperIsRunning = true
- go func() {
- defer func() {
- cb.videoScanAndRefreshHelperIsRunning = false
- cb.videoScanAndRefreshHelperLocker.Unlock()
- cb.log.Infoln("Video Scan End By webui")
- cb.log.Infoln("------------------------------------")
- }()
- cb.log.Infoln("------------------------------------")
- cb.log.Infoln("Video Scan Started By webui...")
- // 先进行扫描
- var err2 error
- var scanVideoResult *video_scan_and_refresh_helper.ScanVideoResult
- cb.videoScanAndRefreshHelperErrMessage = ""
- scanVideoResult, err2 = cb.videoScanAndRefreshHelper.ScanNormalMovieAndSeries()
- if err2 != nil {
- cb.log.Errorln("ScanNormalMovieAndSeries", err2)
- cb.videoScanAndRefreshHelperErrMessage = err2.Error()
- return
- }
- err2 = cb.videoScanAndRefreshHelper.ScanEmbyMovieAndSeries(scanVideoResult)
- if err2 != nil {
- cb.log.Errorln("ScanEmbyMovieAndSeries", err2)
- cb.videoScanAndRefreshHelperErrMessage = err2.Error()
- return
- }
- pathUrlMap := cb.StaticFileSystemBackEnd.GetPathUrlMap()
- cb.MovieInfos = make([]backend.MovieInfo, 0)
- cb.SeasonInfos = make([]backend.SeasonInfo, 0)
- MovieInfos, SeasonInfos := cb.videoScanAndRefreshHelper.ScrabbleUpVideoList(scanVideoResult, pathUrlMap)
- cb.MovieInfos = append(cb.MovieInfos, MovieInfos...)
- cb.SeasonInfos = append(cb.SeasonInfos, SeasonInfos...)
- // 缓存到本地
- err = cb.saveVideoListCache()
- if err != nil {
- cb.log.Errorln("saveVideoListCache", err)
- return
- }
- }()
- c.JSON(http.StatusOK, backend.ReplyRefreshVideoList{
- Status: "running"})
- return
- }
- func (cb *ControllerBase) VideoListAddHandler(c *gin.Context) {
- var err error
- defer func() {
- // 统一的异常处理
- cb.ErrorProcess(c, "VideoListAddHandler", err)
- }()
- videoListAdd := backend.ReqVideoListAdd{}
- err = c.ShouldBindJSON(&videoListAdd)
- if err != nil {
- return
- }
- videoType := common.Movie
- if videoListAdd.VideoType == 1 {
- videoType = common.Series
- }
- bok, err := cb.cronHelper.DownloadQueue.Add(*TTaskqueue.NewOneJob(
- videoType, videoListAdd.PhysicalVideoFileFullPath, videoListAdd.TaskPriorityLevel,
- videoListAdd.MediaServerInsideVideoID,
- ))
- if err != nil {
- return
- }
- if bok == false {
- c.JSON(http.StatusOK, backend.ReplyCommon{
- Message: "job is already in queue",
- })
- } else {
- c.JSON(http.StatusOK, backend.ReplyCommon{
- Message: "ok",
- })
- }
- }
- func (cb *ControllerBase) VideoListHandler(c *gin.Context) {
- var err error
- defer func() {
- // 统一的异常处理
- cb.ErrorProcess(c, "VideoListHandler", err)
- }()
- c.JSON(http.StatusOK, backend.ReplyVideoList{
- MovieInfos: cb.MovieInfos,
- SeasonInfos: cb.SeasonInfos,
- })
- }
- func (cb *ControllerBase) saveVideoListCache() error {
- // 缓存下来
- cacheCenterFolder, err := my_folder.GetRootCacheCenterFolder()
- if err != nil {
- return err
- }
- movieInfosFileName := filepath.Join(cacheCenterFolder, "movie_infos.json")
- seasonInfosFileName := filepath.Join(cacheCenterFolder, "season_infos.json")
- err = strcut_json.ToFile(movieInfosFileName, cb.MovieInfos)
- if err != nil {
- return err
- }
- err = strcut_json.ToFile(seasonInfosFileName, cb.SeasonInfos)
- if err != nil {
- return err
- }
- return nil
- }
- func (cb *ControllerBase) loadVideoListCache() error {
- // 缓存下来
- cacheCenterFolder, err := my_folder.GetRootCacheCenterFolder()
- if err != nil {
- return err
- }
- movieInfosFileName := filepath.Join(cacheCenterFolder, "movie_infos.json")
- seasonInfosFileName := filepath.Join(cacheCenterFolder, "season_infos.json")
- if my_util.IsFile(movieInfosFileName) == true {
- err = strcut_json.ToStruct(movieInfosFileName, &cb.MovieInfos)
- if err != nil {
- return err
- }
- }
- if my_util.IsFile(seasonInfosFileName) == true {
- err = strcut_json.ToStruct(seasonInfosFileName, &cb.SeasonInfos)
- if err != nil {
- return err
- }
- }
- return nil
- }
|