Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v8 & v9 stuff #982

Closed
wants to merge 23 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
03a52c2
Added stickers
vys534 Jul 27, 2021
60ccd3f
upgrade to discord api v9
vys534 Jul 28, 2021
e746973
optimize parameters for thread rest api functions
vys534 Jul 28, 2021
9ca8b33
lint
vys534 Jul 28, 2021
8727f0c
store threads in state & update them accordingly
vys534 Jul 30, 2021
6408522
Reverted Invite() for backwards compatibility; changes moved to Invit…
vys534 Jul 30, 2021
f0d574e
Added select menu as a message component
vys534 Jul 30, 2021
6ab7ae6
Fixed wrong label in SelectOption, renamed ButtonEmoji to ComponentEm…
vys534 Jul 30, 2021
85c7477
Fix incorrect type for Message.Interaction, added field for values fr…
vys534 Jul 30, 2021
b9fe5fa
Change int to ArchiveDuration on thread metadata AutoArchiveDuration
vys534 Jul 30, 2021
9cc08be
Merge branch 'bwmarrin:master' into master
vys534 Jul 30, 2021
29791b6
Merge branch 'v9'
vys534 Jul 30, 2021
9459b08
Added functions for stickers, naming scheme fix for threads, added st…
vys534 Jul 30, 2021
c56255a
Added stage instance support, added missing audit log change keys & a…
vys534 Jul 30, 2021
a93fb91
gofmt
vys534 Jul 30, 2021
f3b5c0a
Fix incorrect values for ArchiveDurationOneHour
vys534 Jul 31, 2021
04013da
Revert 60*60 to 60
vys534 Jul 31, 2021
ecd5d0d
Restored UnmarshalJSON to Message, rename StickerFormatType -> Sticke…
vys534 Aug 1, 2021
32da67e
Add ThreadEdit function
Aug 24, 2021
356f82e
Merge pull request #1 from binwiederhier/vysiondev-threads
vys534 Aug 24, 2021
2962d8f
Merge remote-tracking branch 'upstream/master'
vys534 Aug 24, 2021
6bf33ca
Gofmt, fixed button types in component example
vys534 Aug 24, 2021
8574857
Integrated bug fixes and additions from #922
vys534 Aug 24, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
44 changes: 22 additions & 22 deletions components.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,9 @@ type ComponentType uint

// MessageComponent types.
const (
ActionsRowComponent ComponentType = 1
ButtonComponent ComponentType = 2
SelectMenuComponent ComponentType = 3
ComponentActionRow ComponentType = 1
ComponentButton ComponentType = 2
ComponentSelectMenu ComponentType = 3
)

