Speed up process of loading channels

This commit is contained in:
erroneousboat 2018-03-31 10:58:37 +02:00
parent 0197300b18
commit 2ccc92179b

View File

@ -7,6 +7,7 @@ import (
"regexp" "regexp"
"strconv" "strconv"
"strings" "strings"
"sync"
"time" "time"
"github.com/nlopes/slack" "github.com/nlopes/slack"
@ -81,12 +82,47 @@ func NewSlackService(config *config.Config) (*SlackService, error) {
func (s *SlackService) GetChannels() []string { func (s *SlackService) GetChannels() []string {
var chans []components.ChannelItem var chans []components.ChannelItem
// Channel var wg sync.WaitGroup
slackChans, err := s.Client.GetChannels(true)
if err != nil {
chans = append(chans, components.ChannelItem{})
}
// Channels
wg.Add(1)
var slackChans []slack.Channel
go func() {
var err error
slackChans, err = s.Client.GetChannels(true)
if err != nil {
chans = append(chans, components.ChannelItem{})
}
wg.Done()
}()
// Groups
wg.Add(1)
var slackGroups []slack.Group
go func() {
var err error
slackGroups, err = s.Client.GetGroups(true)
if err != nil {
chans = append(chans, components.ChannelItem{})
}
wg.Done()
}()
// IM
wg.Add(1)
var slackIM []slack.IM
go func() {
var err error
slackIM, err = s.Client.GetIMChannels()
if err != nil {
chans = append(chans, components.ChannelItem{})
}
wg.Done()
}()
wg.Wait()
// Channels
for _, chn := range slackChans { for _, chn := range slackChans {
if chn.IsMember { if chn.IsMember {
s.SlackChannels = append(s.SlackChannels, chn) s.SlackChannels = append(s.SlackChannels, chn)
@ -106,10 +142,6 @@ func (s *SlackService) GetChannels() []string {
} }
// Groups // Groups
slackGroups, err := s.Client.GetGroups(true)
if err != nil {
chans = append(chans, components.ChannelItem{})
}
for _, grp := range slackGroups { for _, grp := range slackGroups {
s.SlackChannels = append(s.SlackChannels, grp) s.SlackChannels = append(s.SlackChannels, grp)
chans = append( chans = append(
@ -127,15 +159,8 @@ func (s *SlackService) GetChannels() []string {
} }
// IM // IM
slackIM, err := s.Client.GetIMChannels()
if err != nil {
chans = append(chans, components.ChannelItem{})
}
for _, im := range slackIM { for _, im := range slackIM {
// FIXME: err
presence, _ := s.GetUserPresence(im.User)
// Uncover name, when we can't uncover name for // Uncover name, when we can't uncover name for
// IM channel this is then probably a deleted // IM channel this is then probably a deleted
// user, because we won't add deleted users // user, because we won't add deleted users
@ -151,7 +176,7 @@ func (s *SlackService) GetChannels() []string {
Topic: "", Topic: "",
Type: components.ChannelTypeIM, Type: components.ChannelTypeIM,
UserID: im.User, UserID: im.User,
Presence: presence, Presence: "",
StylePrefix: s.Config.Theme.Channel.Prefix, StylePrefix: s.Config.Theme.Channel.Prefix,
StyleIcon: s.Config.Theme.Channel.Icon, StyleIcon: s.Config.Theme.Channel.Icon,
StyleText: s.Config.Theme.Channel.Text, StyleText: s.Config.Theme.Channel.Text,
@ -163,10 +188,15 @@ func (s *SlackService) GetChannels() []string {
s.Channels = chans s.Channels = chans
// We set presence of IM channels here because we need to separately
// issue an API call for every channel, this will speed up that process
s.SetPresenceChannels()
var channels []string var channels []string
for _, chn := range s.Channels { for _, chn := range s.Channels {
channels = append(channels, chn.ToString()) channels = append(channels, chn.ToString())
} }
return channels return channels
} }
@ -179,6 +209,26 @@ func (s *SlackService) ChannelsToString() []string {
return channels return channels
} }
// SetPresence will set presence for all IM channels
func (s *SlackService) SetPresenceChannels() {
var wg sync.WaitGroup
for i, channel := range s.SlackChannels {
switch channel := channel.(type) {
case slack.IM:
wg.Add(1)
go func(i int) {
presence, _ := s.GetUserPresence(channel.User)
s.Channels[i].Presence = presence
wg.Done()
}(i)
}
}
wg.Wait()
}
// SetPresenceChannelEvent will set the presence of a IM channel // SetPresenceChannelEvent will set the presence of a IM channel
func (s *SlackService) SetPresenceChannelEvent(userID string, presence string) { func (s *SlackService) SetPresenceChannelEvent(userID string, presence string) {
// Get the correct Channel from svc.Channels // Get the correct Channel from svc.Channels