From 5f015e26eec9c04a5c53abf58fd9140d978706fe Mon Sep 17 00:00:00 2001 From: Kegan Dougal Date: Wed, 12 Oct 2016 11:15:00 +0100 Subject: [PATCH] Join rooms when registering rss service --- .../go-neb/services/rssbot/rssbot.go | 21 +++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/src/github.com/matrix-org/go-neb/services/rssbot/rssbot.go b/src/github.com/matrix-org/go-neb/services/rssbot/rssbot.go index d779ace6..bdf72be5 100644 --- a/src/github.com/matrix-org/go-neb/services/rssbot/rssbot.go +++ b/src/github.com/matrix-org/go-neb/services/rssbot/rssbot.go @@ -63,9 +63,30 @@ func (s *rssBotService) Register(oldService types.Service, client *matrix.Client return fmt.Errorf("Feed %s has no rooms to send updates to", feedURL) } } + + s.joinRooms(client) return nil } +func (s *rssBotService) joinRooms(client *matrix.Client) { + roomSet := make(map[string]bool) + for _, feedInfo := range s.Feeds { + for _, roomID := range feedInfo.Rooms { + roomSet[roomID] = true + } + } + + for roomID := range roomSet { + if _, err := client.JoinRoom(roomID, "", ""); err != nil { + log.WithFields(log.Fields{ + log.ErrorKey: err, + "room_id": roomID, + "user_id": client.UserID, + }).Error("Failed to join room") + } + } +} + func (s *rssBotService) PostRegister(oldService types.Service) { if len(s.Feeds) == 0 { // bye-bye :( logger := log.WithFields(log.Fields{