// MessageComponent is a base interface for all message components.
Expand All @@ -36,11 +36,11 @@ func (umc *unmarshalableMessageComponent) UnmarshalJSON(src []byte) error {

var data MessageComponent
switch v.Type {
case ActionsRowComponent:
case ComponentActionRow:
v := ActionsRow{}
err = json.Unmarshal(src, &v)
data = v
case ButtonComponent:
case ComponentButton:
v := Button{}
err = json.Unmarshal(src, &v)
data = v
Expand Down Expand Up @@ -89,27 +89,27 @@ func (r *ActionsRow) UnmarshalJSON(data []byte) error {

// Type is a method to get the type of a component.
func (r ActionsRow) Type() ComponentType {
return ActionsRowComponent
return ComponentActionRow
}

// ButtonStyle is style of button.
type ButtonStyle uint

// Button styles.
const (
// PrimaryButton is a button with blurple color.
PrimaryButton ButtonStyle = 1
// SecondaryButton is a button with grey color.
SecondaryButton ButtonStyle = 2
// SuccessButton is a button with green color.
SuccessButton ButtonStyle = 3
// DangerButton is a button with red color.
DangerButton ButtonStyle = 4
// LinkButton is a special type of button which navigates to a URL. Has grey color.
LinkButton ButtonStyle = 5
// ButtonPrimary is a button with blurple color.
ButtonPrimary ButtonStyle = 1
// ButtonSecondary is a button with grey color.
ButtonSecondary ButtonStyle = 2
// ButtonSuccess is a button with green color.
ButtonSuccess ButtonStyle = 3
// ButtonDanger is a button with red color.
ButtonDanger ButtonStyle = 4
// ButtonLink is a special type of button which navigates to a URL. Has grey color.
ButtonLink ButtonStyle = 5
)

// ComponentEmoji represents button emoji, if it does have one.
// ComponentEmoji represents a button's emoji, if it has one.
type ComponentEmoji struct {
Name string `json:"name,omitempty"`
ID string `json:"id,omitempty"`
Expand All @@ -123,7 +123,7 @@ type Button struct {
Disabled bool `json:"disabled"`
Emoji ComponentEmoji `json:"emoji"`

// NOTE: Only button with LinkButton style can have link. Also, URL is mutually exclusive with CustomID.
// NOTE: Only button with ButtonLink style can have link. Also, URL is mutually exclusive with CustomID.
URL string `json:"url,omitempty"`
CustomID string `json:"custom_id,omitempty"`
}
Expand All @@ -133,7 +133,7 @@ func (b Button) MarshalJSON() ([]byte, error) {
type button Button

if b.Style == 0 {
b.Style = PrimaryButton
b.Style = ButtonPrimary
}

return json.Marshal(struct {
Expand All @@ -146,8 +146,8 @@ func (b Button) MarshalJSON() ([]byte, error) {
}

// Type is a method to get the type of a component.
func (Button) Type() ComponentType {
return ButtonComponent
func (b Button) Type() ComponentType {
return ComponentButton
}

// SelectMenuOption represents an option for a select menu.
Expand Down Expand Up @@ -175,7 +175,7 @@ type SelectMenu struct {

// Type is a method to get the type of a component.
func (SelectMenu) Type() ComponentType {
return SelectMenuComponent
return ComponentSelectMenu
}

// MarshalJSON is a method for marshaling SelectMenu to a JSON object.
Expand Down
43 changes: 33 additions & 10 deletions endpoints.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ package discordgo
import "strconv"

// APIVersion is the Discord API version used for the REST and Websocket API.
var APIVersion = "8"
var APIVersion = "9"

// Known Discord API Endpoints.
var (
Expand All @@ -23,14 +23,16 @@ var (
EndpointSmActive = EndpointSm + "active.json"
EndpointSmUpcoming = EndpointSm + "upcoming.json"

EndpointDiscord = "https://discord.com/"
EndpointAPI = EndpointDiscord + "api/v" + APIVersion + "/"
EndpointGuilds = EndpointAPI + "guilds/"
EndpointChannels = EndpointAPI + "channels/"
EndpointUsers = EndpointAPI + "users/"
EndpointGateway = EndpointAPI + "gateway"
EndpointGatewayBot = EndpointGateway + "/bot"
EndpointWebhooks = EndpointAPI + "webhooks/"
EndpointDiscord = "https://discord.com/"
EndpointAPI = EndpointDiscord + "api/v" + APIVersion + "/"
EndpointGuilds = EndpointAPI + "guilds/"
EndpointChannels = EndpointAPI + "channels/"
EndpointUsers = EndpointAPI + "users/"
EndpointGateway = EndpointAPI + "gateway"
EndpointGatewayBot = EndpointGateway + "/bot"
EndpointWebhooks = EndpointAPI + "webhooks/"
EndpointStickers = EndpointAPI + "stickers/"
EndpointStageInstances = EndpointAPI + "stage-instances/"

EndpointCDN = "https://cdn.discordapp.com/"
EndpointCDNAttachments = EndpointCDN + "attachments/"
Expand Down Expand Up @@ -102,6 +104,9 @@ var (
EndpointGuildEmojis = func(gID string) string { return EndpointGuilds + gID + "/emojis" }
EndpointGuildEmoji = func(gID, eID string) string { return EndpointGuilds + gID + "/emojis/" + eID }
EndpointGuildBanner = func(gID, hash string) string { return EndpointCDNBanners + gID + "/" + hash + ".png" }
EndpointGuildStickers = func(gID string) string { return EndpointGuilds + gID + "/stickers" }
EndpointGuildSticker = func(gID, sID string) string { return EndpointGuilds + gID + "/stickers/" + sID }
EndpointGuildActiveThreads = func(gID string) string { return EndpointGuilds + gID + "/threads/active" }

EndpointChannel = func(cID string) string { return EndpointChannels + cID }
EndpointChannelPermissions = func(cID string) string { return EndpointChannels + cID + "/permissions" }
Expand All @@ -115,10 +120,28 @@ var (
EndpointChannelMessagesPins = func(cID string) string { return EndpointChannel(cID) + "/pins" }
EndpointChannelMessagePin = func(cID, mID string) string { return EndpointChannel(cID) + "/pins/" + mID }
EndpointChannelMessageCrosspost = func(cID, mID string) string { return EndpointChannel(cID) + "/messages/" + mID + "/crosspost" }
EndpointChannelFollow = func(cID string) string { return EndpointChannel(cID) + "/followers" }
EndpointChannelUsers = func(cID string) string { return EndpointChannel(cID) + "/users" }
EndpointChannelMessageThreads = func(cID, mID string) string {
return EndpointChannels + cID + "/messages/" + mID + "/threads"
}

EndpointThreads = func(cID string) string { return EndpointChannel(cID) + "/threads" }
EndpointThreadMembers = func(cID string) string { return EndpointChannel(cID) + "/thread-members" }
EndpointThreadMember = func(cID, uID string) string { return EndpointChannel(cID) + "/thread-members/" + uID }
EndpointThreadsArchived = func(cID string) string { return EndpointThreads(cID) + "/archived" }
EndpointThreadsPublicArchived = func(cID string) string { return EndpointThreadsArchived(cID) + "/public" }
EndpointThreadsPrivateArchived = func(cID string) string { return EndpointThreadsArchived(cID) + "/private" }
EndpointThreadsJoinedPrivateArchived = func(cID string) string { return EndpointChannelUsers(cID) + "/@me/threads/archived/private" }

EndpointChannelFollow = func(cID string) string { return EndpointChannel(cID) + "/followers" }

EndpointGroupIcon = func(cID, hash string) string { return EndpointCDNChannelIcons + cID + "/" + hash + ".png" }

EndpointSticker = func(sID string) string { return EndpointStickers + sID }
EndpointNitroStickerPacks = EndpointAPI + "/sticker-packs"

EndpointStageInstance = func(cID string) string { return EndpointStageInstances + cID }

EndpointChannelWebhooks = func(cID string) string { return EndpointChannel(cID) + "/webhooks" }
EndpointWebhook = func(wID string) string { return EndpointWebhooks + wID }
EndpointWebhookToken = func(wID, token string) string { return EndpointWebhooks + wID + "/" + token }
Expand Down
144 changes: 144 additions & 0 deletions eventhandlers.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

37 changes: 37 additions & 0 deletions events.go
Original file line number Diff line number Diff line change
Expand Up @@ -289,6 +289,43 @@ type InteractionCreate struct {
*Interaction
}

// ThreadCreate is the data for a ThreadCreate event
type ThreadCreate struct {
*Channel
}

// ThreadUpdate is the data for a ThreadUpdate event
type ThreadUpdate struct {
*Channel
}

// ThreadDelete is the data for a ThreadDelete event
type ThreadDelete struct {
*Channel
}

// ThreadMemberUpdate is the data for a ThreadMemberUpdate event
type ThreadMemberUpdate struct {
*ThreadMember
}

// ThreadMembersUpdate is the data for a ThreadMembersUpdate event
type ThreadMembersUpdate struct {
ID string `json:"id"`
GuildID string `json:"guild_id"`
MemberCount int `json:"member_count"`
AddedMembers []*ThreadMember `json:"added_members"`
RemovedMemberIDs []string `json:"removed_member_ids"`
}

// ThreadListSync is the data for a ThreadListSync event
type ThreadListSync struct {
GuildID string `json:"guild_id"`
ChannelIDs []string `json:"channel_ids"`
Threads []*Channel `json:"threads"`
Members []*ThreadMember `json:"members"`
}

// UnmarshalJSON is a helper function to unmarshal Interaction object.
func (i *InteractionCreate) UnmarshalJSON(b []byte) error {
return json.Unmarshal(b, &i.Interaction)
Expand Down
Loading