feedvault.se/feeds.go

67 lines
1.8 KiB
Go

package main
import (
"context"
"fmt"
"log"
"time"
"github.com/mmcdole/gofeed"
)
func AddFeedToDB(feedURL string) error {
// Cancel the request after 60 seconds if it hasn't finished
ctx, cancel := context.WithTimeout(context.Background(), 60*time.Second)
defer cancel()
// Parse the feed
fp := gofeed.NewParser()
fp.UserAgent = "FeedVault/1.0 (RSS feed archive; https://feedvault.se; bot@feedvault.se; TheLovinator#9276)"
feed, err := fp.ParseURLWithContext(feedURL, ctx)
if err != nil {
return fmt.Errorf("Error parsing feed: %s", err)
}
// Add the feed to the database
newFeed, err := DB.CreateFeed(ctx, makeCreateFeedParams(feedURL, feed))
if err != nil {
return fmt.Errorf("Error adding feed to database: %s", err)
}
log.Printf("Feed added to database")
// Add the items to the database
for _, item := range feed.Items {
addItemToDB(item, ctx, newFeed)
}
// Add extensions to the database
log.Printf("Adding extensions to the database")
addFeedExtensionToDB(ctx, feed, newFeed)
// Add authors to the database
log.Printf("Adding authors to the database")
addFeedAuthors(ctx, feed, newFeed)
// TODO: Add categories to the database
// Add images to the database
log.Printf("Adding images to the database")
addFeedImages(ctx, feed, newFeed)
// Add Dublin Core to the database
log.Printf("Adding Dublin Core to the database")
createFeedDublinCore(ctx, feed, newFeed)
// Add iTunes extensions to the database
log.Printf("Adding iTunes extensions to the database")
itunes, err := createFeedItunes(ctx, feed, newFeed)
if err != nil {
log.Printf("Error adding iTunes extensions to database: %s", err)
}
createFeedItunesCategories(ctx, feed, itunes)
createFeedItunesOwners(ctx, feed, itunes)
log.Printf("Feed added to database")
return nil
}