Skip to content
Permalink

Comparing changes

Choose two branches to see what’s changed or to start a new pull request. If you need to, you can also or learn more about diff comparisons.

Open a pull request

Create a new pull request by comparing changes across two branches. If you need to, you can also . Learn more about diff comparisons here.
base repository: disgoorg/disgo
Failed to load repositories. Confirm that selected base ref is valid, then try again.
Loading
base: v0.18.14
Choose a base ref
...
head repository: disgoorg/disgo
Failed to load repositories. Confirm that selected head ref is valid, then try again.
Loading
compare: v0.18.15
Choose a head ref
  • 11 commits
  • 15 files changed
  • 4 contributors

Commits on Nov 4, 2024

  1. Add MessageFlagHasSnapshot

    sebm253 committed Nov 4, 2024

    Verified

    This commit was signed with the committer’s verified signature.
    sebm253 Sebastian
    Copy the full SHA
    fbd227f View commit details

Commits on Dec 11, 2024

  1. Remove rest.GetDMChannels

    it does nothing lulz thanks discord 🙏
    sebm253 committed Dec 11, 2024

    Verified

    This commit was signed with the committer’s verified signature.
    sebm253 Sebastian
    Copy the full SHA
    fe3e043 View commit details

Commits on Dec 12, 2024

  1. Add RenewalSkuIDs to Subscription

    sebm253 committed Dec 12, 2024

    Verified

    This commit was signed with the committer’s verified signature.
    sebm253 Sebastian
    Copy the full SHA
    015b4b7 View commit details

Commits on Dec 14, 2024

  1. update dependencies

    topi314 committed Dec 14, 2024

    Verified

    This commit was signed with the committer’s verified signature.
    topi314 Toπ
    Copy the full SHA
    86315b1 View commit details
  2. update example dependencies

    topi314 committed Dec 14, 2024

    Verified

    This commit was signed with the committer’s verified signature.
    topi314 Toπ
    Copy the full SHA
    e1313eb View commit details

