controller_base.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package v1
  2. import (
  3. "net/http"
  4. "github.com/allanpk716/ChineseSubFinder/pkg/types/backend"
  5. "github.com/allanpk716/ChineseSubFinder/pkg/lock"
  6. "github.com/allanpk716/ChineseSubFinder/pkg/logic/cron_helper"
  7. "github.com/allanpk716/ChineseSubFinder/pkg/sub_formatter"
  8. "github.com/allanpk716/ChineseSubFinder/pkg/video_scan_and_refresh_helper"
  9. "github.com/gin-gonic/gin"
  10. "github.com/sirupsen/logrus"
  11. )
  12. type ControllerBase struct {
  13. log *logrus.Logger
  14. cronHelper *cron_helper.CronHelper
  15. pathUrlMap map[string]string
  16. videoScanAndRefreshHelper *video_scan_and_refresh_helper.VideoScanAndRefreshHelper
  17. videoScanAndRefreshHelperIsRunning bool
  18. videoScanAndRefreshHelperLocker lock.Lock
  19. videoScanAndRefreshHelperErrMessage string
  20. }
  21. func NewControllerBase(log *logrus.Logger, cronHelper *cron_helper.CronHelper) *ControllerBase {
  22. cb := &ControllerBase{
  23. log: log,
  24. cronHelper: cronHelper,
  25. pathUrlMap: make(map[string]string),
  26. // 这里因为不进行任务的添加,仅仅是扫描,所以 downloadQueue 可以为 nil
  27. videoScanAndRefreshHelper: video_scan_and_refresh_helper.NewVideoScanAndRefreshHelper(
  28. sub_formatter.GetSubFormatter(log, cronHelper.Settings.AdvancedSettings.SubNameFormatter),
  29. cronHelper.FileDownloader, nil),
  30. videoScanAndRefreshHelperLocker: lock.NewLock(),
  31. }
  32. return cb
  33. }
  34. func (cb ControllerBase) SetPathUrlMapItem(path string, url string) {
  35. cb.pathUrlMap[path] = url
  36. }
  37. // GetPathUrlMap x://电影 -- /movie_dir_0 or x://电视剧 -- /series_dir_0
  38. func (cb *ControllerBase) GetPathUrlMap() map[string]string {
  39. return cb.pathUrlMap
  40. }
  41. func (cb *ControllerBase) Close() {
  42. cb.cronHelper.Stop()
  43. cb.videoScanAndRefreshHelper.Cancel()
  44. cb.videoScanAndRefreshHelperLocker.Close()
  45. }
  46. func (cb ControllerBase) GetVersion() string {
  47. return "v1"
  48. }
  49. func (cb *ControllerBase) ErrorProcess(c *gin.Context, funcName string, err error) {
  50. if err != nil {
  51. cb.log.Errorln(funcName, err.Error())
  52. c.JSON(http.StatusInternalServerError, backend.ReplyCommon{Message: err.Error()})
  53. }
  54. }