feedvault.se/feeds.go

46 lines
1.1 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
addFeedExtensionToDB(ctx, feed, newFeed)
// Add authors to the database
addFeedAuthors(ctx, feed, newFeed)
fmt.Println(feed.Title)
return nil
}