Commits on Dec 18, 2024

  1. fix: variables parsed after middleware runs (#406)

    topi314 authored Dec 18, 2024

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature.
    Copy the full SHA
    e727bba View commit details

Commits on Dec 19, 2024

  1. Add ConnectionTypeBluesky and Mastodon (#401)

    * Add ConnectionTypeBluesky
    
    * add ConnectionTypeMastodon
    sebm253 authored Dec 19, 2024

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature.
    Copy the full SHA
    68e1953 View commit details

Commits on Dec 28, 2024

  1. add nonce field to message struct (#408)

    topi314 authored Dec 28, 2024

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature.
    Copy the full SHA
    3bdb88c View commit details

Commits on Jan 20, 2025

  1. Add Acknowledge function to ApplicationCommandInteractionCreate for H…

    …TTP server interactions (#409)
    
    feat: add Acknowledge response type for interaction handling
    BowsiePup authored Jan 20, 2025

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature.
    Copy the full SHA
    69944d0 View commit details

Commits on Jan 23, 2025

  1. Merge pull request #398 from disgoorg/feature/has-snapshot-message-flag

    Add MessageFlagHasSnapshot
    sebm253 authored Jan 23, 2025

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature.
    Copy the full SHA
    e5d0cac View commit details

Commits on Jan 24, 2025

  1. Add guild incidents (#303)

    * Add guild incidents
    
    * add incident message types
    
    * add new fields
    
    * make new types deletable
    
    * reformat
    
    ---------
    
    Co-authored-by: mlnrDev <git@mlnr.dev>
    sebm253 and mlnrDev authored Jan 24, 2025

    Verified

    This commit was created on GitHub.com and signed with GitHub’s verified signature.
    Copy the full SHA
    25685c9 View commit details
6 changes: 3 additions & 3 deletions _examples/application_commands/http/go.mod
Original file line number Diff line number Diff line change
@@ -5,7 +5,7 @@ go 1.21
replace github.com/disgoorg/disgo => ../../../

require (
github.com/disgoorg/disgo v0.18.11
github.com/disgoorg/disgo v0.18.14
github.com/disgoorg/snowflake/v2 v2.0.3
github.com/oasisprotocol/curve25519-voi v0.0.0-20230904125328-1f23a7beb09a
)
@@ -14,6 +14,6 @@ require (
github.com/disgoorg/json v1.2.0 // indirect
github.com/gorilla/websocket v1.5.3 // indirect
github.com/sasha-s/go-csync v0.0.0-20240107134140-fcbab37b09ad // indirect
golang.org/x/crypto v0.27.0 // indirect
golang.org/x/sys v0.25.0 // indirect
golang.org/x/crypto v0.31.0 // indirect
golang.org/x/sys v0.28.0 // indirect
)
12 changes: 6 additions & 6 deletions _examples/application_commands/http/go.sum
Original file line number Diff line number Diff line change
@@ -12,11 +12,11 @@ github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZb
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/sasha-s/go-csync v0.0.0-20240107134140-fcbab37b09ad h1:qIQkSlF5vAUHxEmTbaqt1hkJ/t6skqEGYiMag343ucI=
github.com/sasha-s/go-csync v0.0.0-20240107134140-fcbab37b09ad/go.mod h1:/pA7k3zsXKdjjAiUhB5CjuKib9KJGCaLvZwtxGC8U0s=
github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg=
github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
golang.org/x/crypto v0.27.0 h1:GXm2NjJrPaiv/h1tb2UH8QfgC/hOf/+z0p6PT8o1w7A=
golang.org/x/crypto v0.27.0/go.mod h1:1Xngt8kV6Dvbssa53Ziq6Eqn0HqbZi5Z6R0ZpwQzt70=
golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34=
golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
golang.org/x/crypto v0.31.0 h1:ihbySMvVjLAeSH1IbfcRTkD/iNscyz8rGzjF/E5hV6U=
golang.org/x/crypto v0.31.0/go.mod h1:kDsLvtWBEx7MV9tJOj9bnXsPbxwJQ6csT/x4KIN4Ssk=
golang.org/x/sys v0.28.0 h1:Fksou7UEQUWlKvIdsqzJmUmCX3cZuD2+P3XyyzwMhlA=
golang.org/x/sys v0.28.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
2 changes: 2 additions & 0 deletions discord/connection.go
Original file line number Diff line number Diff line change
@@ -17,6 +17,7 @@ type ConnectionType string
const (
ConnectionTypeAmazonMusic ConnectionType = "amazon-music"
ConnectionTypeBattleNet ConnectionType = "battlenet"
ConnectionTypeBluesky ConnectionType = "bluesky"
ConnectionTypeBungie ConnectionType = "bungie"
ConnectionTypeCrunchyroll ConnectionType = "crunchyroll"
ConnectionTypeDomain ConnectionType = "domain"
@@ -26,6 +27,7 @@ const (
ConnectionTypeGitHub ConnectionType = "github"
ConnectionTypeInstagram ConnectionType = "instagram"
ConnectionTypeLeagueOfLegends ConnectionType = "leagueoflegends"
ConnectionTypeMastodon ConnectionType = "mastodon"
ConnectionTypePayPal ConnectionType = "paypal"
ConnectionTypePlayStationNetwork ConnectionType = "playstation"
ConnectionTypeReddit ConnectionType = "reddit"
13 changes: 13 additions & 0 deletions discord/guild.go
Original file line number Diff line number Diff line change
@@ -166,6 +166,7 @@ type Guild struct {
PremiumProgressBarEnabled bool `json:"premium_progress_bar_enabled"`
JoinedAt time.Time `json:"joined_at"`
SafetyAlertsChannelID *snowflake.ID `json:"safety_alerts_channel_id"`
IncidentsData *GuildIncidentsData `json:"incidents_data"`

// only over GET /guilds/{guild.id}
ApproximateMemberCount int `json:"approximate_member_count"`
@@ -319,6 +320,18 @@ type GuildPreview struct {
Stickers []Sticker `json:"stickers"`
}

type GuildIncidentsData struct {
InvitesDisabledUntil *time.Time `json:"invites_disabled_until"`
DMsDisabledUntil *time.Time `json:"dms_disabled_until"`
DMSpamDetectedAt *time.Time `json:"dm_spam_detected_at"`
RaidDetectedAt *time.Time `json:"raid_detected_at"`
}

type GuildIncidentActionsUpdate struct {
InvitesDisabledUntil *json.Nullable[time.Time] `json:"invites_disabled_until,omitempty"`
DMsDisabledUntil *json.Nullable[time.Time] `json:"dms_disabled_until,omitempty"`
}

// GuildCreate is the payload used to create a Guild
type GuildCreate struct {
Name string `json:"name"`
5 changes: 5 additions & 0 deletions discord/interaction_response.go
Original file line number Diff line number Diff line change
@@ -3,6 +3,11 @@ package discord
// InteractionResponseType indicates the type of slash command response, whether it's responding immediately or deferring to edit your response later
type InteractionResponseType int

// InteractionResponseTypeAcknowledge is stricly internal and will never be sent to discord.
//
// It is used to indicate that the HTTP response should be 202 Accepted
const InteractionResponseTypeAcknowledge InteractionResponseType = -1

// Constants for the InteractionResponseType(s)
const (
InteractionResponseTypePong InteractionResponseType = iota + 1
40 changes: 39 additions & 1 deletion discord/message.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
package discord

import (
"bytes"
"fmt"
"strconv"
"time"

"github.com/disgoorg/json"
@@ -48,7 +50,18 @@ const (
_
MessageTypeStageTopic
MessageTypeGuildApplicationPremiumSubscription
MessageTypePurchaseNotification MessageType = iota + 11
_
_
_
MessageTypeGuildIncidentAlertModeEnabled
MessageTypeGuildIncidentAlertModeDisabled
MessageTypeGuildIncidentReportRaid
MessageTypeGuildIncidentReportFalseAlarm
_
_
_
_
MessageTypePurchaseNotification
_
MessageTypePollResult
)
@@ -119,6 +132,7 @@ type Message struct {
Resolved *ResolvedData `json:"resolved,omitempty"`
Poll *Poll `json:"poll,omitempty"`
Call *MessageCall `json:"call,omitempty"`
Nonce Nonce `json:"nonce,omitempty"`
}

func (m *Message) UnmarshalJSON(data []byte) error {
@@ -490,6 +504,7 @@ const (
_
MessageFlagSuppressNotifications
MessageFlagIsVoiceMessage
MessageFlagHasSnapshot
MessageFlagsNone MessageFlags = 0
)

@@ -552,3 +567,26 @@ func unmarshalComponents(components []UnmarshalComponent) []ContainerComponent {
}
return containerComponents
}

// Nonce is a string or int used when sending a message to discord.
type Nonce string

// UnmarshalJSON unmarshals the Nonce from a string or int.
func (n *Nonce) UnmarshalJSON(b []byte) error {
if bytes.Equal(b, []byte("null")) {
return nil
}

unquoted, err := strconv.Unquote(string(b))
if err != nil {
i, err := strconv.ParseInt(string(b), 10, 64)
if err != nil {
return err
}
*n = Nonce(strconv.FormatInt(i, 10))
} else {
*n = Nonce(unquoted)
}

return nil
}
1 change: 1 addition & 0 deletions discord/subscription.go
Original file line number Diff line number Diff line change
@@ -11,6 +11,7 @@ type Subscription struct {
UserID snowflake.ID `json:"user_id"`
SkuIDs []snowflake.ID `json:"sku_ids"`
EntitlementIDs []snowflake.ID `json:"entitlement_ids"`
RenewalSkuIDs []snowflake.ID `json:"renewal_sku_ids"`
CurrentPeriodStart time.Time `json:"current_period_start"`
CurrentPeriodEnd time.Time `json:"current_period_end"`
Status SubscriptionStatus `json:"status"`
76 changes: 76 additions & 0 deletions events/interaction_events.go
Original file line number Diff line number Diff line change
@@ -42,6 +42,25 @@ func (e *ApplicationCommandInteractionCreate) Guild() (discord.Guild, bool) {
return discord.Guild{}, false
}

// Acknowledge acknowledges the interaction.
//
// This is used strictly for acknowledging the HTTP interaction request from discord. This responds with 202 Accepted.
//
// When using this, your first http request must be [rest.Interactions.CreateInteractionResponse] or [rest.Interactions.CreateInteractionResponseWithCallback]
//
// This does not produce a visible loading state to the user.
// You are expected to send a new http request within 3 seconds to respond to the interaction.
// This allows you to gracefully handle errors with your sent response & access the resulting message.
//
// If you want to create a visible loading state, use DeferCreateMessage.
//
// Source docs: [Discord Source docs]
//
// [Discord Source docs]: https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-callback
func (e *ApplicationCommandInteractionCreate) Acknowledge(opts ...rest.RequestOpt) error {
return e.Respond(discord.InteractionResponseTypeAcknowledge, nil, opts...)
}

// CreateMessage responds to the interaction with a new message.
func (e *ApplicationCommandInteractionCreate) CreateMessage(messageCreate discord.MessageCreate, opts ...rest.RequestOpt) error {
return e.Respond(discord.InteractionResponseTypeCreateMessage, messageCreate, opts...)
@@ -89,6 +108,25 @@ func (e *ComponentInteractionCreate) Guild() (discord.Guild, bool) {
return discord.Guild{}, false
}

// Acknowledge acknowledges the interaction.
//
// This is used strictly for acknowledging the HTTP interaction request from discord. This responds with 202 Accepted.
//
// When using this, your first http request must be [rest.Interactions.CreateInteractionResponse] or [rest.Interactions.CreateInteractionResponseWithCallback]
//
// This does not produce a visible loading state to the user.
// You are expected to send a new http request within 3 seconds to respond to the interaction.
// This allows you to gracefully handle errors with your sent response & access the resulting message.
//
// If you want to create a visible loading state, use DeferCreateMessage.
//
// Source docs: [Discord Source docs]
//
// [Discord Source docs]: https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-callback
func (e *ComponentInteractionCreate) Acknowledge(opts ...rest.RequestOpt) error {
return e.Respond(discord.InteractionResponseTypeAcknowledge, nil, opts...)
}

// CreateMessage responds to the interaction with a new message.
func (e *ComponentInteractionCreate) CreateMessage(messageCreate discord.MessageCreate, opts ...rest.RequestOpt) error {
return e.Respond(discord.InteractionResponseTypeCreateMessage, messageCreate, opts...)
@@ -146,6 +184,25 @@ func (e *AutocompleteInteractionCreate) Guild() (discord.Guild, bool) {
return discord.Guild{}, false
}

// Acknowledge acknowledges the interaction.
//
// This is used strictly for acknowledging the HTTP interaction request from discord. This responds with 202 Accepted.
//
// When using this, your first http request must be [rest.Interactions.CreateInteractionResponse] or [rest.Interactions.CreateInteractionResponseWithCallback]
//
// This does not produce a visible loading state to the user.
// You are expected to send a new http request within 3 seconds to respond to the interaction.
// This allows you to gracefully handle errors with your sent response & access the resulting message.
//
// If you want to create a visible loading state, use DeferCreateMessage.
//
// Source docs: [Discord Source docs]
//
// [Discord Source docs]: https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-callback
func (e *AutocompleteInteractionCreate) Acknowledge(opts ...rest.RequestOpt) error {
return e.Respond(discord.InteractionResponseTypeAcknowledge, nil, opts...)
}

// AutocompleteResult responds to the interaction with a slice of choices.
func (e *AutocompleteInteractionCreate) AutocompleteResult(choices []discord.AutocompleteChoice, opts ...rest.RequestOpt) error {
return e.Respond(discord.InteractionResponseTypeAutocompleteResult, discord.AutocompleteResult{Choices: choices}, opts...)
@@ -168,6 +225,25 @@ func (e *ModalSubmitInteractionCreate) Guild() (discord.Guild, bool) {
return discord.Guild{}, false
}

// Acknowledge acknowledges the interaction.
//
// This is used strictly for acknowledging the HTTP interaction request from discord. This responds with 202 Accepted.
//
// When using this, your first http request must be [rest.Interactions.CreateInteractionResponse] or [rest.Interactions.CreateInteractionResponseWithCallback]
//
// This does not produce a visible loading state to the user.
// You are expected to send a new http request within 3 seconds to respond to the interaction.
// This allows you to gracefully handle errors with your sent response & access the resulting message.
//
// If you want to create a visible loading state, use DeferCreateMessage.
//
// Source docs: [Discord Source docs]
//
// [Discord Source docs]: https://discord.com/developers/docs/interactions/receiving-and-responding#interaction-callback
func (e *ModalSubmitInteractionCreate) Acknowledge(opts ...rest.RequestOpt) error {
return e.Respond(discord.InteractionResponseTypeAcknowledge, nil, opts...)
}

// CreateMessage responds to the interaction with a new message.
func (e *ModalSubmitInteractionCreate) CreateMessage(messageCreate discord.MessageCreate, opts ...rest.RequestOpt) error {
return e.Respond(discord.InteractionResponseTypeCreateMessage, messageCreate, opts...)
6 changes: 3 additions & 3 deletions go.mod
Original file line number Diff line number Diff line change
@@ -7,13 +7,13 @@ require (
github.com/disgoorg/snowflake/v2 v2.0.3
github.com/gorilla/websocket v1.5.3
github.com/sasha-s/go-csync v0.0.0-20240107134140-fcbab37b09ad
github.com/stretchr/testify v1.9.0
golang.org/x/crypto v0.27.0
github.com/stretchr/testify v1.10.0
golang.org/x/crypto v0.31.0
)

require (
github.com/davecgh/go-spew v1.1.1 // indirect
github.com/pmezard/go-difflib v1.0.0 // indirect
golang.org/x/sys v0.25.0 // indirect
golang.org/x/sys v0.28.0 // indirect
gopkg.in/yaml.v3 v3.0.1 // indirect
)
12 changes: 6 additions & 6 deletions go.sum
Original file line number Diff line number Diff line change
@@ -10,12 +10,12 @@ github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZb
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/sasha-s/go-csync v0.0.0-20240107134140-fcbab37b09ad h1:qIQkSlF5vAUHxEmTbaqt1hkJ/t6skqEGYiMag343ucI=
github.com/sasha-s/go-csync v0.0.0-20240107134140-fcbab37b09ad/go.mod h1:/pA7k3zsXKdjjAiUhB5CjuKib9KJGCaLvZwtxGC8U0s=
github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg=
github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
golang.org/x/crypto v0.27.0 h1:GXm2NjJrPaiv/h1tb2UH8QfgC/hOf/+z0p6PT8o1w7A=
golang.org/x/crypto v0.27.0/go.mod h1:1Xngt8kV6Dvbssa53Ziq6Eqn0HqbZi5Z6R0ZpwQzt70=
golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34=
golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
golang.org/x/crypto v0.31.0 h1:ihbySMvVjLAeSH1IbfcRTkD/iNscyz8rGzjF/E5hV6U=
golang.org/x/crypto v0.31.0/go.mod h1:kDsLvtWBEx7MV9tJOj9bnXsPbxwJQ6csT/x4KIN4Ssk=
golang.org/x/sys v0.28.0 h1:Fksou7UEQUWlKvIdsqzJmUmCX3cZuD2+P3XyyzwMhlA=
golang.org/x/sys v0.28.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
4 changes: 2 additions & 2 deletions handler/mux.go
Original file line number Diff line number Diff line change
@@ -108,9 +108,9 @@ func (r *Mux) Match(path string, t discord.InteractionType, t2 int) bool {

// Handle handles the given interaction event.
func (r *Mux) Handle(path string, event *InteractionEvent) error {
handlerChain := Handler(func(event *InteractionEvent) error {
path = parseVariables(path, r.pattern, event.Vars)
path = parseVariables(path, r.pattern, event.Vars)

handlerChain := Handler(func(event *InteractionEvent) error {
t := event.Type()
var t2 int
switch i := event.Interaction.(type) {
8 changes: 8 additions & 0 deletions httpserver/server.go
Original file line number Diff line number Diff line change
@@ -167,6 +167,14 @@ func HandleInteraction(publicKey PublicKey, logger *slog.Logger, handleFunc Even
defer cancel()
select {
case response := <-responseChannel:

// if we only acknowledge the interaction, we don't need to send a response body
// we just need to send a 202 Accepted status
if response.Type == discord.InteractionResponseTypeAcknowledge {
w.WriteHeader(http.StatusAccepted)
return
}

if body, err = response.ToBody(); err != nil {
http.Error(w, "Internal Server Error", http.StatusInternalServerError)
errorChannel <- err
7 changes: 7 additions & 0 deletions rest/guilds.go
Original file line number Diff line number Diff line change
@@ -60,6 +60,8 @@ type Guilds interface {

GetGuildOnboarding(guildID snowflake.ID, opts ...RequestOpt) (*discord.GuildOnboarding, error)
UpdateGuildOnboarding(guildID snowflake.ID, onboardingUpdate discord.GuildOnboardingUpdate, opts ...RequestOpt) (*discord.GuildOnboarding, error)

UpdateGuildIncidentActions(guildID snowflake.ID, actionsUpdate discord.GuildIncidentActionsUpdate, opts ...RequestOpt) (*discord.GuildIncidentsData, error)
}

type guildImpl struct {
@@ -310,3 +312,8 @@ func (s *guildImpl) UpdateGuildOnboarding(guildID snowflake.ID, onboardingUpdate
err = s.client.Do(UpdateGuildOnboarding.Compile(nil, guildID), onboardingUpdate, &guildOnboarding, opts...)
return
}

func (s *guildImpl) UpdateGuildIncidentActions(guildID snowflake.ID, actionsUpdate discord.GuildIncidentActionsUpdate, opts ...RequestOpt) (incidentsData *discord.GuildIncidentsData, err error) {
err = s.client.Do(UpdateGuildIncidentActions.Compile(nil, guildID), actionsUpdate, &incidentsData, opts...)
return
}
3 changes: 2 additions & 1 deletion rest/rest_endpoints.go
Original file line number Diff line number Diff line change
@@ -44,7 +44,6 @@ var (
GetCurrentUserApplicationRoleConnection = NewNoBotAuthEndpoint(http.MethodGet, "/users/@me/applications/{application.id}/role-connection")
UpdateCurrentUserApplicationRoleConnection = NewNoBotAuthEndpoint(http.MethodPut, "/users/@me/applications/{application.id}/role-connection")
LeaveGuild = NewEndpoint(http.MethodDelete, "/users/@me/guilds/{guild.id}")
GetDMChannels = NewEndpoint(http.MethodGet, "/users/@me/channels")
CreateDMChannel = NewEndpoint(http.MethodPost, "/users/@me/channels")
)

@@ -93,6 +92,8 @@ var (
GetGuildOnboarding = NewEndpoint(http.MethodGet, "/guilds/{guild.id}/onboarding")
UpdateGuildOnboarding = NewEndpoint(http.MethodPut, "/guilds/{guild.id}/onboarding")

UpdateGuildIncidentActions = NewEndpoint(http.MethodPut, "/guilds/{guild.id}/incident-actions")

GetCurrentUserVoiceState = NewEndpoint(http.MethodGet, "/guilds/{guild.id}/voice-states/@me")
GetUserVoiceState = NewEndpoint(http.MethodGet, "/guilds/{guild.id}/voice-states/{user.id}")
UpdateCurrentUserVoiceState = NewEndpoint(http.MethodPatch, "/guilds/{guild.id}/voice-states/@me")
6 changes: 0 additions & 6 deletions rest/users.go
Original file line number Diff line number Diff line change
@@ -16,7 +16,6 @@ type Users interface {
GetUser(userID snowflake.ID, opts ...RequestOpt) (*discord.User, error)
UpdateCurrentUser(userUpdate discord.UserUpdate, opts ...RequestOpt) (*discord.OAuth2User, error)
LeaveGuild(guildID snowflake.ID, opts ...RequestOpt) error
GetDMChannels(opts ...RequestOpt) ([]discord.Channel, error)
CreateDMChannel(userID snowflake.ID, opts ...RequestOpt) (*discord.DMChannel, error)
}

@@ -38,11 +37,6 @@ func (s *userImpl) LeaveGuild(guildID snowflake.ID, opts ...RequestOpt) error {
return s.client.Do(LeaveGuild.Compile(nil, guildID), nil, nil, opts...)
}

func (s *userImpl) GetDMChannels(opts ...RequestOpt) (channels []discord.Channel, err error) {
err = s.client.Do(GetDMChannels.Compile(nil), nil, &channels, opts...)
return
}

func (s *userImpl) CreateDMChannel(userID snowflake.ID, opts ...RequestOpt) (channel *discord.DMChannel, err error) {
err = s.client.Do(CreateDMChannel.Compile(nil), discord.DMChannelCreate{RecipientID: userID}, &channel, opts...)
return