misc: rss and media changes (#27)
* refactor: tweak rss processing * media: override trakt network with tvdb network if trakts is empty * media: dont merge tvdb language with trakt language * media: resolve issue with imdb ids
This commit is contained in:
@@ -4,7 +4,6 @@ import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"github.com/l3uddz/nabarr/media/trakt"
|
||||
"github.com/l3uddz/nabarr/util"
|
||||
"strconv"
|
||||
)
|
||||
|
||||
@@ -64,7 +63,11 @@ func (c *Client) GetShowInfo(item *FeedItem) (*Item, error) {
|
||||
Msg("Item was not found on tvdb")
|
||||
} else if ti != nil {
|
||||
mi.Tvdb = *ti
|
||||
mi.Languages = util.StringSliceMergeUnique(mi.Languages, []string{ti.Language})
|
||||
|
||||
// merge with trakt data
|
||||
if mi.Network == "" {
|
||||
mi.Network = ti.Network
|
||||
}
|
||||
}
|
||||
|
||||
return mi, nil
|
||||
|
||||
@@ -4,7 +4,9 @@ import (
|
||||
"encoding/xml"
|
||||
"github.com/l3uddz/nabarr/media/omdb"
|
||||
"github.com/l3uddz/nabarr/media/tvdb"
|
||||
"github.com/l3uddz/nabarr/util"
|
||||
"github.com/pkg/errors"
|
||||
"strings"
|
||||
"time"
|
||||
)
|
||||
|
||||
@@ -80,11 +82,11 @@ type FeedItem struct {
|
||||
|
||||
func (f *FeedItem) GetProviderData() (string, string) {
|
||||
switch {
|
||||
case f.TvdbId != "" && f.TvdbId != "0":
|
||||
case f.TvdbId != "" && !util.StringSliceContains([]string{"0", "1"}, f.TvdbId):
|
||||
return "tvdb", f.TvdbId
|
||||
case f.TmdbId != "" && f.TmdbId != "0":
|
||||
case f.TmdbId != "" && !util.StringSliceContains([]string{"0", "1"}, f.TmdbId):
|
||||
return "tmdb", f.TmdbId
|
||||
case f.ImdbId != "":
|
||||
case f.ImdbId != "" && strings.HasPrefix(f.ImdbId, "tt"):
|
||||
return "imdb", f.ImdbId
|
||||
}
|
||||
return "", ""
|
||||
|
||||
@@ -46,6 +46,7 @@ func (c *Client) GetItem(tvdbId string) (*Item, error) {
|
||||
return &Item{
|
||||
Runtime: util.Atoi(b.Data.Runtime, 0),
|
||||
Language: b.Data.Language,
|
||||
Network: b.Data.Network,
|
||||
Genre: b.Data.Genre,
|
||||
AirsDayOfWeek: b.Data.AirsDayOfWeek,
|
||||
SiteRating: b.Data.SiteRating,
|
||||
|
||||
@@ -35,6 +35,7 @@ type lookupResponse struct {
|
||||
type Item struct {
|
||||
Runtime int `json:"Runtime,omitempty"`
|
||||
Language string `json:"Language,omitempty"`
|
||||
Network string `json:"Network,omitempty"`
|
||||
Genre []string `json:"Genre,omitempty"`
|
||||
AirsDayOfWeek string `json:"AirsDayOfWeek,omitempty"`
|
||||
SiteRating float64 `json:"SiteRating,omitempty"`
|
||||
|
||||
@@ -26,7 +26,7 @@ func (c *Client) AddJob(feed feedItem) error {
|
||||
job := &rssJob{
|
||||
name: feed.Name,
|
||||
log: l,
|
||||
http: util.NewRetryableHttpClient(30*time.Second, nil, &l),
|
||||
http: util.NewRetryableHttpClient(60*time.Second, nil, &l),
|
||||
|
||||
url: feed.URL,
|
||||
pvrs: make(map[string]pvr.PVR, 0),
|
||||
|
||||
@@ -4,6 +4,7 @@ import (
|
||||
"encoding/xml"
|
||||
"fmt"
|
||||
"github.com/l3uddz/nabarr/media"
|
||||
"github.com/l3uddz/nabarr/util"
|
||||
"github.com/lucperkins/rek"
|
||||
"sort"
|
||||
"strings"
|
||||
@@ -113,13 +114,13 @@ func (j *rssJob) getFeed() ([]media.FeedItem, error) {
|
||||
|
||||
// validate item
|
||||
switch {
|
||||
case b.Channel.Items[p].TvdbId != "" && b.Channel.Items[p].TvdbId != "0":
|
||||
case b.Channel.Items[p].TvdbId != "" && !util.StringSliceContains([]string{"0", "1"}, b.Channel.Items[p].TvdbId):
|
||||
// tvdb id is present, allow processing
|
||||
break
|
||||
case b.Channel.Items[p].ImdbId != "":
|
||||
case b.Channel.Items[p].ImdbId != "" && strings.HasPrefix(b.Channel.Items[p].ImdbId, "tt"):
|
||||
// imdb id present, allow processing
|
||||
break
|
||||
case b.Channel.Items[p].TmdbId != "" && b.Channel.Items[p].TmdbId != "0":
|
||||
case b.Channel.Items[p].TmdbId != "" && !util.StringSliceContains([]string{"0", "1"}, b.Channel.Items[p].TmdbId):
|
||||
// tmdb id present, allow processing
|
||||
break
|
||||
default:
|
||||
|
||||
@@ -11,6 +11,17 @@ func StringSliceContains(slice []string, val string) bool {
|
||||
return false
|
||||
}
|
||||
|
||||
func StringSliceContainsAny(slice []string, vals []string) bool {
|
||||
for _, s := range slice {
|
||||
for _, v := range vals {
|
||||
if strings.EqualFold(s, v) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
func StringSliceMergeUnique(existingSlice []string, mergeSlice []string) []string {
|
||||
// add existing
|
||||
data := make([]string, 0)
|
||||
|
||||
@@ -92,3 +92,39 @@ func TestStringSliceMergeUnique(t *testing.T) {
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestStringSliceContainsAny(t *testing.T) {
|
||||
type args struct {
|
||||
slice []string
|
||||
vals []string
|
||||
}
|
||||
tests := []struct {
|
||||
name string
|
||||
args args
|
||||
want bool
|
||||
}{
|
||||
{
|
||||
name: "expect true",
|
||||
args: args{
|
||||
slice: []string{"tes", "Test"},
|
||||
vals: []string{"nope", "test"},
|
||||
},
|
||||
want: true,
|
||||
},
|
||||
{
|
||||
name: "expect false",
|
||||
args: args{
|
||||
slice: []string{"tes", "Test"},
|
||||
vals: []string{"testing"},
|
||||
},
|
||||
want: false,
|
||||
},
|
||||
}
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
if got := StringSliceContainsAny(tt.args.slice, tt.args.vals); got != tt.want {
|
||||
t.Errorf("StringSliceContainsAny() = %v, want %v", got, tt.want)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user