mirror of
https://github.com/zoriya/vex.git
synced 2026-06-01 01:58:18 +00:00
Add sync service
This commit is contained in:
+83
@@ -0,0 +1,83 @@
|
||||
package vex
|
||||
|
||||
import (
|
||||
"cmp"
|
||||
"log"
|
||||
"time"
|
||||
|
||||
"github.com/google/uuid"
|
||||
"github.com/mmcdole/gofeed"
|
||||
)
|
||||
|
||||
type SyncService struct {
|
||||
reader *Reader
|
||||
feeds *FeedService
|
||||
entries *EntryService
|
||||
}
|
||||
|
||||
func NewSyncService(reader *Reader, feeds *FeedService, entries *EntryService) SyncService {
|
||||
return SyncService{
|
||||
reader: reader,
|
||||
feeds: feeds,
|
||||
entries: entries,
|
||||
}
|
||||
}
|
||||
|
||||
func (s SyncService) SyncFeed(feed Feed) error {
|
||||
info, err := s.reader.ReadFeed(feed.Link, feed.etag, feed.lastFetchDate)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if info == nil {
|
||||
// no new items
|
||||
return nil
|
||||
}
|
||||
log.Printf("Adding %v new entries", len(info.Items))
|
||||
entries := Map(info.Items, func(item *gofeed.Item, _ int) EntryDao {
|
||||
var date time.Time
|
||||
if item.PublishedParsed != nil {
|
||||
date = *item.PublishedParsed
|
||||
} else {
|
||||
date = time.Now()
|
||||
}
|
||||
|
||||
return EntryDao{
|
||||
Id: uuid.New(),
|
||||
Title: item.Title,
|
||||
Link: item.Link,
|
||||
Date: date,
|
||||
Authors: Map(item.Authors, func(author *gofeed.Person, _ int) string { return author.Name }),
|
||||
Content: cmp.Or(item.Content, item.Description),
|
||||
FeedId: feed.Id,
|
||||
}
|
||||
})
|
||||
err = s.entries.Add(entries)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
// TODO: update etag and last fetch date of feed
|
||||
return nil
|
||||
}
|
||||
|
||||
func (s SyncService) SyncFeeds() error {
|
||||
feeds, err := s.feeds.ListFeeds()
|
||||
if err != nil {
|
||||
log.Printf("Could not retrive feeds: %v", err)
|
||||
return err
|
||||
}
|
||||
for _, feed := range feeds {
|
||||
err := s.SyncFeed(feed)
|
||||
if err != nil {
|
||||
log.Printf("Could not sync feed %v: %v", feed.Link, err)
|
||||
// TODO: s.feeds.SaveError(feed.Id, err)
|
||||
}
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (s SyncService) SyncFeedsForever() {
|
||||
for {
|
||||
s.SyncFeeds()
|
||||
time.Sleep(15 * time.Minute)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user