Browse Source

Add a caching HTTP client

pull/83/head
Kegan Dougal 8 years ago
parent
commit
b0eb284347
  1. 7
      src/github.com/matrix-org/go-neb/services/rssbot/rssbot.go

7
src/github.com/matrix-org/go-neb/services/rssbot/rssbot.go

@ -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,

Loading…
Cancel
Save