|
@ -4,15 +4,19 @@ import ( |
|
|
"errors" |
|
|
"errors" |
|
|
"fmt" |
|
|
"fmt" |
|
|
log "github.com/Sirupsen/logrus" |
|
|
log "github.com/Sirupsen/logrus" |
|
|
|
|
|
"github.com/gregjones/httpcache" |
|
|
"github.com/matrix-org/go-neb/database" |
|
|
"github.com/matrix-org/go-neb/database" |
|
|
"github.com/matrix-org/go-neb/matrix" |
|
|
"github.com/matrix-org/go-neb/matrix" |
|
|
"github.com/matrix-org/go-neb/polling" |
|
|
"github.com/matrix-org/go-neb/polling" |
|
|
"github.com/matrix-org/go-neb/types" |
|
|
"github.com/matrix-org/go-neb/types" |
|
|
"github.com/mmcdole/gofeed" |
|
|
"github.com/mmcdole/gofeed" |
|
|
"html" |
|
|
"html" |
|
|
|
|
|
"net/http" |
|
|
"time" |
|
|
"time" |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
var cachingClient *http.Client |
|
|
|
|
|
|
|
|
const minPollingIntervalSeconds = 60 // 1 min (News feeds can be genuinely spammy)
|
|
|
const minPollingIntervalSeconds = 60 // 1 min (News feeds can be genuinely spammy)
|
|
|
|
|
|
|
|
|
type rssBotService struct { |
|
|
type rssBotService struct { |
|
@ -50,6 +54,7 @@ func (s *rssBotService) Register(oldService types.Service, client *matrix.Client |
|
|
// Make sure we can parse the feed
|
|
|
// Make sure we can parse the feed
|
|
|
for feedURL, feedInfo := range s.Feeds { |
|
|
for feedURL, feedInfo := range s.Feeds { |
|
|
fp := gofeed.NewParser() |
|
|
fp := gofeed.NewParser() |
|
|
|
|
|
fp.Client = cachingClient |
|
|
if _, err := fp.ParseURL(feedURL); err != nil { |
|
|
if _, err := fp.ParseURL(feedURL); err != nil { |
|
|
return fmt.Errorf("Failed to read URL %s: %s", feedURL, err.Error()) |
|
|
return fmt.Errorf("Failed to read URL %s: %s", feedURL, err.Error()) |
|
|
} |
|
|
} |
|
@ -138,6 +143,7 @@ func (s *rssBotService) queryFeed(feedURL string) (*gofeed.Feed, []gofeed.Item, |
|
|
log.WithField("feed_url", feedURL).Info("Querying feed") |
|
|
log.WithField("feed_url", feedURL).Info("Querying feed") |
|
|
var items []gofeed.Item |
|
|
var items []gofeed.Item |
|
|
fp := gofeed.NewParser() |
|
|
fp := gofeed.NewParser() |
|
|
|
|
|
fp.Client = cachingClient |
|
|
feed, err := fp.ParseURL(feedURL) |
|
|
feed, err := fp.ParseURL(feedURL) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
return nil, items, err |
|
|
return nil, items, err |
|
@ -214,6 +220,7 @@ func itemToHTML(feed *gofeed.Feed, item gofeed.Item) matrix.HTMLMessage { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func init() { |
|
|
func init() { |
|
|
|
|
|
cachingClient = httpcache.NewMemoryCacheTransport().Client() |
|
|
types.RegisterService(func(serviceID, serviceUserID, webhookEndpointURL string) types.Service { |
|
|
types.RegisterService(func(serviceID, serviceUserID, webhookEndpointURL string) types.Service { |
|
|
r := &rssBotService{ |
|
|
r := &rssBotService{ |
|
|
id: serviceID, |
|
|
id: serviceID, |
|
|