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 }