74 lines
1.7 KiB
Go
74 lines
1.7 KiB
Go
package local
|
|
|
|
import (
|
|
"time"
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
"github.com/lbryio/lbry.go/v2/extras/util"
|
|
)
|
|
|
|
type YouTubeVideoEnricher interface {
|
|
EnrichMissing(source *SourceVideo) error
|
|
}
|
|
|
|
type YouTubeAPIVideoEnricher struct {
|
|
api *YouTubeAPI
|
|
}
|
|
|
|
func NewYouTubeAPIVideoEnricher(apiKey string) (*YouTubeAPIVideoEnricher) {
|
|
enricher := YouTubeAPIVideoEnricher{
|
|
api: NewYouTubeAPI(apiKey),
|
|
}
|
|
return &enricher
|
|
}
|
|
|
|
func (e *YouTubeAPIVideoEnricher) EnrichMissing(source *SourceVideo) error {
|
|
if source.ReleaseTime != nil {
|
|
log.Debugf("Video %s does not need enrichment. YouTubeAPIVideoEnricher is skipping.", source.ID)
|
|
return nil
|
|
}
|
|
|
|
snippet, err := e.api.GetVideoSnippet(source.ID)
|
|
if err != nil {
|
|
log.Errorf("Error snippet data for video %s: %v", err)
|
|
return err
|
|
}
|
|
|
|
publishedAt, err := time.Parse(time.RFC3339, snippet.PublishedAt)
|
|
if err != nil {
|
|
log.Errorf("Error converting publishedAt to timestamp: %v", err)
|
|
} else {
|
|
source.ReleaseTime = util.PtrToInt64(publishedAt.Unix())
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type CacheVideoEnricher struct {
|
|
syncDB *SyncDb
|
|
}
|
|
|
|
func NewCacheVideoEnricher(syncDB *SyncDb) *CacheVideoEnricher {
|
|
enricher := CacheVideoEnricher {
|
|
syncDB,
|
|
}
|
|
return &enricher
|
|
}
|
|
|
|
func (e *CacheVideoEnricher) EnrichMissing(source *SourceVideo) error {
|
|
if source.ReleaseTime != nil {
|
|
log.Debugf("Video %s does not need enrichment. YouTubeAPIVideoEnricher is skipping.", source.ID)
|
|
return nil
|
|
}
|
|
|
|
cached, err := e.syncDB.GetVideoRecord(source.Source, source.ID, false, false)
|
|
if err != nil {
|
|
log.Errorf("Error getting cached video %s: %v", source.ID, err)
|
|
return err
|
|
}
|
|
|
|
if cached != nil && cached.ReleaseTime.Valid {
|
|
source.ReleaseTime = &cached.ReleaseTime.Int64
|
|
}
|
|
return nil
|
|
}
|