From 51f4f12588c1cdced50d0548fe4b8ed90333ac5d Mon Sep 17 00:00:00 2001 From: IoIxD Date: Tue, 23 Jul 2024 14:29:31 -0700 Subject: [PATCH] properly get channel --- discord.go | 10 ++++++++++ server.go | 6 +++--- 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/discord.go b/discord.go index 235bc4b..3d71a34 100755 --- a/discord.go +++ b/discord.go @@ -14,6 +14,16 @@ import ( "github.com/diamondburned/arikawa/v3/state" ) +func (s *server) channel(channelID discord.ChannelID) (*discord.Channel, error) { + s.fetchedInactiveMu.Lock() + defer s.fetchedInactiveMu.Unlock() + channel, err := s.discord.Channel(channelID) + if err != nil { + return nil, err + } + return channel, nil +} + func (s *server) channels(guildID discord.GuildID) ([]discord.Channel, error) { s.fetchedInactiveMu.Lock() defer s.fetchedInactiveMu.Unlock() diff --git a/server.go b/server.go index 353e68a..05eac92 100755 --- a/server.go +++ b/server.go @@ -200,7 +200,7 @@ func (s *server) publicActiveThreads(gid discord.GuildID) ([]discord.Channel, er if channel.Type != discord.GuildPublicThread { continue } - parent, err := s.discord.Cabinet.Channel(channel.ParentID) + parent, err := s.channel(channel.ParentID) if err != nil { return nil, err } @@ -447,7 +447,7 @@ func (s *server) getForum(w http.ResponseWriter, r *http.Request) { } var posts []Post for _, thread := range channels { - parent, err := s.discord.Cabinet.Channel(thread.ParentID) + parent, err := s.channel(thread.ParentID) if err != nil { s.displayErr(w, http.StatusInternalServerError, fmt.Errorf("fetching parent channel's type: %w", err)) @@ -659,7 +659,7 @@ func (s *server) forumFromReq(w http.ResponseWriter, r *http.Request) (*discord. return nil, false } forumID := discord.ChannelID(forumIDsf) - forum, err := s.discord.Cabinet.Channel(forumID) + forum, err := s.channel(forumID) if err != nil { if discordStatusIs(err, http.StatusNotFound) { s.displayErr(w, http.StatusNotFound, nil)