-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscrapefeeds.go
81 lines (66 loc) · 1.76 KB
/
scrapefeeds.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package main
import (
"context"
"errors"
"time"
"github.com/SplinterSword/GOGator/feeds"
"github.com/SplinterSword/GOGator/internal/database"
"github.com/google/uuid"
"github.com/lib/pq"
)
func scrapeFeeds(s *State) error {
nextFeed, err := s.db.GetNextFeedToFetch(context.Background())
if err != nil {
WriteInTerminal("failed to get next feed to fetch")
return errors.New("failed to get next feed to fetch")
}
err = s.db.MarkFeedFetched(context.Background(), nextFeed.ID)
if err != nil {
WriteInTerminal("failed to mark feed fetched: " + err.Error())
return errors.New("failed to mark feed fetched")
}
feed, err := feeds.FetchFeed(context.Background(), nextFeed.Url)
if err != nil {
return err
}
WriteInTerminal("Title: " + feed.Channel.Title)
WriteInTerminal(" ")
for i := 0; i < len(feed.Channel.Item); i++ {
item := feed.Channel.Item[i]
FeedNullUUID := uuid.NullUUID{
UUID: nextFeed.ID,
Valid: true,
}
PubTime, err := time.Parse(time.RFC1123Z, item.PubDate)
if err != nil {
WriteInTerminal("Failed to parse publication date: " + item.PubDate)
return err
}
post := database.CreatePostParams{
ID: uuid.New(),
CreatedAt: time.Now(),
UpdatedAt: time.Now(),
Title: item.Title,
Url: item.Link,
Description: item.Description,
PublishedAt: PubTime,
FeedID: FeedNullUUID,
}
_, err = s.db.CreatePost(context.Background(), post)
if err != nil {
if pgErr, ok := err.(*pq.Error); ok && pgErr.Code == "23505" {
// Skip duplicate posts
continue
}
WriteInTerminal("Failed to create post: " + err.Error())
return err
}
if item.Title == "" {
continue
}
WriteInTerminal("Title: " + item.Title)
}
WriteInTerminal(" ")
WriteInTerminal(" ")
return nil
}