main.go 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. package main
  2. import (
  3. "github.com/allanpk716/ChineseSubFinder/internal"
  4. commonValue "github.com/allanpk716/ChineseSubFinder/internal/common"
  5. config2 "github.com/allanpk716/ChineseSubFinder/internal/pkg/config"
  6. "github.com/allanpk716/ChineseSubFinder/internal/pkg/hot_fix"
  7. "github.com/allanpk716/ChineseSubFinder/internal/pkg/log_helper"
  8. "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_util"
  9. "github.com/allanpk716/ChineseSubFinder/internal/pkg/notify_center"
  10. "github.com/allanpk716/ChineseSubFinder/internal/pkg/proxy_helper"
  11. "github.com/allanpk716/ChineseSubFinder/internal/pkg/sub_formatter"
  12. "github.com/allanpk716/ChineseSubFinder/internal/pkg/sub_formatter/common"
  13. "github.com/allanpk716/ChineseSubFinder/internal/types"
  14. "github.com/robfig/cron/v3"
  15. "github.com/sirupsen/logrus"
  16. )
  17. func init() {
  18. log = log_helper.GetLogger()
  19. log.Infoln("ChineseSubFinder Version:", AppVersion)
  20. if my_util.OSCheck() == false {
  21. panic(`only support Linux and Windows, if you want support MacOS,
  22. you need implement getDbName() in file: internal/dao/init.go
  23. and
  24. implement getSpeFileName() in internal/logic/forced_scan_and_down_sub/forced_scan_and_down_sub.go`)
  25. }
  26. config = config2.GetConfig()
  27. }
  28. func main() {
  29. if log == nil {
  30. panic("log init error")
  31. }
  32. if config == nil {
  33. panic("read config error")
  34. }
  35. httpProxy := config.HttpProxy
  36. if config.UseProxy == false {
  37. httpProxy = ""
  38. }
  39. if config.UseProxy == false {
  40. log.Infoln("UseProxy = false")
  41. } else {
  42. log.Infoln("UseProxy:", httpProxy)
  43. proxySpeed, proxyStatus, err := proxy_helper.ProxyTest(httpProxy)
  44. if err != nil {
  45. log.Errorln("ProxyTest Target Site http://google.com", err)
  46. return
  47. } else {
  48. log.Infoln("ProxyTest Target Site http://google.com", "Speed:", proxySpeed, "Status:", proxyStatus)
  49. }
  50. }
  51. // 判断文件夹是否存在
  52. if my_util.IsDir(config.MovieFolder) == false {
  53. log.Errorln("MovieFolder not found --", config.MovieFolder)
  54. return
  55. }
  56. if my_util.IsDir(config.SeriesFolder) == false {
  57. log.Errorln("SeriesFolder not found --", config.SeriesFolder)
  58. return
  59. }
  60. // 读取到的文件夹信息展示
  61. log.Infoln("MovieFolder:", config.MovieFolder)
  62. log.Infoln("SeriesFolder:", config.SeriesFolder)
  63. // ------ Hot Fix Start ------
  64. // 开始修复
  65. log.Infoln("HotFix Start, wait ...")
  66. log.Infoln(commonValue.NotifyStringTellUserWait)
  67. err := hot_fix.HotFixProcess(types.HotFixParam{
  68. MovieRootDir: config.MovieFolder,
  69. SeriesRootDir: config.SeriesFolder,
  70. })
  71. if err != nil {
  72. log.Errorln("HotFixProcess()", err)
  73. log.Infoln("HotFix End")
  74. return
  75. }
  76. log.Infoln("HotFix End")
  77. // ------ Hot Fix End ------
  78. // ------ Change SubName Format Start ------
  79. /*
  80. 字幕命名格式转换,需要数据库支持
  81. 如果数据库没有记录经过转换,那么默认从 Emby 的格式作为检测的起点,转换到目标的格式
  82. 然后需要在数据库中记录本次的转换结果
  83. */
  84. log.Infoln("Change Sub Name Format Start...")
  85. log.Infoln(commonValue.NotifyStringTellUserWait)
  86. renameResults, err := sub_formatter.SubFormatChangerProcess(config.MovieFolder, config.SeriesFolder, common.FormatterName(config.SubNameFormatter))
  87. // 出错的文件有哪一些
  88. for s, i := range renameResults.ErrFiles {
  89. log_helper.GetLogger().Errorln("reformat ErrFile:"+s, i)
  90. }
  91. if err != nil {
  92. log.Errorln("SubFormatChangerProcess()", err)
  93. return
  94. }
  95. log.Infoln("Change Sub Name Format End")
  96. // ------ Change SubName Format End ------
  97. // 初始化通知缓存模块
  98. notify_center.Notify = notify_center.NewNotifyCenter(config.WhenSubSupplierInvalidWebHook)
  99. //log.Infoln("ReloadBrowser Start...")
  100. //// ReloadBrowser 提前把浏览器下载好
  101. //rod_helper.ReloadBrowser()
  102. //log.Infoln("ReloadBrowser End")
  103. // 任务还没执行完,下一次执行时间到来,下一次执行就跳过不执行
  104. c := cron.New(cron.WithChain(cron.SkipIfStillRunning(cron.DefaultLogger)))
  105. // 定时器
  106. entryID, err := c.AddFunc("@every "+config.EveryTime, func() {
  107. DownLoadStart(httpProxy)
  108. })
  109. if err != nil {
  110. log.Errorln("cron entryID:", entryID, "Error:", err)
  111. return
  112. }
  113. if config.RunAtStartup == true {
  114. log.Infoln("First Time Download Start")
  115. DownLoadStart(httpProxy)
  116. log.Infoln("First Time Download End")
  117. } else {
  118. log.Infoln("config.yaml set RunAtStartup: false, so will not Run At Startup, wait", config.EveryTime, "to Download")
  119. }
  120. c.Start()
  121. // 阻塞
  122. select {}
  123. }
  124. func DownLoadStart(httpProxy string) {
  125. notify_center.Notify.Clear()
  126. // 下载实例
  127. downloader := internal.NewDownloader(sub_formatter.GetSubFormatter(config.SubNameFormatter),
  128. types.ReqParam{
  129. HttpProxy: httpProxy,
  130. DebugMode: config.DebugMode,
  131. SaveMultiSub: config.SaveMultiSub,
  132. Threads: config.Threads,
  133. SubTypePriority: config.SubTypePriority,
  134. WhenSubSupplierInvalidWebHook: config.WhenSubSupplierInvalidWebHook,
  135. EmbyConfig: config.EmbyConfig,
  136. SaveOneSeasonSub: config.SaveOneSeasonSub,
  137. SubTimelineFixerConfig: config.SubTimelineFixerConfig,
  138. FixTimeLine: config.FixTimeLine,
  139. })
  140. defer func() {
  141. log.Infoln("Download One End...")
  142. notify_center.Notify.Send()
  143. //pkg.CloseChrome()
  144. //rod_helper.Clear()
  145. }()
  146. log.Infoln("Download One Started...")
  147. // 优先级最高。读取特殊文件,启用一些特殊的功能,比如 forced_scan_and_down_sub
  148. err := downloader.ReadSpeFile()
  149. if err != nil {
  150. log.Errorln("ReadSpeFile", err)
  151. }
  152. // 从 csf-bk 文件还原时间轴修复前的字幕文件
  153. if downloader.NeedRestoreFixTimeLineBK == true {
  154. err = downloader.RestoreFixTimelineBK(config.MovieFolder, config.SeriesFolder)
  155. if err != nil {
  156. log.Errorln("RestoreFixTimelineBK", err)
  157. }
  158. }
  159. // 刷新 Emby 的字幕,如果下载了字幕倒是没有刷新,则先刷新一次,便于后续的 Emby api 统计逻辑
  160. err = downloader.RefreshEmbySubList()
  161. if err != nil {
  162. log.Errorln("RefreshEmbySubList", err)
  163. return
  164. }
  165. err = downloader.GetUpdateVideoListFromEmby(config.MovieFolder, config.SeriesFolder)
  166. if err != nil {
  167. log.Errorln("GetUpdateVideoListFromEmby", err)
  168. return
  169. }
  170. // 开始下载,电影
  171. err = downloader.DownloadSub4Movie(config.MovieFolder)
  172. if err != nil {
  173. log.Errorln("DownloadSub4Movie", err)
  174. return
  175. }
  176. // 开始下载,连续剧
  177. err = downloader.DownloadSub4Series(config.SeriesFolder)
  178. if err != nil {
  179. log.Errorln("DownloadSub4Series", err)
  180. return
  181. }
  182. // 刷新 Emby 的字幕,下载完毕字幕了,就统一刷新一下
  183. err = downloader.RefreshEmbySubList()
  184. if err != nil {
  185. log.Errorln("RefreshEmbySubList", err)
  186. return
  187. }
  188. }
  189. var (
  190. log *logrus.Logger
  191. config *types.Config
  192. )
  193. /*
  194. 没有很好的想法,因为喜欢使用 tag 进行版本的输出标记,但是 tag 的时候编译 docker 前确实可以修改源码替换关键词做到版本与 tag 同步变更
  195. 但是, goreleaser 却不支持这样,会提示源码被改了,无法进行编译发布
  196. 除非不发布、编译 Linux 和 Windows 程序,这样就能做到 tag 与 程序内部输出版本一致。
  197. */
  198. var AppVersion = "unknow"