| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- package imdb_helper
- import (
- "crypto/tls"
- "github.com/StalkR/imdb"
- "github.com/allanpk716/ChineseSubFinder/internal/dao"
- "github.com/allanpk716/ChineseSubFinder/internal/pkg/log_helper"
- "github.com/allanpk716/ChineseSubFinder/internal/pkg/notify_center"
- "github.com/allanpk716/ChineseSubFinder/internal/pkg/settings"
- gModels "github.com/allanpk716/ChineseSubModels/models"
- "net/http"
- "net/url"
- "strings"
- "time"
- )
- // GetVideoInfoFromIMDBWeb 从 IMDB 网站 ID 查询影片的信息
- func GetVideoInfoFromIMDBWeb(imdbID string, _proxySettings ...*settings.ProxySettings) (*imdb.Title, error) {
- var cli *http.Client
- var proxySettings *settings.ProxySettings
- if len(_proxySettings) > 0 && _proxySettings[0].UseHttpProxy == true || len(_proxySettings[0].HttpProxyAddress) > 0 {
- proxySettings = _proxySettings[0]
- proxy, err := url.Parse(proxySettings.HttpProxyAddress)
- if err != nil {
- return nil, err
- }
- tr := &http.Transport{
- Proxy: http.ProxyURL(proxy),
- TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
- }
- cli = &http.Client{
- Timeout: 15 * time.Second,
- Transport: tr,
- }
- } else {
- cli = &http.Client{
- Timeout: 15 * time.Second,
- }
- }
- t, err := imdb.NewTitle(cli, imdbID)
- if err != nil {
- notify_center.Notify.Add("imdb model - imdb.NewTitle :", err.Error())
- return nil, err
- }
- return t, nil
- }
- // GetVideoIMDBInfoFromLocal 从本地获取 IMDB 信息,如果找不到则去网络获取并写入本地缓存
- func GetVideoIMDBInfoFromLocal(imdbID string, _proxySettings ...*settings.ProxySettings) (*gModels.IMDBInfo, error) {
- log_helper.GetLogger().Debugln("GetVideoIMDBInfoFromLocal", 0)
- // 首先从数据库中查找是否存在这个 IMDB 信息,如果不存在再使用 Web 查找,且写入数据库
- var imdbInfos []gModels.IMDBInfo
- // 把嵌套关联的 has many 的信息都查询出来
- dao.GetDb().Preload("VideoSubInfos").Limit(1).Where(&gModels.IMDBInfo{IMDBID: imdbID}).Find(&imdbInfos)
- log_helper.GetLogger().Debugln("GetVideoIMDBInfoFromLocal", 1)
- if len(imdbInfos) <= 0 {
- // 没有找到,去网上获取
- t, err := GetVideoInfoFromIMDBWeb(imdbID, _proxySettings...)
- if err != nil {
- return nil, err
- }
- log_helper.GetLogger().Debugln("GetVideoIMDBInfoFromLocal", 2)
- // 存入数据库
- nowIMDBInfo := gModels.NewIMDBInfo(imdbID, t.Name, t.Year, t.Description, t.Languages, t.AKA)
- imdbInfos = make([]gModels.IMDBInfo, 0)
- imdbInfos = append(imdbInfos, *nowIMDBInfo)
- dao.GetDb().Create(nowIMDBInfo)
- log_helper.GetLogger().Debugln("GetVideoIMDBInfoFromLocal", 3)
- return nowIMDBInfo, nil
- } else {
- log_helper.GetLogger().Debugln("GetVideoIMDBInfoFromLocal", 4)
- // 找到
- return &imdbInfos[0], nil
- }
- }
- // IsChineseVideo 从 imdbID 去查询判断是否是中文视频
- func IsChineseVideo(imdbID string, _proxySettings ...*settings.ProxySettings) (bool, *gModels.IMDBInfo, error) {
- const chName0 = "chinese"
- const chName1 = "mandarin"
- var proxySettings *settings.ProxySettings
- if len(_proxySettings) > 0 {
- proxySettings = _proxySettings[0]
- }
- localIMDBInfo, err := GetVideoIMDBInfoFromLocal(imdbID, proxySettings)
- if err != nil {
- return false, nil, err
- }
- if len(localIMDBInfo.Languages) <= 0 {
- return false, nil, nil
- }
- firstLangLowCase := strings.ToLower(localIMDBInfo.Languages[0])
- // 判断第一语言是否是中文
- switch firstLangLowCase {
- case chName0, chName1:
- return true, localIMDBInfo, nil
- default:
- return false, localIMDBInfo, nil
- }
- }
|