Documentation ¶
Overview ¶
Package disgord GoLang module for interacting with the Discord API
Index ¶
- Constants
- func AddGuildMemberRole(client httd.Puter, guildID, userID, roleID Snowflake) (err error)
- func AddPinnedChannelMessage(client httd.Puter, channelID, msgID Snowflake) (err error)
- func BulkDeleteMessages(client httd.Poster, chanID Snowflake, params *BulkDeleteMessagesParams) (err error)
- func CreateGuildBan(client httd.Puter, guildID, userID Snowflake, params *CreateGuildBanParams) (err error)
- func CreateGuildIntegration(client httd.Poster, guildID Snowflake, params *CreateGuildIntegrationParams) (err error)
- func DeleteAllReactions(client httd.Deleter, channelID, messageID Snowflake) (err error)
- func DeleteChannel(client httd.Deleter, id Snowflake) (err error)
- func DeleteChannelPermission(client httd.Deleter, channelID, overwriteID Snowflake) (err error)
- func DeleteGuild(client httd.Deleter, id Snowflake) (err error)
- func DeleteGuildEmoji(client httd.Deleter, guildID, emojiID Snowflake) (err error)
- func DeleteGuildIntegration(client httd.Deleter, guildID, integrationID Snowflake) (err error)
- func DeleteGuildRole(client httd.Deleter, guildID, roleID Snowflake) (err error)
- func DeleteMessage(client httd.Deleter, channelID, msgID Snowflake) (err error)
- func DeleteOwnReaction(client httd.Deleter, channelID, messageID Snowflake, emoji interface{}) (err error)
- func DeletePinnedChannelMessage(client httd.Deleter, channelID, msgID Snowflake) (err error)
- func DeleteUserReaction(client httd.Deleter, channelID, messageID, userID Snowflake, emoji interface{}) (err error)
- func DeleteWebhook(client httd.Deleter, webhookID Snowflake) (err error)
- func DeleteWebhookWithToken(client httd.Deleter, id Snowflake, token string) (err error)
- func EditChannelPermissions(client httd.Puter, chanID, overwriteID Snowflake, ...) (err error)
- func ExecuteGitHubWebhook(client httd.Poster, params *ExecuteWebhookParams, wait bool) (err error)
- func ExecuteSlackWebhook(client httd.Poster, params *ExecuteWebhookParams, wait bool) (err error)
- func ExecuteWebhook(client httd.Poster, params *ExecuteWebhookParams, wait bool, URLSuffix string) (err error)
- func GroupDMAddRecipient(client httd.Puter, channelID, userID Snowflake, ...) (err error)
- func GroupDMRemoveRecipient(client httd.Deleter, channelID, userID Snowflake) (err error)
- func LeaveGuild(client httd.Deleter, id Snowflake) (err error)
- func LibraryInfo() string
- func ModifyCurrentUserNick(client httd.Patcher, id Snowflake, params *ModifyCurrentUserNickParams) (nick string, err error)
- func ModifyGuildIntegration(client httd.Patcher, guildID, integrationID Snowflake, ...) (err error)
- func ModifyGuildMember(client httd.Patcher, guildID, userID Snowflake, ...) (err error)
- func RemoveGuildBan(client httd.Deleter, guildID, userID Snowflake) (err error)
- func RemoveGuildMember(client httd.Deleter, guildID, userID Snowflake) (err error)
- func RemoveGuildMemberRole(client httd.Deleter, guildID, userID, roleID Snowflake) (err error)
- func SyncGuildIntegration(client httd.Poster, guildID, integrationID Snowflake) (err error)
- func TriggerTypingIndicator(client httd.Poster, channelID Snowflake) (err error)
- type AddGuildMemberParams
- type Attachment
- type AuditLog
- type AuditLogChange
- type AuditLogEntry
- type AuditLogOption
- type Ban
- type BodyUserCreateDM
- type BulkDeleteMessagesParams
- type Cache
- type Cacher
- type Channel
- func CreateDM(client httd.Poster, recipientID Snowflake) (ret *Channel, err error)
- func CreateGroupDM(client httd.Poster, params *CreateGroupDMParams) (ret *Channel, err error)
- func CreateGuildChannel(client httd.Poster, id Snowflake, params *CreateGuildChannelParams) (ret *Channel, err error)
- func GetChannel(client httd.Getter, id Snowflake) (ret *Channel, err error)
- func GetGuildChannels(client httd.Getter, id Snowflake) (ret []*Channel, err error)
- func GetUserDMs(client httd.Getter) (ret []*Channel, err error)
- func ModifyChannel(client httd.Patcher, changes *ModifyChannelParams) (ret *Channel, err error)
- func NewChannel() *Channel
- func (c *Channel) Clear()
- func (c *Channel) Compare(other *Channel) bool
- func (c *Channel) Create()
- func (c *Channel) DeepCopy() *Channel
- func (c *Channel) Delete(client ChannelDeleter) (err error)
- func (c *Channel) Mention() string
- func (c *Channel) Replicate(channel *Channel, recipients []*User)
- func (c *Channel) SendMsg(client MessageSender, message *Message) (msg *Message, err error)
- func (c *Channel) SendMsgString(client MessageSender, content string) (msg *Message, err error)
- func (c *Channel) Update(client ChannelUpdater)
- type ChannelCreate
- type ChannelCreateCallback
- type ChannelDelete
- type ChannelDeleteCallback
- type ChannelDeleter
- type ChannelEmbed
- type ChannelEmbedAuthor
- type ChannelEmbedField
- type ChannelEmbedFooter
- type ChannelEmbedImage
- type ChannelEmbedProvider
- type ChannelEmbedThumbnail
- type ChannelEmbedVideo
- type ChannelFetcher
- type ChannelMessager
- type ChannelPinsUpdate
- type ChannelPinsUpdateCallback
- type ChannelUpdate
- type ChannelUpdateCallback
- type ChannelUpdater
- type Client
- func (c *Client) AddGuildMember(guildID, userID Snowflake, params *AddGuildMemberParams) (ret *Member, err error)
- func (c *Client) AddGuildMemberRole(guildID, userID, roleID Snowflake) (err error)
- func (c *Client) AddListener(evtName string, listener interface{})
- func (c *Client) AddListenerOnce(evtName string, listener interface{})
- func (c *Client) AddPinnedChannelMessage(channelID, msgID Snowflake) (err error)
- func (c *Client) BeginGuildPrune(id Snowflake, params *GuildPruneParams) (ret *GuildPruneCount, err error)
- func (c *Client) BulkDeleteMessages(chanID Snowflake, params *BulkDeleteMessagesParams) (err error)
- func (c *Client) Connect() (err error)
- func (c *Client) CreateChannelInvites(id Snowflake, params *CreateChannelInvitesParams) (ret *Invite, err error)
- func (c *Client) CreateChannelMessage(channelID Snowflake, params *CreateChannelMessageParams) (ret *Message, err error)
- func (c *Client) CreateDM(recipientID Snowflake) (ret *Channel, err error)
- func (c *Client) CreateGroupDM(params *CreateGroupDMParams) (ret *Channel, err error)
- func (c *Client) CreateGuild(params *CreateGuildParams) (ret *Guild, err error)
- func (c *Client) CreateGuildBan(guildID, userID Snowflake, params *CreateGuildBanParams) (err error)
- func (c *Client) CreateGuildChannel(id Snowflake, params *CreateGuildChannelParams) (ret *Channel, err error)
- func (c *Client) CreateGuildEmoji(guildID Snowflake, params *CreateGuildEmojiParams) (ret *Emoji, err error)
- func (c *Client) CreateGuildIntegration(guildID Snowflake, params *CreateGuildIntegrationParams) (err error)
- func (c *Client) CreateGuildRole(id Snowflake, params *CreateGuildRoleParams) (ret *Role, err error)
- func (c *Client) CreateReaction(channelID, messageID Snowflake, emoji interface{}) (ret *Reaction, err error)
- func (c *Client) CreateWebhook(channelID Snowflake, params *CreateWebhookParams) (ret *Webhook, err error)
- func (c *Client) DeleteAllReactions(channelID, messageID Snowflake) (err error)
- func (c *Client) DeleteChannel(id Snowflake) (err error)
- func (c *Client) DeleteChannelPermission(channelID, overwriteID Snowflake) (err error)
- func (c *Client) DeleteGuild(id Snowflake) (err error)
- func (c *Client) DeleteGuildEmoji(guildID, emojiID Snowflake) (err error)
- func (c *Client) DeleteGuildIntegration(guildID, integrationID Snowflake) (err error)
- func (c *Client) DeleteGuildRole(guildID, roleID Snowflake) (err error)
- func (c *Client) DeleteInvite(inviteCode string) (invite *Invite, err error)
- func (c *Client) DeleteMessage(channelID, msgID Snowflake) (err error)
- func (c *Client) DeleteOwnReaction(channelID, messageID Snowflake, emoji interface{}) (err error)
- func (c *Client) DeletePinnedChannelMessage(channelID, msgID Snowflake) (err error)
- func (c *Client) DeleteUserReaction(channelID, messageID, userID Snowflake, emoji interface{}) (err error)
- func (c *Client) DeleteWebhook(webhookID Snowflake) (err error)
- func (c *Client) DeleteWebhookWithToken(id Snowflake, token string) (err error)
- func (c *Client) Disconnect() (err error)
- func (c *Client) DisconnectOnInterrupt() (err error)
- func (c *Client) EditChannelPermissions(chanID, overwriteID Snowflake, params *EditChannelPermissionsParams) (err error)
- func (c *Client) EditMessage(chanID, msgID Snowflake, params *EditMessageParams) (ret *Message, err error)
- func (c *Client) Evt() EvtDispatcher
- func (c *Client) ExecuteGitHubWebhook(params *ExecuteWebhookParams, wait bool) (err error)
- func (c *Client) ExecuteSlackWebhook(params *ExecuteWebhookParams, wait bool) (err error)
- func (c *Client) ExecuteWebhook(params *ExecuteWebhookParams, wait bool, URLSuffix string) (err error)
- func (c *Client) GetChannel(id Snowflake) (ret *Channel, err error)
- func (c *Client) GetChannelInvites(id Snowflake) (ret []*Invite, err error)
- func (c *Client) GetChannelMessage(channelID, messageID Snowflake) (ret *Message, err error)
- func (c *Client) GetChannelMessages(channelID Snowflake, params URLParameters) (ret []*Message, err error)
- func (c *Client) GetChannelWebhooks(channelID Snowflake) (ret []*Webhook, err error)
- func (c *Client) GetCurrentUser() (ret *User, err error)
- func (c *Client) GetCurrentUserGuilds(params *GetCurrentUserGuildsParams) (ret []*Guild, err error)
- func (c *Client) GetGuild(id Snowflake) (ret *Guild, err error)
- func (c *Client) GetGuildAuditLogs(guildID Snowflake, params *GuildAuditLogsParams) (log *AuditLog, err error)
- func (c *Client) GetGuildBan(guildID, userID Snowflake) (ret *Ban, err error)
- func (c *Client) GetGuildBans(id Snowflake) (ret []*Ban, err error)
- func (c *Client) GetGuildChannels(id Snowflake) (ret []*Channel, err error)
- func (c *Client) GetGuildEmbed(guildID Snowflake) (ret *GuildEmbed, err error)
- func (c *Client) GetGuildEmoji(guildID, emojiID Snowflake) (ret *Emoji, err error)
- func (c *Client) GetGuildEmojis(id Snowflake) (ret []*Emoji, err error)
- func (c *Client) GetGuildIntegrations(id Snowflake) (ret []*Integration, err error)
- func (c *Client) GetGuildInvites(id Snowflake) (ret []*Invite, err error)
- func (c *Client) GetGuildMember(guildID, userID Snowflake) (ret *Member, err error)
- func (c *Client) GetGuildMembers(guildID, after Snowflake, limit int) (ret []*Member, err error)
- func (c *Client) GetGuildPruneCount(id Snowflake, params *GuildPruneParams) (ret *GuildPruneCount, err error)
- func (c *Client) GetGuildRoles(guildID Snowflake) (ret []*Role, err error)
- func (c *Client) GetGuildVanityURL(guildID Snowflake) (ret *PartialInvite, err error)
- func (c *Client) GetGuildVoiceRegions(id Snowflake) (ret []*VoiceRegion, err error)
- func (c *Client) GetGuildWebhooks(guildID Snowflake) (ret []*Webhook, err error)
- func (c *Client) GetInvite(inviteCode string, withCounts bool) (invite *Invite, err error)
- func (c *Client) GetPinnedMessages(channelID Snowflake) (ret []*Message, err error)
- func (c *Client) GetReaction(channelID, messageID Snowflake, emoji interface{}, params URLParameters) (ret []*User, err error)
- func (c *Client) GetUser(id Snowflake) (ret *User, err error)
- func (c *Client) GetUserConnections() (ret []*UserConnection, err error)
- func (c *Client) GetUserDMs() (ret []*Channel, err error)
- func (c *Client) GetVoiceRegions() (ret []*VoiceRegion, err error)
- func (c *Client) GetWebhook(id Snowflake) (ret *Webhook, err error)
- func (c *Client) GetWebhookWithToken(id Snowflake, token string) (ret *Webhook, err error)
- func (c *Client) GroupDMAddRecipient(channelID, userID Snowflake, params *GroupDMAddRecipientParams) (err error)
- func (c *Client) GroupDMRemoveRecipient(channelID, userID Snowflake) (err error)
- func (c *Client) LeaveGuild(id Snowflake) (err error)
- func (c *Client) ModifyChannel(changes *ModifyChannelParams) (ret *Channel, err error)
- func (c *Client) ModifyCurrentUser(params *ModifyCurrentUserParams) (ret *User, err error)
- func (c *Client) ModifyCurrentUserNick(id Snowflake, params *ModifyCurrentUserNickParams) (nick string, err error)
- func (c *Client) ModifyGuild(id Snowflake, params *ModifyGuildParams) (ret *Guild, err error)
- func (c *Client) ModifyGuildEmbed(guildID Snowflake, params *GuildEmbed) (ret *GuildEmbed, err error)
- func (c *Client) ModifyGuildEmoji(guildID, emojiID Snowflake, params *ModifyGuildEmojiParams) (ret *Emoji, err error)
- func (c *Client) ModifyGuildIntegration(guildID, integrationID Snowflake, params *ModifyGuildIntegrationParams) (err error)
- func (c *Client) ModifyGuildMember(guildID, userID Snowflake, params *ModifyGuildMemberParams) (err error)
- func (c *Client) ModifyGuildRole(guildID, roleID Snowflake, params *ModifyGuildRoleParams) (ret []*Role, err error)
- func (c *Client) ModifyGuildRolePositions(guildID Snowflake, params *ModifyGuildRolePositionsParams) (ret []*Role, err error)
- func (c *Client) ModifyWebhook(newWebhook *Webhook) (ret *Webhook, err error)
- func (c *Client) ModifyWebhookWithToken(newWebhook *Webhook) (ret *Webhook, err error)
- func (c *Client) RateLimiter() httd.RateLimiter
- func (c *Client) RemoveGuildBan(guildID, userID Snowflake) (err error)
- func (c *Client) RemoveGuildMember(guildID, userID Snowflake) (err error)
- func (c *Client) RemoveGuildMemberRole(guildID, userID, roleID Snowflake) (err error)
- func (c *Client) Req() httd.Requester
- func (c *Client) SendMsg(channelID Snowflake, message *Message) (msg *Message, err error)
- func (c *Client) SendMsgString(channelID Snowflake, content string) (msg *Message, err error)
- func (c *Client) State() Cacher
- func (c *Client) String() string
- func (c *Client) SyncGuildIntegration(guildID, integrationID Snowflake) (err error)
- func (c *Client) TriggerTypingIndicator(channelID Snowflake) (err error)
- func (c *Client) UpdateChannel(channel *Channel) (err error)
- func (c *Client) UpdateMessage(message *Message) (msg *Message, err error)
- type Config
- type CreateChannelInvitesParams
- type CreateChannelMessageParams
- type CreateGroupDMParams
- type CreateGuildBanParams
- type CreateGuildChannelParams
- type CreateGuildEmojiParams
- type CreateGuildIntegrationParams
- type CreateGuildParams
- type CreateGuildRoleParams
- type CreateWebhookParams
- type DefaultMessageNotificationLvl
- type DeletedMessage
- type Dispatch
- func (d *Dispatch) AddHandler(evtName string, listener interface{})
- func (d *Dispatch) AddHandlerOnce(evtName string, listener interface{})
- func (d *Dispatch) AllChan() <-chan interface{}
- func (d *Dispatch) ChannelCreateChan() <-chan *ChannelCreate
- func (d *Dispatch) ChannelDeleteChan() <-chan *ChannelDelete
- func (d *Dispatch) ChannelPinsUpdateChan() <-chan *ChannelPinsUpdate
- func (d *Dispatch) ChannelUpdateChan() <-chan *ChannelUpdate
- func (d *Dispatch) GuildBanAddChan() <-chan *GuildBanAdd
- func (d *Dispatch) GuildBanRemoveChan() <-chan *GuildBanRemove
- func (d *Dispatch) GuildCreateChan() <-chan *GuildCreate
- func (d *Dispatch) GuildDeleteChan() <-chan *GuildDelete
- func (d *Dispatch) GuildEmojisUpdateChan() <-chan *GuildEmojisUpdate
- func (d *Dispatch) GuildIntegrationsUpdateChan() <-chan *GuildIntegrationsUpdate
- func (d *Dispatch) GuildMemberAddChan() <-chan *GuildMemberAdd
- func (d *Dispatch) GuildMemberRemoveChan() <-chan *GuildMemberRemove
- func (d *Dispatch) GuildMemberUpdateChan() <-chan *GuildMemberUpdate
- func (d *Dispatch) GuildMembersChunkChan() <-chan *GuildMembersChunk
- func (d *Dispatch) GuildRoleCreateChan() <-chan *GuildRoleCreate
- func (d *Dispatch) GuildRoleDeleteChan() <-chan *GuildRoleDelete
- func (d *Dispatch) GuildRoleUpdateChan() <-chan *GuildRoleUpdate
- func (d *Dispatch) GuildUpdateChan() <-chan *GuildUpdate
- func (d *Dispatch) MessageCreateChan() <-chan *MessageCreate
- func (d *Dispatch) MessageDeleteBulkChan() <-chan *MessageDeleteBulk
- func (d *Dispatch) MessageDeleteChan() <-chan *MessageDelete
- func (d *Dispatch) MessageReactionAddChan() <-chan *MessageReactionAdd
- func (d *Dispatch) MessageReactionRemoveAllChan() <-chan *MessageReactionRemoveAll
- func (d *Dispatch) MessageReactionRemoveChan() <-chan *MessageReactionRemove
- func (d *Dispatch) MessageUpdateChan() <-chan *MessageUpdate
- func (d *Dispatch) PresenceUpdateChan() <-chan *PresenceUpdate
- func (d *Dispatch) ReadyChan() <-chan *Ready
- func (d *Dispatch) ResumedChan() <-chan *Resumed
- func (d *Dispatch) TypingStartChan() <-chan *TypingStart
- func (d *Dispatch) UserUpdateChan() <-chan *UserUpdate
- func (d *Dispatch) VoiceServerUpdateChan() <-chan *VoiceServerUpdate
- func (d *Dispatch) VoiceStateUpdateChan() <-chan *VoiceStateUpdate
- func (d *Dispatch) WebhooksUpdateChan() <-chan *WebhooksUpdate
- type EditChannelPermissionsParams
- type EditMessageParams
- type Emoji
- func CreateGuildEmoji(client httd.Poster, guildID Snowflake, params *CreateGuildEmojiParams) (ret *Emoji, err error)
- func GetGuildEmoji(client httd.Getter, guildID, emojiID Snowflake) (ret *Emoji, err error)
- func ListGuildEmojis(client httd.Getter, id Snowflake) (ret []*Emoji, err error)
- func ModifyGuildEmoji(client httd.Patcher, guildID, emojiID Snowflake, ...) (ret *Emoji, err error)
- type EventCallback
- type EvtDispatcher
- type ExecuteWebhookParams
- type ExplicitContentFilterLvl
- type GetChannelMessagesParams
- type GetCurrentUserGuildsParams
- type GetReactionURLParams
- type GroupDMAddRecipientParams
- type Guild
- func CreateGuild(client httd.Poster, params *CreateGuildParams) (ret *Guild, err error)
- func GetCurrentUserGuilds(client httd.Getter, params *GetCurrentUserGuildsParams) (ret []*Guild, err error)
- func GetGuild(client httd.Getter, id Snowflake) (ret *Guild, err error)
- func ModifyGuild(client httd.Patcher, id Snowflake, params *ModifyGuildParams) (ret *Guild, err error)
- func ModifyGuildChannelPositions(client httd.Patcher, id Snowflake, params *ModifyGuildChannelPositionsParams) (ret *Guild, err error)
- func NewGuild() *Guild
- func NewGuildFromJSON(data []byte) *Guild
- func NewGuildFromUnavailable(gu *GuildUnavailable) *Guild
- func NewPartialGuild(ID Snowflake) *Guild
- func (g *Guild) AddChannel(c *Channel) error
- func (g *Guild) AddMember(member *Member) error
- func (g *Guild) AddRole(role *Role) error
- func (g *Guild) Channel(id Snowflake) (*Channel, error)
- func (g *Guild) Clear()
- func (g *Guild) Compare(other *Guild) bool
- func (g *Guild) DeepCopy() *Guild
- func (g *Guild) DeleteChannel(c *Channel) error
- func (g *Guild) DeleteChannelByID(ID Snowflake) error
- func (g *Guild) DeleteRoleByID(ID Snowflake)
- func (g *Guild) MarshalJSON() ([]byte, error)
- func (g *Guild) Member(id Snowflake) (*Member, error)
- func (g *Guild) MemberByName(name string) ([]*Member, error)
- func (g *Guild) Role(id Snowflake) (*Role, error)
- func (g *Guild) RoleByName(name string) ([]*Role, error)
- func (g *Guild) Update(new *Guild)
- func (g *Guild) UpdatePresence(p *UserPresence)
- func (g *Guild) UpdateRole(r *Role)
- type GuildAuditLogsParams
- type GuildBanAdd
- type GuildBanAddCallback
- type GuildBanRemove
- type GuildBanRemoveCallback
- type GuildCreate
- type GuildCreateCallback
- type GuildDelete
- type GuildDeleteCallback
- type GuildEmbed
- type GuildEmojisUpdate
- type GuildEmojisUpdateCallback
- type GuildIntegrationsUpdate
- type GuildIntegrationsUpdateCallback
- type GuildInterface
- type GuildMemberAdd
- type GuildMemberAddCallback
- type GuildMemberRemove
- type GuildMemberRemoveCallback
- type GuildMemberUpdate
- type GuildMemberUpdateCallback
- type GuildMembersChunk
- type GuildMembersChunkCallback
- type GuildPruneCount
- type GuildPruneParams
- type GuildRoleCreate
- type GuildRoleCreateCallback
- type GuildRoleDelete
- type GuildRoleDeleteCallback
- type GuildRoleUpdate
- type GuildRoleUpdateCallback
- type GuildUnavailable
- type GuildUpdate
- type GuildUpdateCallback
- type Hello
- type HelloCallback
- type Integration
- type IntegrationAccount
- type InvalidSession
- type InvalidSessionCallback
- type Invite
- func CreateChannelInvites(client httd.Poster, id Snowflake, params *CreateChannelInvitesParams) (ret *Invite, err error)
- func DeleteInvite(client httd.Deleter, inviteCode string) (invite *Invite, err error)
- func GetChannelInvites(client httd.Getter, id Snowflake) (ret []*Invite, err error)
- func GetGuildInvites(client httd.Getter, id Snowflake) (ret []*Invite, err error)
- func GetInvite(client httd.Getter, inviteCode string, withCounts bool) (invite *Invite, err error)
- type InviteMetadata
- type MFALvl
- type Marshaler
- type Member
- func AddGuildMember(client httd.Puter, guildID, userID Snowflake, params *AddGuildMemberParams) (ret *Member, err error)
- func GetGuildMember(client httd.Getter, guildID, userID Snowflake) (ret *Member, err error)
- func GetGuildMembers(client httd.Getter, guildID, after Snowflake, limit int) (ret []*Member, err error)
- type Message
- func CreateChannelMessage(client httd.Poster, channelID Snowflake, params *CreateChannelMessageParams) (ret *Message, err error)
- func EditMessage(client httd.Patcher, chanID, msgID Snowflake, params *EditMessageParams) (ret *Message, err error)
- func GetChannelMessage(client httd.Getter, channelID, messageID Snowflake) (ret *Message, err error)
- func GetChannelMessages(client httd.Getter, channelID Snowflake, params URLParameters) (ret []*Message, err error)
- func GetPinnedMessages(client httd.Getter, channelID Snowflake) (ret []*Message, err error)
- func NewMessage() *Message
- func (m *Message) AddReaction(reaction *Reaction)
- func (m *Message) Delete(client MessageDeleter) (err error)
- func (m *Message) MarshalJSON() ([]byte, error)
- func (m *Message) RemoveReaction(id Snowflake)
- func (m *Message) Respond(client MessageSender, message *Message) (msg *Message, err error)
- func (m *Message) RespondString(client MessageSender, content string) (msg *Message, err error)
- func (m *Message) Send(client MessageSender) (msg *Message, err error)
- func (m *Message) Update(client MessageUpdater) (msg *Message, err error)
- type MessageActivity
- type MessageApplication
- type MessageCreate
- type MessageCreateCallback
- type MessageDelete
- type MessageDeleteBulk
- type MessageDeleteBulkCallback
- type MessageDeleteCallback
- type MessageDeleter
- type MessageReactionAdd
- type MessageReactionAddCallback
- type MessageReactionRemove
- type MessageReactionRemoveAll
- type MessageReactionRemoveAllCallback
- type MessageReactionRemoveCallback
- type MessageSender
- type MessageUpdate
- type MessageUpdateCallback
- type MessageUpdater
- type ModifyChannelParams
- type ModifyCurrentUserNickParams
- type ModifyCurrentUserParams
- type ModifyGuildChannelPositionsParams
- type ModifyGuildEmojiParams
- type ModifyGuildIntegrationParams
- type ModifyGuildMemberParams
- type ModifyGuildParams
- type ModifyGuildRoleParams
- type ModifyGuildRolePositionsParams
- type PartialChannel
- type PartialEmoji
- type PartialGuild
- type PartialInvite
- type PermissionOverwrite
- type PresenceUpdate
- type PresenceUpdateCallback
- type Reaction
- type Ready
- type ReadyCallback
- type Resumed
- type ResumedCallback
- type Role
- func CreateGuildRole(client httd.Poster, id Snowflake, params *CreateGuildRoleParams) (ret *Role, err error)
- func GetGuildRoles(client httd.Getter, guildID Snowflake) (ret []*Role, err error)
- func ModifyGuildRole(client httd.Patcher, guildID, roleID Snowflake, params *ModifyGuildRoleParams) (ret []*Role, err error)
- func ModifyGuildRolePositions(client httd.Patcher, guildID Snowflake, params *ModifyGuildRolePositionsParams) (ret []*Role, err error)
- func NewRole() *Role
- type Session
- type Snowflake
- type Timestamp
- type TypingStart
- type TypingStartCallback
- type URLParameters
- type Unmarshaler
- type User
- func GetCurrentUser(client httd.Getter) (ret *User, err error)
- func GetReaction(client httd.Getter, channelID, messageID Snowflake, emoji interface{}, ...) (ret []*User, err error)
- func GetUser(client httd.Getter, id Snowflake) (ret *User, err error)
- func ModifyCurrentUser(client httd.Patcher, params *ModifyCurrentUserParams) (ret *User, err error)
- func NewUser() *User
- func (u *User) Clear()
- func (u *User) DeepCopy() *User
- func (u *User) MarshalJSON() ([]byte, error)
- func (u *User) Mention() string
- func (u *User) MentionNickname() string
- func (u *User) Partial() bool
- func (u *User) SendMsg(session Session, message *Message) (channel *Channel, msg *Message, err error)
- func (u *User) SendMsgString(session Session, content string) (channel *Channel, msg *Message, err error)
- func (u *User) String() string
- func (u *User) Valid() bool
- type UserActivity
- type UserConnection
- type UserInterface
- type UserPresence
- type UserUpdate
- type UserUpdateCallback
- type VerificationLvl
- type VoiceRegion
- type VoiceServerUpdate
- type VoiceServerUpdateCallback
- type VoiceState
- type VoiceStateUpdate
- type VoiceStateUpdateCallback
- type Webhook
- func CreateWebhook(client httd.Poster, channelID Snowflake, params *CreateWebhookParams) (ret *Webhook, err error)
- func GetChannelWebhooks(client httd.Getter, channelID Snowflake) (ret []*Webhook, err error)
- func GetGuildWebhooks(client httd.Getter, guildID Snowflake) (ret []*Webhook, err error)
- func GetWebhook(client httd.Getter, id Snowflake) (ret *Webhook, err error)
- func GetWebhookWithToken(client httd.Getter, id Snowflake, token string) (ret *Webhook, err error)
- func ModifyWebhook(client httd.Patcher, newWebhook *Webhook) (ret *Webhook, err error)
- func ModifyWebhookWithToken(client httd.Patcher, newWebhook *Webhook) (ret *Webhook, err error)
- type WebhooksUpdate
- type WebhooksUpdateCallback
Constants ¶
const ( // JSONEncoding const for JSON encoding type JSONEncoding = "json" // APIVersion desired API version to use APIVersion = 6 // February 5, 2018 // DefaultAPIVersion the default Discord API version DefaultAPIVersion = 6 // GitHubURL complete url for this project GitHubURL = "https://github.com/andersfylling/disgord" )
const ( AuditLogEvtGuildUpdate = 1 AuditLogEvtChannelCreate = 10 AuditLogEvtChannelUpdate = 11 AuditLogEvtChannelDelete = 12 AuditLogEvtOverwriteCreate = 13 AuditLogEvtOverwriteUpdate = 14 AuditLogEvtOverwriteDelete = 15 AuditLogEvtMemberKick = 20 AuditLogEvtMemberPrune = 21 AuditLogEvtMemberBanAdd = 22 AuditLogEvtMemberBanRemove = 23 AuditLogEvtMemberUpdate = 24 AuditLogEvtMemberRoleUpdate = 25 AuditLogEvtRoleCreate = 30 AuditLogEvtRoleUpdate = 31 AuditLogEvtRoleDelete = 32 AuditLogEvtInviteCreate = 40 AuditLogEvtInviteUpdate = 41 AuditLogEvtInviteDelete = 42 AuditLogEvtWebhookCreate = 50 AuditLogEvtWebhookUpdate = 51 AuditLogEvtWebhookDelete = 52 AuditLogEvtEmojiCreate = 60 AuditLogEvtEmojiUpdate = 61 AuditLogEvtEmojiDelete = 62 AuditLogEvtMessageDelete = 72 )
const ( // key name, identifier changed, type, description AuditLogChangeKeyName = "name" // guild string name changed AuditLogChangeKeyIconHash = "icon_hash" // guild string icon changed AuditLogChangeKeySplashHash = "splash_hash" // guild string invite splash page artwork changed AuditLogChangeKeyOwnerID = "owner_id" // guild snowflake owner changed AuditLogChangeKeyRegion = "region" // guild string region changed AuditLogChangeKeyAFKChannelID = "afk_channel_id" // guild snowflake afk channel changed AuditLogChangeKeyAFKTimeout = "afk_timeout" // guild integer afk timeout duration changed AuditLogChangeKeyMFALevel = "mfa_level" // guild integer two-factor auth requirement changed AuditLogChangeKeyVerificationLevel = "verification_level" // guild integer required verification level changed AuditLogChangeKeyExplicitContentFilter = "explicit_content_filter" // guild integer change in whose messages are scanned and deleted for explicit content in the server AuditLogChangeKeyDefaultMessageNotifications = "default_message_notifications" // guild integer default message notification level changed AuditLogChangeKeyVanityURLCode = "vanity_url_code" // guild string guild invite vanity url changed AuditLogChangeKeyAdd = "$add" // add guild array of role objects new role added AuditLogChangeKeyRemove = "$remove" // remove guild array of role objects role removed AuditLogChangeKeyPruneDeleteDays = "prune_delete_days" // guild integer change in number of days after which inactive and role-unassigned members are kicked AuditLogChangeKeyWidgetEnabled = "widget_enabled" // guild bool server widget enabled/disable AuditLogChangeKeyWidgetChannelID = "widget_channel_id" // guild snowflake channel id of the server widget changed AuditLogChangeKeyPosition = "position" // channel integer text or voice channel position changed AuditLogChangeKeyTopic = "topic" // channel string text channel topic changed AuditLogChangeKeyBitrate = "bitrate" // channel integer voice channel bitrate changed AuditLogChangeKeyPermissionOverwrites = "permission_overwrites" // channel array of channel overwrite objects permissions on a channel changed AuditLogChangeKeyNSFW = "nsfw" // channel bool channel nsfw restriction changed AuditLogChangeKeyApplicationID = "application_id" // channel snowflake application id of the added or removed webhook or bot AuditLogChangeKeyPermissions = "permissions" // role integer permissions for a role changed AuditLogChangeKeyColor = "color" // role integer role color changed AuditLogChangeKeyHoist = "hoist" // role bool role is now displayed/no longer displayed separate from online users AuditLogChangeKeyMentionable = "mentionable" // role bool role is now mentionable/unmentionable AuditLogChangeKeyAllow = "allow" // role integer a permission on a text or voice channel was allowed for a role AuditLogChangeKeyDeny = "deny" // role integer a permission on a text or voice channel was denied for a role AuditLogChangeKeyCode = "code" // invite string invite code changed AuditLogChangeKeyChannelID = "channel_id" // invite snowflake channel for invite code changed AuditLogChangeKeyInviterID = "inviter_id" // invite snowflake person who created invite code changed AuditLogChangeKeyMaxUses = "max_uses" // invite integer change to max number of times invite code can be used AuditLogChangeKeyUses = "uses" // invite integer number of times invite code used changed AuditLogChangeKeyMaxAge = "max_age" // invite integer how long invite code lasts changed AuditLogChangeKeyTemporary = "temporary" // invite bool invite code is temporary/never expires AuditLogChangeKeyDeaf = "deaf" // user bool user server deafened/undeafened AuditLogChangeKeyMute = "mute" // user bool user server muted/unmuteds AuditLogChangeKeyNick = "nick" // user string user nickname changed AuditLogChangeKeyAvatarHash = "avatar_hash" // user string user avatar changed AuditLogChangeKeyID = "id" // any snowflake the id of the changed entity - sometimes used in conjunction with other keys AuditLogChangeKeyType = "type" // any integer (channel type) or string type of entity created )
const ( // Channel types // https://discordapp.com/developers/docs/resources/channel#channel-object-channel-types ChannelTypeGuildText uint = iota ChannelTypeDM ChannelTypeGuildVoice ChannelTypeGroupDM ChannelTypeGuildCategory )
const ( MessageActivityTypeJoin MessageActivityTypeSpectate MessageActivityTypeListen MessageActivityTypeJoinRequest )
const ( MessageTypeDefault = iota MessageTypeRecipientAdd MessageTypeRecipientRemove MessageTypeCall MessageTypeChannelNameChange MessageTypeChannelIconChange MessageTypeChannelPinnedMessage MessageTypeGuildMemberJoin )
const ( ReadMessagesPermission = 1 << (iota + 10) SendMessagesPermission SendTTSMessagesPermission ManageMessagesPermission EmbedLinksPermission AttachFilesPermission ReadMessageHistoryPermission MentionEveryonePermission UseExternalEmojisPermission )
Constants for the different bit offsets of text channel permissions
const ( VoiceConnectPermission = 1 << (iota + 20) VoiceSpeakPermission VoiceMuteMembersPermission VoiceDeafenMembersPermission VoiceMoveMembersPermission VoiceUseVADPermission )
Constants for the different bit offsets of voice permissions
const ( ChangeNicknamePermission = 1 << (iota + 26) ManageNicknamesPermission ManageRolesPermission ManageWebhooksPermission ManageEmojisPermission )
Constants for general management.
const ( CreateInstantInvitePermission = 1 << iota KickMembersPermission BanMembersPermission AdministratorPermission ManageChannelsPermission ManageServerPermission AddReactionsPermission ViewAuditLogsPermission AllTextPermission = ReadMessagesPermission | SendMessagesPermission | SendTTSMessagesPermission | ManageMessagesPermission | EmbedLinksPermission | AttachFilesPermission | ReadMessageHistoryPermission | MentionEveryonePermission AllVoicePermission = VoiceConnectPermission | VoiceSpeakPermission | VoiceMuteMembersPermission | VoiceDeafenMembersPermission | VoiceMoveMembersPermission | VoiceUseVADPermission AllChannelPermission = AllTextPermission | AllVoicePermission | CreateInstantInvitePermission | ManageRolesPermission | ManageChannelsPermission | AddReactionsPermission | ViewAuditLogsPermission AllPermission = AllChannelPermission | KickMembersPermission | BanMembersPermission | ManageServerPermission | AdministratorPermission )
Constants for the different bit offsets of general permissions
const ( // StatusIdle presence status for idle StatusIdle = "idle" // StatusDnd presence status for dnd StatusDnd = "dnd" // StatusOnline presence status for online StatusOnline = "online" // StatusOffline presence status for offline StatusOffline = "offline" )
const (
EndpointGuild = "/guilds/"
)
const EventAllEvents = "GOD_DAMN_EVERYTHING"
EventAllEvents keys that does not fit within one of the existing files goes here
const EventChannelCreate = "CHANNEL_CREATE"
EventChannelCreate Sent when a new channel is created, relevant to the current
user. The inner payload is a DM channel or guild channel object.
const EventChannelDelete = "CHANNEL_DELETE"
EventChannelDelete Sent when a channel relevant to the current user is deleted.
The inner payload is a DM or Guild channel object.
const EventChannelPinsUpdate = "CHANNEL_PINS_UPDATE"
EventChannelPinsUpdate Sent when a message is pinned or unpinned in a text
channel. This is not sent when a pinned message is deleted. Fields: * ChannelID int64 or discord.Snowflake * LastPinTimestamp time.Now().UTC().Format(time.RFC3339)
TODO fix.
const EventChannelUpdate = "CHANNEL_UPDATE"
EventChannelUpdate Sent when a channel is updated. The inner payload is a guild
channel object.
const EventGuildBanAdd = "GUILD_BAN_ADD"
EventGuildBanAdd Sent when a user is banned from a guild. The inner payload is
a user object, with an extra guild_id key.
const EventGuildBanRemove = "GUILD_BAN_REMOVE"
EventGuildBanRemove Sent when a user is unbanned from a guild. The inner
payload is a user object, with an extra guild_id key.
const EventGuildCreate = "GUILD_CREATE"
EventGuildCreate This event can be sent in three different scenarios:
- When a user is initially connecting, to lazily load and backfill information for all unavailable guilds sent in the Ready event.
- When a Guild becomes available again to the client.
- When the current user joins a new Guild. The inner payload is a guild object, with all the extra fields specified.
const EventGuildDelete = "GUILD_DELETE"
EventGuildDelete Sent when a guild becomes unavailable during a guild outage,
or when the user leaves or is removed from a guild. The inner payload is an unavailable guild object. If the unavailable field is not set, the user was removed from the guild.
const EventGuildEmojisUpdate = "GUILD_EMOJI_UPDATE"
EventGuildEmojisUpdate Sent when a guild's emojis have been updated.
Fields: * GuildID int64 or discord.Snowflake
const EventGuildIntegrationsUpdate = "GUILD_INTEGRATIONS_UPDATE"
EventGuildIntegrationsUpdate Sent when a guild integration is updated.
Fields: * GuildID int64 or discord.Snowflake * Emojis []*discord.emoji.Emoji
const EventGuildMemberAdd = "GUILD_MEMBER_ADD"
EventGuildMemberAdd Sent when a new user joins a guild. The inner payload is a
guild member object with these extra fields: * GuildID int64 or discord.Snowflake
const EventGuildMemberRemove = "GUILD_MEMBER_REMOVE"
EventGuildMemberRemove Sent when a user is removed from a guild
(leave/kick/ban). Fields: * GuildID int64 or discord.Snowflake * User *discord.user.User
const EventGuildMemberUpdate = "GUILD_MEMBER_UPDATE"
EventGuildMemberUpdate Sent when a guild member is updated.
Fields: * GuildID int64 or discord.Snowflake * Roles []int64 or []discord.Snowflake * User *discord.user.User * Nick string
const EventGuildMembersChunk = "GUILD_MEMBER_CHUNK"
EventGuildMemberChunk Sent in response to Gateway Request Guild Members.
Fields: * GuildID int64 or discord.Snowflake * Members []*discord.member.Member
const EventGuildRoleCreate = "GUILD_ROLE_CREATE"
EventGuildRoleCreate Sent when a guild role is created.
Fields: * GuildID int64 or discord.Snowflake * Role *discord.role.Role
const EventGuildRoleDelete = "GUILD_ROLE_DELETE"
EventGuildRoleDelete Sent when a guild role is created.
Fields: * GuildID int64 or discord.Snowflake * RoleID int64 or discord.Snowflake
const EventGuildRoleUpdate = "GUILD_ROLE_UPDATE"
EventGuildRoleUpdate Sent when a guild role is created.
Fields: * GuildID int64 or discord.Snowflake * Role *discord.role.Role
const EventGuildUpdate = "GUILD_UPDATE"
EventGuildUpdate Sent when a guild is updated. The inner payload is a guild
object.
const EventMessageCreate = "MESSAGE_CREATE"
EventMessageCreate Sent when a message is created. The inner payload is a
message object.
const EventMessageDelete = "MESSAGE_DELETE"
EventMessageDelete Sent when a message is deleted.
Fields: * ID int64 or discord.Snowflake * ChannelID int64 or discord.Snowflake
const EventMessageDeleteBulk = "MESSAGE_DELETE_BULK"
EventMessageDeleteBulk Sent when multiple messages are deleted at once.
Fields: * IDs []int64 or []discord.Snowflake * ChannelID int64 or discord.Snowflake
const EventMessageReactionAdd = "MESSAGE_REACTION_ADD"
EventMessageReactionAdd Sent when a user adds a reaction to a message.
Fields: * UserID int64 or discord.Snowflake * ChannelID int64 or discord.Snowflake * MessageID int64 or discord.Snowflake * Emoji *discord.emoji.Emoji
const EventMessageReactionRemove = "MESSAGE_REACTION_REMOVE"
EventMessageReactionRemove Sent when a user removes a reaction from a message.
Fields: * UserID int64 or discord.Snowflake * ChannelID int64 or discord.Snowflake * MessageID int64 or discord.Snowflake * Emoji *discord.emoji.Emoji
const EventMessageReactionRemoveAll = "MESSAGE_REACTION_REMOVE_ALL"
EventMessageReactionRemoveAll Sent when a user explicitly removes all reactions
from a message. Fields: * ChannelID int64 or discord.Snowflake * MessageID int64 or discord.Snowflake
const EventMessageUpdate = "MESSAGE_UPDATE"
EventMessageUpdate Sent when a message is updated. The inner payload is a
message object. NOTE! Has _at_least_ the GuildID and ChannelID fields.
const EventPresenceUpdate = "PRESENCE_UPDATE"
EventPresenceUpdate A user's presence is their current state on a guild.
This event is sent when a user's presence is updated for a guild. Fields: User *discord.user.User Roles []*discord.role.Role Game *discord.game.Game GuildID int64 or discord.Snowflake Status *string or *discord.presence.Status
const EventReady = "READY"
EventReady The ready event is dispatched when a client has completed the
initial handshake with the gateway (for new sessions). The ready event can be the largest and most complex event the gateway will send, as it contains all the state required for a client to begin interacting with the rest of the platform. Fields: * V uint8 * User *discord.user.User * PrivateChannels []*discord.channel.Private * Guilds []*discord.guild.Unavailable * SessionID string * Trace []string
const EventResumed = "RESUMED"
EventResumed The resumed event is dispatched when a client has sent a resume
payload to the gateway (for resuming existing sessions). Fields: * Trace []string
const EventTypingStart = "TYPING_START"
EventTypingStart Sent when a user starts typing in a channel.
Fields: TODO
const EventUserUpdate = "USER_UPDATE"
EventUserUpdate Sent when properties about the user change. Inner payload is a
user object.
const EventVoiceServerUpdate = "VOICE_SERVER_UPDATE"
EventVoiceServerUpdate Sent when a guild's voice server is updated. This is
sent when initially connecting to voice, and when the current voice instance fails over to a new server. Fields: * Token string or discord.Token * ChannelID int64 or discord.Snowflake * Endpoint string or discord.Endpoint
const EventVoiceStateUpdate = "VOICE_STATE_UPDATE"
EventVoiceStateUpdate Sent when someone joins/leaves/moves voice channels.
Inner payload is a voice state object.
const EventWebhooksUpdate = "WEBHOOK_UPDATE"
EventWebhooksUpdate Sent when a guild channel's webhook is created, updated, or
deleted. Fields: * GuildID int64 or discord.Snowflake * ChannelID int64 or discord.Snowflake
Variables ¶
This section is empty.
Functions ¶
func AddGuildMemberRole ¶ added in v0.6.0
AddGuildMemberRole [PUT] Adds a role to a guild member. Requires the 'MANAGE_ROLES' permission. Returns a 204
empty response on success. Fires a Guild Member Update Gateway event.
Endpoint /guilds/{guild.id}/members/{user.id}/roles/{role.id} Rate limiter /guilds/{guild.id}/members TODO: I don't know if this is correct Discord documentation https://discordapp.com/developers/docs/resources/guild#add-guild-member-role Reviewed 2018-08-18 Comment -
func AddPinnedChannelMessage ¶ added in v0.6.0
AddPinnedChannelMessage [GET] Pin a message in a channel. Requires the 'MANAGE_MESSAGES' permission.
Returns a 204 empty response on success.
Endpoint /channels/{channel.id}/pins/{message.id} Rate limiter [MAJOR] /channels/{channel.id}/pins Discord documentation https://discordapp.com/developers/docs/resources/channel#add-pinned-channel-message Reviewed 2018-06-10 Comment -
func BulkDeleteMessages ¶ added in v0.6.0
func BulkDeleteMessages(client httd.Poster, chanID Snowflake, params *BulkDeleteMessagesParams) (err error)
BulkDeleteMessages [POST] Delete multiple messages in a single request. This endpoint can only be used
on guild channels and requires the 'MANAGE_MESSAGES' permission. Returns a 204 empty response on success. Fires multiple Message Delete Gateway events.Any message IDs given that do not exist or are invalid will count towards the minimum and maximum message count (currently 2 and 100 respectively). Additionally, duplicated IDs will only be counted once.
Endpoint /channels/{channel.id}/messages/bulk-delete Rate limiter [MAJOR] /channels/{channel.id}/messages [DELETE] TODO: is this limiter key incorrect? Discord documentation https://discordapp.com/developers/docs/resources/channel#delete-message Reviewed 2018-06-10 Comment This endpoint will not delete messages older than 2 weeks, and will fail if
any message provided is older than that.
func CreateGuildBan ¶ added in v0.6.0
func CreateGuildBan(client httd.Puter, guildID, userID Snowflake, params *CreateGuildBanParams) (err error)
CreateGuildBan [PUT] Create a guild ban, and optionally delete previous messages sent by the banned user.
Requires the 'BAN_MEMBERS' permission. Returns a 204 empty response on success. Fires a Guild Ban Add Gateway event.
Endpoint /guilds/{guild.id}/bans/{user.id} Rate limiter /guilds/{guild.id}/bans Discord documentation https://discordapp.com/developers/docs/resources/guild#create-guild-ban Reviewed 2018-08-18 Comment -
func CreateGuildIntegration ¶ added in v0.6.0
func CreateGuildIntegration(client httd.Poster, guildID Snowflake, params *CreateGuildIntegrationParams) (err error)
CreateGuildIntegration [POST] Attach an integration object from the current user to the guild. Requires
the 'MANAGE_GUILD' permission. Returns a 204 empty response on success. Fires a Guild Integrations Update Gateway event.
Endpoint /guilds/{guild.id}/integrations Rate limiter /guilds/{guild.id}/integrations Discord documentation https://discordapp.com/developers/docs/resources/guild#create-guild-integration Reviewed 2018-08-18 Comment -
func DeleteAllReactions ¶ added in v0.6.0
DeleteAllReactions [DELETE] Deletes all reactions on a message. This endpoint requires the 'MANAGE_MESSAGES'
permission to be present on the current user.
Endpoint /channels/{channel.id}/messages/{message.id}/reactions Rate limiter [MAJOR] /channels/{channel.id}/messages [DELETE] TODO: I have no idea if this is the correct key Discord documentation https://discordapp.com/developers/docs/resources/channel#delete-all-reactions Reviewed 2018-06-07 Comment - emoji either unicode (string) or *Emoji with an snowflake Snowflake if it's custom
func DeleteChannel ¶ added in v0.6.0
DeleteChannel [DELETE] Delete a channel, or close a private message. Requires the 'MANAGE_CHANNELS'
permission for the guild. Deleting a category does not delete its child channels; they will have their parent_id removed and a Channel Update Gateway event will fire for each of them. Returns a channel object on success. Fires a Channel Delete Gateway event.
Endpoint /channels/{channel.id} Rate limiter [MAJOR] /channels/{channel.id} Discord documentation https://discordapp.com/developers/docs/resources/channel#deleteclose-channel Reviewed 2018-06-07 Comment Deleting a guild channel cannot be undone. Use this with caution, as it
is impossible to undo this action when performed on a guild channel. In contrast, when used with a private message, it is possible to undo the action by opening a private message with the recipient again.
func DeleteChannelPermission ¶ added in v0.6.0
DeleteChannelPermission [DELETE] Delete a channel permission overwrite for a user or role in a channel.
Only usable for guild channels. Requires the 'MANAGE_ROLES' permission. Returns a 204 empty response on success. For more information about permissions, see permissions: https://discordapp.com/developers/docs/topics/permissions#permissions
Endpoint /channels/{channel.id}/permissions/{overwrite.id} Rate limiter [MAJOR] /channels/{channel.id}/permissions Discord documentation https://discordapp.com/developers/docs/resources/channel#delete-channel-permission Reviewed 2018-06-07 Comment -
func DeleteGuild ¶ added in v0.6.0
DeleteGuild [DELETE] Delete a guild permanently. User must be owner. Returns 204 No Content on success.
Fires a Guild Delete Gateway event.
Endpoint /guilds/{guild.id} Rate limiter /guilds/{guild.id} Discord documentation https://discordapp.com/developers/docs/resources/guild#delete-guild Reviewed 2018-08-17 Comment -
func DeleteGuildEmoji ¶ added in v0.6.0
DeleteGuildEmoji [DELETE] Delete the given emoji. Requires the
'MANAGE_EMOJIS' permission. Returns 204 No Content on success. Fires a Guild Emojis Update Gateway event.
Endpoint /guilds/{guild.id}/emojis/{emoji.id} Rate limiter [MAJOR] /guilds/{guild.id} // TODO: no idea if this is correct Discord documentation https://discordapp.com/developers/docs/resources/emoji#delete-guild-emoji Reviewed 2018-06-10 Comment -
func DeleteGuildIntegration ¶ added in v0.6.0
DeleteGuildIntegration [DELETE] Delete the attached integration object for the guild.
Requires the 'MANAGE_GUILD' permission. Returns a 204 empty response on success. Fires a Guild Integrations Update Gateway event.
Endpoint /guilds/{guild.id}/integrations/{integration.id} Rate limiter /guilds/{guild.id}/integrations Discord documentation https://discordapp.com/developers/docs/resources/guild#delete-guild-integration Reviewed 2018-08-18 Comment -
func DeleteGuildRole ¶ added in v0.6.0
DeleteGuildRole [DELETE] Delete a guild role. Requires the 'MANAGE_ROLES' permission. Returns a 204 empty
response on success. Fires a Guild Role Delete Gateway event.
Endpoint /guilds/{guild.id}/roles/{role.id} Rate limiter /guilds/{guild.id}/roles Discord documentation https://discordapp.com/developers/docs/resources/guild#delete-guild-role Reviewed 2018-08-18 Comment -
func DeleteMessage ¶ added in v0.6.0
DeleteMessage [DELETE] Delete a message. If operating on a guild channel and trying to delete a
message that was not sent by the current user, this endpoint requires the 'MANAGE_MESSAGES' permission. Returns a 204 empty response on success. Fires a Message Delete Gateway event.
Endpoint /channels/{channel.id}/messages/{message.id} Rate limiter [MAJOR] /channels/{channel.id}/messages [DELETE] Discord documentation https://discordapp.com/developers/docs/resources/channel#delete-message Reviewed 2018-06-10 Comment -
func DeleteOwnReaction ¶ added in v0.6.0
func DeleteOwnReaction(client httd.Deleter, channelID, messageID Snowflake, emoji interface{}) (err error)
DeleteOwnReaction [DELETE] Delete a reaction the current user has made for the message. Returns a 204
empty response on success.
Endpoint /channels/{channel.id}/messages/{message.id}/reactions/{emoji}/@me Rate limiter [MAJOR] /channels/{channel.id}/messages [DELETE] TODO: I have no idea what the key is Discord documentation https://discordapp.com/developers/docs/resources/channel#delete-own-reaction Reviewed 2018-06-07 Comment emoji either unicode (string) or *Emoji with an snowflake Snowflake if it's custom
func DeletePinnedChannelMessage ¶ added in v0.6.0
DeletePinnedChannelMessage [DELETE] Delete a pinned message in a channel. Requires the 'MANAGE_MESSAGES'
permission. Returns a 204 empty response on success. Returns a 204 empty response on success.
Endpoint /channels/{channel.id}/pins/{message.id} Rate limiter [MAJOR] /channels/{channel.id}/pins Discord documentation https://discordapp.com/developers/docs/resources/channel#delete-pinned-channel-message Reviewed 2018-06-10 Comment -
func DeleteUserReaction ¶ added in v0.6.0
func DeleteUserReaction(client httd.Deleter, channelID, messageID, userID Snowflake, emoji interface{}) (err error)
DeleteUserReaction [DELETE] Deletes another user's reaction. This endpoint requires the 'MANAGE_MESSAGES'
permission to be present on the current user. Returns a 204 empty response on success.
Endpoint /channels/{channel.id}/messages/{message.id}/reactions/{emoji}/@me Rate limiter [MAJOR] /channels/{channel.id}/messages [DELETE] TODO: I have no idea if this is the correct key Discord documentation https://discordapp.com/developers/docs/resources/channel#delete-user-reaction Reviewed 2018-06-07 Comment emoji either unicode (string) or *Emoji with an snowflake Snowflake if it's custom
func DeleteWebhook ¶ added in v0.6.0
DeleteWebhook [DELETE] Delete a webhook permanently. User must be owner. Returns a 204 NO CONTENT response
on success.
Endpoint /webhooks/{webhook.id} Rate limiter /webhooks/{webhook.id} Discord documentation https://discordapp.com/developers/docs/resources/webhook#delete-webhook Reviewed 2018-08-14 Comment -
func DeleteWebhookWithToken ¶ added in v0.6.0
DeleteWebhookWithToken [DELETE] Same as DeleteWebhook, except this call does not require authentication. Endpoint /webhooks/{webhook.id}/{webhook.token} Rate limiter /webhooks/{webhook.id} Discord documentation https://discordapp.com/developers/docs/resources/webhook#delete-webhook-with-token Reviewed 2018-08-14 Comment -
func EditChannelPermissions ¶ added in v0.6.0
func EditChannelPermissions(client httd.Puter, chanID, overwriteID Snowflake, params *EditChannelPermissionsParams) (err error)
EditChannelPermissions [PUT] Edit the channel permission overwrites for a user or role in a channel.
Only usable for guild channels. Requires the 'MANAGE_ROLES' permission. Returns a 204 empty response on success. For more information about permissions, see permissions.
Endpoint /channels/{channel.id}/permissions/{overwrite.id} Rate limiter [MAJOR] /channels/{channel.id}/permissions Discord documentation https://discordapp.com/developers/docs/resources/channel#edit-channel-permissions Reviewed 2018-06-07 Comment -
func ExecuteGitHubWebhook ¶ added in v0.6.0
func ExecuteGitHubWebhook(client httd.Poster, params *ExecuteWebhookParams, wait bool) (err error)
ExecuteGitHubWebhook [POST] Trigger a webhook in Discord from the GitHub app. Endpoint /webhooks/{webhook.id}/{webhook.token} Rate limiter /webhooks Discord documentation https://discordapp.com/developers/docs/resources/webhook#execute-githubcompatible-webhook Reviewed 2018-08-14 Comment Add a new webhook to your GitHub repo (in the repo's settings), and use this endpoint.
as the "Payload URL." You can choose what events your Discord channel receives by choosing the "Let me select individual events" option and selecting individual events for the new webhook you're configuring.
func ExecuteSlackWebhook ¶ added in v0.6.0
func ExecuteSlackWebhook(client httd.Poster, params *ExecuteWebhookParams, wait bool) (err error)
ExecuteSlackWebhook [POST] Trigger a webhook in Discord from the Slack app. Endpoint /webhooks/{webhook.id}/{webhook.token} Rate limiter /webhooks Discord documentation https://discordapp.com/developers/docs/resources/webhook#execute-slackcompatible-webhook Reviewed 2018-08-14 Comment Refer to Slack's documentation for more information. We do not support Slack's channel,
icon_emoji, mrkdwn, or mrkdwn_in properties.
func ExecuteWebhook ¶ added in v0.6.0
func ExecuteWebhook(client httd.Poster, params *ExecuteWebhookParams, wait bool, URLSuffix string) (err error)
ExecuteWebhook [POST] Trigger a webhook in Discord. Endpoint /webhooks/{webhook.id}/{webhook.token} Rate limiter /webhooks/{webhook.id} Discord documentation https://discordapp.com/developers/docs/resources/webhook#execute-webhook Reviewed 2018-08-14 Comment This endpoint. supports both JSON and form data bodies. It does require
multipart/form-data requests instead of the normal JSON request type when uploading files. Make sure you set your Content-Type to multipart/form-data if you're doing that. Note that in that case, the embeds field cannot be used, but you can pass an url-encoded JSON body as a form value for payload_json.
Comment#2 For the webhook embed objects, you can set every field except type (it will be
rich regardless of if you try to set it), provider, video, and any height, width, or proxy_url values for images.
TODO
func GroupDMAddRecipient ¶ added in v0.6.0
func GroupDMAddRecipient(client httd.Puter, channelID, userID Snowflake, params *GroupDMAddRecipientParams) (err error)
GroupDMAddRecipient [PUT] Adds a recipient to a Group DM using their access token.
Returns a 204 empty response on success.
Endpoint /channels/{channel.id}/recipients/{user.id} Rate limiter [MAJOR] /channels/{channel.id}/recipients Discord documentation https://discordapp.com/developers/docs/resources/channel#group-dm-add-recipient Reviewed 2018-06-10 Comment -
func GroupDMRemoveRecipient ¶ added in v0.6.0
GroupDMRemoveRecipient [DELETE] Removes a recipient from a Group DM. Returns a 204 empty response on success. Endpoint /channels/{channel.id}/recipients/{user.id} Rate limiter [MAJOR] /channels/{channel.id}/recipients Discord documentation https://discordapp.com/developers/docs/resources/channel#group-dm-remove-recipient Reviewed 2018-06-10 Comment -
func LeaveGuild ¶ added in v0.6.0
LeaveGuild [DELETE] Leave a guild. Returns a 204 empty response on success. Endpoint /users/@me/guilds/{guild.id} Rate limiter /users TODO: is this correct? Discord documentation https://discordapp.com/developers/docs/resources/user#leave-guild Reviewed 2018-06-10 Comment -
func ModifyCurrentUserNick ¶ added in v0.6.0
func ModifyCurrentUserNick(client httd.Patcher, id Snowflake, params *ModifyCurrentUserNickParams) (nick string, err error)
ModifyCurrentUserNick [PATCH] Modifies the nickname of the current user in a guild. Returns a 200 with the
nickname on success. Fires a Guild Member Update Gateway event.
Endpoint /guilds/{guild.id}/members/@me/nick Rate limiter /guilds/{guild.id}/members TODO: I don't know if this is correct Discord documentation https://discordapp.com/developers/docs/resources/guild#modify-current-user-nick Reviewed 2018-08-18 Comment -
func ModifyGuildIntegration ¶ added in v0.6.0
func ModifyGuildIntegration(client httd.Patcher, guildID, integrationID Snowflake, params *ModifyGuildIntegrationParams) (err error)
ModifyGuildIntegration [POST] Modify the behavior and settings of a integration object for the guild.
Requires the 'MANAGE_GUILD' permission. Returns a 204 empty response on success. Fires a Guild Integrations Update Gateway event.
Endpoint /guilds/{guild.id}/integrations/{integration.id} Rate limiter /guilds/{guild.id}/integrations Discord documentation https://discordapp.com/developers/docs/resources/guild#modify-guild-integration Reviewed 2018-08-18 Comment -
func ModifyGuildMember ¶ added in v0.6.0
func ModifyGuildMember(client httd.Patcher, guildID, userID Snowflake, params *ModifyGuildMemberParams) (err error)
ModifyGuildMember [PATCH] Modify attributes of a guild member. Returns a 204 empty response on success.
Fires a Guild Member Update Gateway event.
Endpoint /guilds/{guild.id}/members/{user.id} Rate limiter /guilds/{guild.id}/members Discord documentation https://discordapp.com/developers/docs/resources/guild#modify-guild-member Reviewed 2018-08-17 Comment All parameters to this endpoint. are optional. When moving members to channels,
the API user must have permissions to both connect to the channel and have the MOVE_MEMBERS permission.
func RemoveGuildBan ¶ added in v0.6.0
RemoveGuildBan [DELETE] Remove the ban for a user. Requires the 'BAN_MEMBERS' permissions.
Returns a 204 empty response on success. Fires a Guild Ban Remove Gateway event.
Endpoint /guilds/{guild.id}/bans/{user.id} Rate limiter /guilds/{guild.id}/bans Discord documentation https://discordapp.com/developers/docs/resources/guild#remove-guild-ban Reviewed 2018-08-18 Comment -
func RemoveGuildMember ¶ added in v0.6.0
RemoveGuildMember [DELETE] Remove a member from a guild. Requires 'KICK_MEMBERS' permission. Returns a 204
empty response on success. Fires a Guild Member Remove Gateway event.
Endpoint /guilds/{guild.id}/members/{user.id} Rate limiter /guilds/{guild.id}/members Discord documentation https://discordapp.com/developers/docs/resources/guild#remove-guild-member Reviewed 2018-08-18 Comment -
func RemoveGuildMemberRole ¶ added in v0.6.0
RemoveGuildMemberRole [DELETE] Removes a role from a guild member. Requires the 'MANAGE_ROLES' permission. Returns
a 204 empty response on success. Fires a Guild Member Update Gateway event.
Endpoint /guilds/{guild.id}/members/{user.id}/roles/{role.id} Rate limiter /guilds/{guild.id}/members Discord documentation https://discordapp.com/developers/docs/resources/guild#remove-guild-member-role Reviewed 2018-08-18 Comment -
func SyncGuildIntegration ¶ added in v0.6.0
SyncGuildIntegration [POST] Sync an integration. Requires the 'MANAGE_GUILD' permission.
Returns a 204 empty response on success.
Endpoint /guilds/{guild.id}/integrations/{integration.id}/sync Rate limiter /guilds/{guild.id}/integrations TODO: is this correct? Discord documentation https://discordapp.com/developers/docs/resources/guild#sync-guild-integration Reviewed 2018-08-18 Comment -
func TriggerTypingIndicator ¶ added in v0.6.0
TriggerTypingIndicator [POST] Post a typing indicator for the specified channel. Generally bots should
not implement this route. However, if a bot is responding to a command and expects the computation to take a few seconds, this endpoint may be called to let the user know that the bot is processing their message. Returns a 204 empty response on success. Fires a Typing Start Gateway event.
Endpoint /channels/{channel.id}/typing Rate limiter [MAJOR] /channels/{channel.id}/typing Discord documentation https://discordapp.com/developers/docs/resources/channel#trigger-typing-indicator Reviewed 2018-06-10 Comment -
Types ¶
type AddGuildMemberParams ¶ added in v0.6.0
type AddGuildMemberParams struct { AccessToken string `json:"access_token"` Nick string `json:"nick,omitempty"` Roles []Snowflake `json:"roles"` Mute bool `json:"mute"` Deaf bool `json:"deaf"` }
AddGuildMemberParams https://discordapp.com/developers/docs/resources/guild#add-guild-member-json-params
type Attachment ¶ added in v0.6.0
type Attachment struct { ID Snowflake `json:"id"` Filename string `json:"filename"` Size uint `json:"size"` URL string `json:"url"` ProxyURL string `json:"proxy_url"` Height uint `json:"height"` Width uint `json:"width"` }
Attachment https://discordapp.com/developers/docs/resources/channel#attachment-object
type AuditLog ¶ added in v0.6.0
type AuditLog struct { Webhooks []*Webhook `json:"webhooks"` Users []*User `json:"users"` AuditLogEntries []*AuditLogEntry `json:"audit_log_entries"` }
func GuildAuditLogs ¶ added in v0.6.0
func GuildAuditLogs(client httd.Getter, guildID Snowflake, params *GuildAuditLogsParams) (log *AuditLog, err error)
GuildAuditLogs [GET] Returns an audit log object for the guild.
Requires the 'VIEW_AUDIT_LOG' permission.
Endpoint /guilds/{guild.id}/audit-logs Rate limiter [MAJOR] /guilds/{guild.id}/audit-logs Discord documentation https://discordapp.com/developers/docs/resources/audit-log#get-guild-audit-log Reviewed 2018-06-05 Comment -
type AuditLogChange ¶ added in v0.6.0
type AuditLogChange struct { NewValue interface{} `json:"new_value,omitempty"` OldValue interface{} `json:"old_value,omitempty"` Key string `json:"key"` }
type AuditLogEntry ¶ added in v0.6.0
type AuditLogEntry struct { TargetID Snowflake `json:"target_id"` Changes []*AuditLogChange `json:"changes,omitempty"` UserID Snowflake `json:"user_id"` ID Snowflake `json:"id"` ActionType uint `json:"action_type"` Options []*AuditLogOption `json:"options,omitempty"` Reason string `json:"reason,omitempty"` }
type AuditLogOption ¶ added in v0.6.0
type AuditLogOption struct { DeleteMemberDays string `json:"delete_member_days"` MembersRemoved string `json:"members_removed"` ChannelID Snowflake `json:"channel_id"` Count string `json:"count"` ID Snowflake `json:"id"` Type string `json:"type"` // type of overwritten entity ("member" or "role") RoleName string `json:"role_name"` }
type Ban ¶ added in v0.6.0
-------------- Ban https://discordapp.com/developers/docs/resources/guild#ban-object
func GetGuildBan ¶ added in v0.6.0
GetGuildBan [GET] Returns a ban object for the given user or a 404 not found if the ban cannot be found.
Requires the 'BAN_MEMBERS' permission.
Endpoint /guilds/{guild.id}/bans/{user.id} Rate limiter /guilds/{guild.id}/bans Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-ban Reviewed 2018-08-18 Comment -
func GetGuildBans ¶ added in v0.6.0
GetGuildBans [GET] Returns a list of ban objects for the users banned from this guild.
Requires the 'BAN_MEMBERS' permission.
Endpoint /guilds/{guild.id}/bans Rate limiter /guilds/{guild.id}/bans Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-bans Reviewed 2018-08-18 Comment -
type BodyUserCreateDM ¶ added in v0.6.0
type BodyUserCreateDM struct {
RecipientID Snowflake `json:"recipient_id"`
}
BodyUserCreateDM JSON param for func CreateDM
type BulkDeleteMessagesParams ¶ added in v0.6.0
type BulkDeleteMessagesParams struct { Messages []Snowflake `json:"messages"` // contains filtered or unexported fields }
BulkDeleteMessagesParams https://discordapp.com/developers/docs/resources/channel#bulk-delete-messages-json-params
func (*BulkDeleteMessagesParams) AddMessage ¶ added in v0.6.0
func (p *BulkDeleteMessagesParams) AddMessage(msg *Message) (err error)
AddMessage Adds a message to be deleted
func (*BulkDeleteMessagesParams) Valid ¶ added in v0.6.0
func (p *BulkDeleteMessagesParams) Valid() (err error)
Valid validates the BulkDeleteMessagesParams data
type Channel ¶ added in v0.6.0
type Channel struct { ID Snowflake `json:"id"` Type uint `json:"type"` GuildID Snowflake `json:"guild_id,omitempty"` // ?| Position uint `json:"position,omitempty"` // ?| PermissionOverwrites []PermissionOverwrite `json:"permission_overwrites,omitempty"` // ?| Name string `json:"name,omitempty"` // ?| Topic string `json:"topic,omitempty"` // ?| NSFW bool `json:"nsfw,omitempty"` // ?| LastMessageID Snowflake `json:"last_message_id,omitempty"` // ?|?, pointer Bitrate uint `json:"bitrate,omitempty"` // ?| UserLimit uint `json:"user_limit,omitempty"` // ?| Recipients []*User `json:"recipient,omitempty"` // ?| , empty if not DM Icon string `json:"icon,omitempty"` // ?|?, pointer OwnerID Snowflake `json:"owner_id,omitempty"` // ?| ApplicationID Snowflake `json:"application_id,omitempty"` // ?| ParentID Snowflake `json:"parent_id,omitempty"` // ?|?, pointer LastPingTimestamp Timestamp `json:"last_ping_timestamp,omitempty"` // ?| sync.RWMutex }
Channel
func CreateDM ¶ added in v0.6.0
CreateDM [POST] Create a new DM channel with a user. Returns a DM channel object. Endpoint /users/@me/channels Rate limiter /users TODO: is this correct? Discord documentation https://discordapp.com/developers/docs/resources/user#create-dm Reviewed 2018-06-10 Comment - TODO: review
func CreateGroupDM ¶ added in v0.6.0
func CreateGroupDM(client httd.Poster, params *CreateGroupDMParams) (ret *Channel, err error)
CreateGroupDM [POST] Create a new group DM channel with multiple users. Returns a DM channel object. Endpoint /users/@me/channels Rate limiter /users TODO: is this correct? Discord documentation https://discordapp.com/developers/docs/resources/user#create-group-dm Reviewed 2018-06-10 Comment -
func CreateGuildChannel ¶ added in v0.6.0
func CreateGuildChannel(client httd.Poster, id Snowflake, params *CreateGuildChannelParams) (ret *Channel, err error)
CreateGuildChannel [POST] Create a new channel object for the guild. Requires the 'MANAGE_CHANNELS' permission.
Returns the new channel object on success. Fires a Channel Create Gateway event.
Endpoint /guilds/{guild.id}/channels Rate limiter /guilds/{guild.id}/channels Discord documentation https://discordapp.com/developers/docs/resources/guild#create-guild-channel Reviewed 2018-08-17 Comment All parameters for this endpoint. are optional excluding 'name'
func GetChannel ¶ added in v0.6.0
GetChannel [GET] Get a channel by Snowflake. Returns a channel object. Endpoint /channels/{channel.id} Rate limiter [MAJOR] /channels/{channel.id} Discord documentation https://discordapp.com/developers/docs/resources/channel#get-channel Reviewed 2018-06-07 Comment -
func GetGuildChannels ¶ added in v0.6.0
GetGuildChannels [GET] Returns a list of guild channel objects. Endpoint /guilds/{guild.id}/channels Rate limiter /guilds/{guild.id}/channels Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-channels Reviewed 2018-08-17 Comment -
func GetUserDMs ¶ added in v0.6.0
GetUserDMs [GET] Returns a list of DM channel objects. Endpoint /users/@me/channels Rate limiter /users TODO: is this correct? Discord documentation https://discordapp.com/developers/docs/resources/user#get-user-dms Reviewed 2018-06-10 Comment -
func ModifyChannel ¶ added in v0.6.0
func ModifyChannel(client httd.Patcher, changes *ModifyChannelParams) (ret *Channel, err error)
ModifyChannel PUT/PATCH Update a channels settings. Requires the 'MANAGE_CHANNELS' permission for the guild.
Returns a channel on success, and a 400 BAD REQUEST on invalid parameters. Fires a Channel Update Gateway event. If modifying a category, individual Channel Update events will fire for each child channel that also changes. For the PATCH method, all the JSON Params are optional.
Endpoint /channels/{channel.id} Rate limiter [MAJOR] /channels/{channel.id} Discord documentation https://discordapp.com/developers/docs/resources/channel#modify-channel Reviewed 2018-06-07 Comment andersfylling: only implemented the patch method, as its parameters are optional.
func NewChannel ¶ added in v0.6.0
func NewChannel() *Channel
func (*Channel) Delete ¶ added in v0.6.0
func (c *Channel) Delete(client ChannelDeleter) (err error)
Delete sends a Discord REST request to delete the related channel
func (*Channel) SendMsg ¶ added in v0.6.0
func (c *Channel) SendMsg(client MessageSender, message *Message) (msg *Message, err error)
func (*Channel) SendMsgString ¶ added in v0.6.0
func (c *Channel) SendMsgString(client MessageSender, content string) (msg *Message, err error)
func (*Channel) Update ¶ added in v0.6.0
func (c *Channel) Update(client ChannelUpdater)
Update send channel changes to the Discord API
type ChannelCreate ¶ added in v0.6.0
ChannelCreateBox new channel created
type ChannelCreateCallback ¶
type ChannelCreateCallback = func(session Session, cc *ChannelCreate)
ChannelCreateCallback triggered on CHANNEL_CREATE events
type ChannelDelete ¶ added in v0.6.0
ChannelDelete channel was deleted
type ChannelDeleteCallback ¶
type ChannelDeleteCallback = func(session Session, cd *ChannelDelete)
ChannelDeleteCallback triggered on CHANNEL_DELETE events
type ChannelDeleter ¶ added in v0.6.0
type ChannelEmbed ¶ added in v0.6.0
type ChannelEmbed struct { Title string `json:"title"` // title of embed Type string `json:"type"` // type of embed (always "rich" for webhook embeds) Description string `json:"description"` // description of embed URL string `json:"url"` // url of embed Timestamp time.Time `json:"timestamp"` // timestamp timestamp of embed content Color int `json:"color"` // color code of the embed Image *ChannelEmbedImage `json:"image"` // embed image object image information Thumbnail *ChannelEmbedThumbnail `json:"thumbnail"` // embed thumbnail object thumbnail information Video *ChannelEmbedVideo `json:"video"` // embed video object video information Provider *ChannelEmbedProvider `json:"provider"` // embed provider object provider information Author *ChannelEmbedAuthor `json:"author"` // embed author object author information Fields []*ChannelEmbedField `json:"fields"` // array of embed field objects fields information }
ChannelEmbed https://discordapp.com/developers/docs/resources/channel#embed-object
type ChannelEmbedAuthor ¶ added in v0.6.0
type ChannelEmbedAuthor struct { Name string `json:"name,omitempty"` // ?| , name of author Url string `json:"url,omitempty"` // ?| , url of author IconUrl string `json:"icon_url,omitempty"` // ?| , url of author icon (only supports http(s) and attachments) ProxyIconUrl string `json:"proxy_icon_url,omitempty"` // ?| , a proxied url of author icon }
ChannelEmbedAuthor https://discordapp.com/developers/docs/resources/channel#embed-object-embed-author-structure
type ChannelEmbedField ¶ added in v0.6.0
type ChannelEmbedField struct { Name string `json:"name"` // | , name of the field Value string `json:"value"` // | , value of the field Inline bool `json:"bool,omitempty"` // ?| , whether or not this field should display inline }
ChannelEmbedField https://discordapp.com/developers/docs/resources/channel#embed-object-embed-field-structure
type ChannelEmbedFooter ¶ added in v0.6.0
type ChannelEmbedFooter struct {}
ChannelEmbedFooter https://discordapp.com/developers/docs/resources/channel#embed-object-embed-footer-structure
type ChannelEmbedImage ¶ added in v0.6.0
type ChannelEmbedImage struct { Url string `json:"url,omitempty"` // ?| , source url of image (only supports http(s) and attachments) ProxyUrl string `json:"proxy_url,omitempty"` // ?| , a proxied url of the image Height int `json:"height,omitempty"` // ?| , height of image Width int `json:"width,omitempty"` // ?| , width of image }
ChannelEmbedImage https://discordapp.com/developers/docs/resources/channel#embed-object-embed-image-structure
type ChannelEmbedProvider ¶ added in v0.6.0
type ChannelEmbedProvider struct { Name string `json:"name,omitempty"` // ?| , name of provider Url string `json:"url,omitempty"` // ?| , url of provider }
ChannelEmbedProvider https://discordapp.com/developers/docs/resources/channel#embed-object-embed-provider-structure
type ChannelEmbedThumbnail ¶ added in v0.6.0
type ChannelEmbedThumbnail struct { Url string `json:"url,omitempty"` // ?| , source url of image (only supports http(s) and attachments) ProxyUrl string `json:"proxy_url,omitempty"` // ?| , a proxied url of the image Height int `json:"height,omitempty"` // ?| , height of image Width int `json:"width,omitempty"` // ?| , width of image }
ChannelEmbedThumbnail https://discordapp.com/developers/docs/resources/channel#embed-object-embed-thumbnail-structure
type ChannelEmbedVideo ¶ added in v0.6.0
type ChannelEmbedVideo struct { Url string `json:"url,omitempty"` // ?| , source url of video Height int `json:"height,omitempty"` // ?| , height of video Width int `json:"width,omitempty"` // ?| , width of video }
ChannelEmbedVideo https://discordapp.com/developers/docs/resources/channel#embed-object-embed-video-structure
type ChannelFetcher ¶ added in v0.6.0
type ChannelMessager ¶ added in v0.6.0
ChannelMessager Methods required to create a new DM (or use an existing one) and send a DM.
type ChannelPinsUpdate ¶ added in v0.6.0
type ChannelPinsUpdate struct { // ChannelID snowflake the id of the channel ChannelID Snowflake `json:"channel_id"` // LastPinTimestamp ISO8601 timestamp the time at which the most recent pinned message was pinned LastPinTimestamp Timestamp `json:"last_pin_timestamp,omitempty"` // ?| Ctx context.Context `json:"-"` }
ChannelPinsUpdate message was pinned or unpinned
type ChannelPinsUpdateCallback ¶
type ChannelPinsUpdateCallback = func(session Session, cpu *ChannelPinsUpdate)
ChannelPinsUpdateCallback triggered on CHANNEL_PINS_UPDATE events
type ChannelUpdate ¶ added in v0.6.0
ChannelUpdateBox channel was updated
type ChannelUpdateCallback ¶
type ChannelUpdateCallback = func(session Session, cu *ChannelUpdate)
ChannelUpdateCallback triggered on CHANNEL_UPDATE events
type ChannelUpdater ¶ added in v0.6.0
type ChannelUpdater interface { }
type Client ¶
Client is the main disgord client to hold your state and data
func NewClientMustCompile ¶
NewClientMustCompile constructs a client and crash on failures
func (*Client) AddGuildMember ¶
func (c *Client) AddGuildMember(guildID, userID Snowflake, params *AddGuildMemberParams) (ret *Member, err error)
AddGuildMember .
func (*Client) AddGuildMemberRole ¶
AddGuildMemberRole .
func (*Client) AddListener ¶
AddListener register a listener for a specific event key/type (see Key...)
func (*Client) AddListenerOnce ¶
AddListenerOnce not implemented. Do not use.
func (*Client) AddPinnedChannelMessage ¶
AddPinnedChannelMessage .
func (*Client) BeginGuildPrune ¶
func (c *Client) BeginGuildPrune(id Snowflake, params *GuildPruneParams) (ret *GuildPruneCount, err error)
BeginGuildPrune .
func (*Client) BulkDeleteMessages ¶
func (c *Client) BulkDeleteMessages(chanID Snowflake, params *BulkDeleteMessagesParams) (err error)
BulkDeleteMessages .
func (*Client) CreateChannelInvites ¶
func (c *Client) CreateChannelInvites(id Snowflake, params *CreateChannelInvitesParams) (ret *Invite, err error)
CreateChannelInvites ...
func (*Client) CreateChannelMessage ¶
func (c *Client) CreateChannelMessage(channelID Snowflake, params *CreateChannelMessageParams) (ret *Message, err error)
CreateChannelMessage .
func (*Client) CreateGroupDM ¶
func (c *Client) CreateGroupDM(params *CreateGroupDMParams) (ret *Channel, err error)
CreateGroupDM .
func (*Client) CreateGuild ¶
func (c *Client) CreateGuild(params *CreateGuildParams) (ret *Guild, err error)
CreateGuild .
func (*Client) CreateGuildBan ¶
func (c *Client) CreateGuildBan(guildID, userID Snowflake, params *CreateGuildBanParams) (err error)
CreateGuildBan .
func (*Client) CreateGuildChannel ¶
func (c *Client) CreateGuildChannel(id Snowflake, params *CreateGuildChannelParams) (ret *Channel, err error)
CreateGuildChannel .
func (*Client) CreateGuildEmoji ¶
func (c *Client) CreateGuildEmoji(guildID Snowflake, params *CreateGuildEmojiParams) (ret *Emoji, err error)
CreateGuildEmoji .
func (*Client) CreateGuildIntegration ¶
func (c *Client) CreateGuildIntegration(guildID Snowflake, params *CreateGuildIntegrationParams) (err error)
CreateGuildIntegration .
func (*Client) CreateGuildRole ¶
func (c *Client) CreateGuildRole(id Snowflake, params *CreateGuildRoleParams) (ret *Role, err error)
CreateGuildRole .
func (*Client) CreateReaction ¶
func (c *Client) CreateReaction(channelID, messageID Snowflake, emoji interface{}) (ret *Reaction, err error)
CreateReaction .
func (*Client) CreateWebhook ¶
func (c *Client) CreateWebhook(channelID Snowflake, params *CreateWebhookParams) (ret *Webhook, err error)
CreateWebhook .
func (*Client) DeleteAllReactions ¶
DeleteAllReactions .
func (*Client) DeleteChannel ¶
DeleteChannel ...
func (*Client) DeleteChannelPermission ¶
DeleteChannelPermission .
func (*Client) DeleteGuildEmoji ¶
DeleteGuildEmoji .
func (*Client) DeleteGuildIntegration ¶
DeleteGuildIntegration .
func (*Client) DeleteGuildRole ¶
DeleteGuildRole .
func (*Client) DeleteInvite ¶
DeleteInvite .
func (*Client) DeleteMessage ¶
DeleteMessage .
func (*Client) DeleteOwnReaction ¶
DeleteOwnReaction .
func (*Client) DeletePinnedChannelMessage ¶
DeletePinnedChannelMessage .
func (*Client) DeleteUserReaction ¶
func (c *Client) DeleteUserReaction(channelID, messageID, userID Snowflake, emoji interface{}) (err error)
DeleteUserReaction .
func (*Client) DeleteWebhook ¶
DeleteWebhook .
func (*Client) DeleteWebhookWithToken ¶
DeleteWebhookWithToken .
func (*Client) Disconnect ¶
Disconnect closes the discord websocket connection
func (*Client) DisconnectOnInterrupt ¶ added in v0.6.2
DisconnectOnInterrupt wait until a termination signal is detected
func (*Client) EditChannelPermissions ¶
func (c *Client) EditChannelPermissions(chanID, overwriteID Snowflake, params *EditChannelPermissionsParams) (err error)
EditChannelPermissions ...
func (*Client) EditMessage ¶
func (c *Client) EditMessage(chanID, msgID Snowflake, params *EditMessageParams) (ret *Message, err error)
EditMessage .
func (*Client) Evt ¶
func (c *Client) Evt() EvtDispatcher
Evt gives access to the event dispatcher for registering handlers and utilising event channels
func (*Client) ExecuteGitHubWebhook ¶
func (c *Client) ExecuteGitHubWebhook(params *ExecuteWebhookParams, wait bool) (err error)
ExecuteGitHubWebhook .
func (*Client) ExecuteSlackWebhook ¶
func (c *Client) ExecuteSlackWebhook(params *ExecuteWebhookParams, wait bool) (err error)
ExecuteSlackWebhook .
func (*Client) ExecuteWebhook ¶
func (c *Client) ExecuteWebhook(params *ExecuteWebhookParams, wait bool, URLSuffix string) (err error)
ExecuteWebhook .
func (*Client) GetChannel ¶
GetChannel ...
func (*Client) GetChannelInvites ¶
GetChannelInvites ...
func (*Client) GetChannelMessage ¶
GetChannelMessage .
func (*Client) GetChannelMessages ¶
func (c *Client) GetChannelMessages(channelID Snowflake, params URLParameters) (ret []*Message, err error)
GetChannelMessages .
func (*Client) GetChannelWebhooks ¶
GetChannelWebhooks .
func (*Client) GetCurrentUser ¶
GetCurrentUser .
func (*Client) GetCurrentUserGuilds ¶
func (c *Client) GetCurrentUserGuilds(params *GetCurrentUserGuildsParams) (ret []*Guild, err error)
GetCurrentUserGuilds .
func (*Client) GetGuildAuditLogs ¶
func (c *Client) GetGuildAuditLogs(guildID Snowflake, params *GuildAuditLogsParams) (log *AuditLog, err error)
GetGuildAuditLogs ...
func (*Client) GetGuildBan ¶
GetGuildBan .
func (*Client) GetGuildBans ¶
GetGuildBans .
func (*Client) GetGuildChannels ¶
GetGuildChannels .
func (*Client) GetGuildEmbed ¶
func (c *Client) GetGuildEmbed(guildID Snowflake) (ret *GuildEmbed, err error)
GetGuildEmbed .
func (*Client) GetGuildEmoji ¶
GetGuildEmoji .
func (*Client) GetGuildEmojis ¶
GetGuildEmojis .
func (*Client) GetGuildIntegrations ¶
func (c *Client) GetGuildIntegrations(id Snowflake) (ret []*Integration, err error)
GetGuildIntegrations .
func (*Client) GetGuildInvites ¶
GetGuildInvites .
func (*Client) GetGuildMember ¶
GetGuildMember .
func (*Client) GetGuildMembers ¶
GetGuildMembers .
func (*Client) GetGuildPruneCount ¶
func (c *Client) GetGuildPruneCount(id Snowflake, params *GuildPruneParams) (ret *GuildPruneCount, err error)
GetGuildPruneCount .
func (*Client) GetGuildRoles ¶
GetGuildRoles .
func (*Client) GetGuildVanityURL ¶
func (c *Client) GetGuildVanityURL(guildID Snowflake) (ret *PartialInvite, err error)
GetGuildVanityURL .
func (*Client) GetGuildVoiceRegions ¶
func (c *Client) GetGuildVoiceRegions(id Snowflake) (ret []*VoiceRegion, err error)
GetGuildVoiceRegions .
func (*Client) GetGuildWebhooks ¶
GetGuildWebhooks .
func (*Client) GetPinnedMessages ¶
GetPinnedMessages .
func (*Client) GetReaction ¶
func (c *Client) GetReaction(channelID, messageID Snowflake, emoji interface{}, params URLParameters) (ret []*User, err error)
GetReaction .
func (*Client) GetUserConnections ¶
func (c *Client) GetUserConnections() (ret []*UserConnection, err error)
GetUserConnections .
func (*Client) GetVoiceRegions ¶
func (c *Client) GetVoiceRegions() (ret []*VoiceRegion, err error)
GetVoiceRegions .
func (*Client) GetWebhook ¶
GetWebhook .
func (*Client) GetWebhookWithToken ¶
GetWebhookWithToken .
func (*Client) GroupDMAddRecipient ¶
func (c *Client) GroupDMAddRecipient(channelID, userID Snowflake, params *GroupDMAddRecipientParams) (err error)
GroupDMAddRecipient .
func (*Client) GroupDMRemoveRecipient ¶
GroupDMRemoveRecipient .
func (*Client) ModifyChannel ¶
func (c *Client) ModifyChannel(changes *ModifyChannelParams) (ret *Channel, err error)
ModifyChannel ...
func (*Client) ModifyCurrentUser ¶
func (c *Client) ModifyCurrentUser(params *ModifyCurrentUserParams) (ret *User, err error)
ModifyCurrentUser .
func (*Client) ModifyCurrentUserNick ¶
func (c *Client) ModifyCurrentUserNick(id Snowflake, params *ModifyCurrentUserNickParams) (nick string, err error)
ModifyCurrentUserNick .
func (*Client) ModifyGuild ¶
func (c *Client) ModifyGuild(id Snowflake, params *ModifyGuildParams) (ret *Guild, err error)
ModifyGuild .
func (*Client) ModifyGuildEmbed ¶
func (c *Client) ModifyGuildEmbed(guildID Snowflake, params *GuildEmbed) (ret *GuildEmbed, err error)
ModifyGuildEmbed .
func (*Client) ModifyGuildEmoji ¶
func (c *Client) ModifyGuildEmoji(guildID, emojiID Snowflake, params *ModifyGuildEmojiParams) (ret *Emoji, err error)
ModifyGuildEmoji .
func (*Client) ModifyGuildIntegration ¶
func (c *Client) ModifyGuildIntegration(guildID, integrationID Snowflake, params *ModifyGuildIntegrationParams) (err error)
ModifyGuildIntegration .
func (*Client) ModifyGuildMember ¶
func (c *Client) ModifyGuildMember(guildID, userID Snowflake, params *ModifyGuildMemberParams) (err error)
ModifyGuildMember .
func (*Client) ModifyGuildRole ¶
func (c *Client) ModifyGuildRole(guildID, roleID Snowflake, params *ModifyGuildRoleParams) (ret []*Role, err error)
ModifyGuildRole .
func (*Client) ModifyGuildRolePositions ¶
func (c *Client) ModifyGuildRolePositions(guildID Snowflake, params *ModifyGuildRolePositionsParams) (ret []*Role, err error)
ModifyGuildRolePositions .
func (*Client) ModifyWebhook ¶
ModifyWebhook .
func (*Client) ModifyWebhookWithToken ¶
ModifyWebhookWithToken .
func (*Client) RateLimiter ¶
func (c *Client) RateLimiter() httd.RateLimiter
RateLimiter return the rate limiter object
func (*Client) RemoveGuildBan ¶
RemoveGuildBan .
func (*Client) RemoveGuildMember ¶
RemoveGuildMember .
func (*Client) RemoveGuildMemberRole ¶
RemoveGuildMemberRole .
func (*Client) Req ¶
Req return the request object. Used in REST requests to handle rate limits, wrong http responses, etc.
func (*Client) SendMsgString ¶ added in v0.4.0
SendMsgString .
func (*Client) SyncGuildIntegration ¶
SyncGuildIntegration .
func (*Client) TriggerTypingIndicator ¶
TriggerTypingIndicator .
func (*Client) UpdateChannel ¶ added in v0.4.0
UpdateChannel Not implemented yet
type Config ¶
type Config struct { Token string HTTPClient *http.Client APIVersion int // eg. version 6. 0 defaults to lowest supported api version APIEncoding string // eg. json, use const. defaults to json CancelRequestWhenRateLimited bool LoadAllMembers bool LoadAllChannels bool LoadAllRoles bool LoadAllPresences bool Debug bool }
Config Configuration for the Disgord client
type CreateChannelInvitesParams ¶ added in v0.6.0
type CreateChannelInvitesParams struct { MaxAge int `json:"max_age,omitempty"` // duration of invite in seconds before expiry, or 0 for never. default 86400 (24 hours) MaxUses int `json:"max_uses,omitempty"` // max number of uses or 0 for unlimited. default 0 Temporary bool `json:"temporary,omitempty"` // whether this invite only grants temporary membership. default false Unique bool `json:"unique,omitempty"` // if true, don't try to reuse a similar invite (useful for creating many unique one time use invites). default false }
CreateChannelInvitesParams https://discordapp.com/developers/docs/resources/channel#create-channel-invite-json-params
type CreateChannelMessageParams ¶ added in v0.6.0
type CreateChannelMessageParams struct { Content string `json:"content"` Nonce Snowflake `json:"nonce,omitempty"` Tts bool `json:"tts,omitempty"` File interface{} `json:"file,omitempty"` // TODO: what is this supposed to be? Embed *ChannelEmbed `json:"embed,omitempty"` // embedded rich content PayloadJSON string `json:"payload_json,omitempty"` }
CreateChannelMessageParams JSON params for CreateChannelMessage
func NewMessageByString ¶ added in v0.6.0
func NewMessageByString(content string) *CreateChannelMessageParams
NewMessageByString creates a message object from a string/content
type CreateGroupDMParams ¶ added in v0.6.0
type CreateGroupDMParams struct { AccessTokens []string `json:"access_tokens"` // access tokens of users that have granted your app the gdm.join scope Nicks map[Snowflake]string `json:"nicks"` // userID => nickname }
CreateGroupDMParams JSON params for func CreateGroupDM https://discordapp.com/developers/docs/resources/user#create-group-dm
type CreateGuildBanParams ¶ added in v0.6.0
type CreateGuildBanParams struct { DeleteMessageDays int `urlparam:"delete_message_days"` // number of days to delete messages for (0-7) Reason string `urlparam:"reason"` // reason for being banned }
CreateGuildBanParams https://discordapp.com/developers/docs/resources/guild#create-guild-ban-query-string-params
func (*CreateGuildBanParams) GetQueryString ¶ added in v0.6.0
func (params *CreateGuildBanParams) GetQueryString() string
GetQueryString .
type CreateGuildChannelParams ¶ added in v0.6.0
type CreateGuildChannelParams struct { Name string `json:"name"` // | Type uint `json:"type,omitempty"` // ?| Topic string `json:"topic,omitempty"` // ?| Bitrate uint `json:"bitrate,omitempty"` // ?| UserLimit uint `json:"user_limit,omitempty"` // ?| PermissionOverwrites []PermissionOverwrite `json:"permission_overwrites,omitempty"` // ?| ParentID Snowflake `json:"parent_id,omitempty"` // ?| NSFW bool `json:"nsfw,omitempty"` // ?| }
CreateGuildChannelParams https://discordapp.com/developers/docs/resources/guild#create-guild-channel-json-params
type CreateGuildEmojiParams ¶ added in v0.6.0
type CreateGuildEmojiParams struct { Name string `json:"name"` Image string `json:"image"` Roles []Snowflake `json:"roles"` }
CreateGuildEmojiParams JSON params for func CreateGuildEmoji
type CreateGuildIntegrationParams ¶ added in v0.6.0
CreateGuildIntegrationParams https://discordapp.com/developers/docs/resources/guild#create-guild-integration-json-params
type CreateGuildParams ¶ added in v0.6.0
type CreateGuildParams struct { Name string `json:"name"` Region string `json:"region"` Icon string `json:"icon"` VerificationLvl int `json:"verification_level"` DefaultMsgNotifications DefaultMessageNotificationLvl `json:"default_message_notifications"` ExplicitContentFilter ExplicitContentFilterLvl `json:"explicit_content_filter"` Roles []*Role `json:"roles"` Channels []*PartialChannel `json:"channels"` }
CreateGuildParams https://discordapp.com/developers/docs/resources/guild#create-guild-json-params example partial channel object:
{ "name": "naming-things-is-hard", "type": 0 }
type CreateGuildRoleParams ¶ added in v0.6.0
type CreateGuildRoleParams struct { Name string `json:"name,omitempty"` Permissions int `json:"permissions,omitempty"` Color int `json:"color,omitempty"` Hoist bool `json:"hoist,omitempty"` Mentionable bool `json:"mentionable,omitempty"` }
CreateGuildRoleParams https://discordapp.com/developers/docs/resources/guild#create-guild-role-json-params
type CreateWebhookParams ¶ added in v0.6.0
type CreateWebhookParams struct { Name string `json:"name"` // name of the webhook (2-32 characters) Avatar string `json:"avatar"` // avatar data uri scheme, image for the default webhook avatar }
CreateWebhookParams json params for the create webhook rest request avatar string: https://discordapp.com/developers/docs/resources/user#avatar-data
type DefaultMessageNotificationLvl ¶ added in v0.6.0
type DefaultMessageNotificationLvl uint
DefaultMessageNotification ... https://discordapp.com/developers/docs/resources/guild#guild-object-default-message-notification-level
func (*DefaultMessageNotificationLvl) AllMessages ¶ added in v0.6.0
func (dmnl *DefaultMessageNotificationLvl) AllMessages() bool
func (*DefaultMessageNotificationLvl) Equals ¶ added in v0.6.0
func (dmnl *DefaultMessageNotificationLvl) Equals(v uint) bool
func (*DefaultMessageNotificationLvl) OnlyMentions ¶ added in v0.6.0
func (dmnl *DefaultMessageNotificationLvl) OnlyMentions() bool
type DeletedMessage ¶ added in v0.6.0
func NewDeletedMessage ¶ added in v0.6.0
func NewDeletedMessage() *DeletedMessage
type Dispatch ¶
type Dispatch struct {
// contains filtered or unexported fields
}
Dispatch holds all the channels and internal state for all registered observers
func NewDispatch ¶
func NewDispatch() *Dispatch
NewDispatch construct a Dispatch object for reacting to web socket events from discord
func (*Dispatch) AddHandler ¶
AddHandler bind a callback to a event type. See event.Key...
func (*Dispatch) AddHandlerOnce ¶
AddHandlerOnce same as AddHandler except that the callback is only triggered once
func (*Dispatch) AllChan ¶
func (d *Dispatch) AllChan() <-chan interface{}
AllChan sends all event types
func (*Dispatch) ChannelCreateChan ¶
func (d *Dispatch) ChannelCreateChan() <-chan *ChannelCreate
ChannelCreateChan for CHANNEL_CREATE, when a channel is created
func (*Dispatch) ChannelDeleteChan ¶
func (d *Dispatch) ChannelDeleteChan() <-chan *ChannelDelete
ChannelDeleteChan for CHANNEL_DELETE, when a channel is deleted
func (*Dispatch) ChannelPinsUpdateChan ¶
func (d *Dispatch) ChannelPinsUpdateChan() <-chan *ChannelPinsUpdate
ChannelPinsUpdateChan for CHANNEL_PIN_UPDATE. Message was pinned or unpinned
func (*Dispatch) ChannelUpdateChan ¶
func (d *Dispatch) ChannelUpdateChan() <-chan *ChannelUpdate
ChannelUpdateChan for CHANNEL_UPDATE, when a channel is updated
func (*Dispatch) GuildBanAddChan ¶
func (d *Dispatch) GuildBanAddChan() <-chan *GuildBanAdd
GuildBanAddChan for GUILD_BAN_ADD. A user was banned from a guild
func (*Dispatch) GuildBanRemoveChan ¶
func (d *Dispatch) GuildBanRemoveChan() <-chan *GuildBanRemove
GuildBanRemoveChan for GUILD_BAN_REMOVE. A user was unbanned from a guild
func (*Dispatch) GuildCreateChan ¶
func (d *Dispatch) GuildCreateChan() <-chan *GuildCreate
GuildCreateChan for GUILD_CREATE. Lazy-load for unavailable guild, guild became available, or user joined a new guild
func (*Dispatch) GuildDeleteChan ¶
func (d *Dispatch) GuildDeleteChan() <-chan *GuildDelete
GuildDeleteChan for GUILD_DELETE, guild became unavailable, or user left/was removed from a guild
func (*Dispatch) GuildEmojisUpdateChan ¶
func (d *Dispatch) GuildEmojisUpdateChan() <-chan *GuildEmojisUpdate
GuildEmojisUpdateChan for GUILD_EMOJI_UPDATE. Guild emojis were updated
func (*Dispatch) GuildIntegrationsUpdateChan ¶
func (d *Dispatch) GuildIntegrationsUpdateChan() <-chan *GuildIntegrationsUpdate
GuildIntegrationsUpdateChan for GUILD_INTEGRATIONS_UPDATE. Guild integration was updated
func (*Dispatch) GuildMemberAddChan ¶
func (d *Dispatch) GuildMemberAddChan() <-chan *GuildMemberAdd
GuildMemberAddChan for GUILD_MEMBER_ADD. New user joined a guild.
func (*Dispatch) GuildMemberRemoveChan ¶
func (d *Dispatch) GuildMemberRemoveChan() <-chan *GuildMemberRemove
GuildMemberRemoveChan for GUILD_MEMBER_REMOVE. User was removed from guild.
func (*Dispatch) GuildMemberUpdateChan ¶
func (d *Dispatch) GuildMemberUpdateChan() <-chan *GuildMemberUpdate
GuildMemberUpdateChan for GUILD_MEMBER_UPDATE. Guild member was updated.
func (*Dispatch) GuildMembersChunkChan ¶
func (d *Dispatch) GuildMembersChunkChan() <-chan *GuildMembersChunk
GuildMembersChunkChan for GUILD_MEMBERS_CHUNK. Response to socket command 'Request Guild Members'
func (*Dispatch) GuildRoleCreateChan ¶
func (d *Dispatch) GuildRoleCreateChan() <-chan *GuildRoleCreate
GuildRoleCreateChan for GUILD_ROLE_CREATE. Guild role was created.
func (*Dispatch) GuildRoleDeleteChan ¶
func (d *Dispatch) GuildRoleDeleteChan() <-chan *GuildRoleDelete
GuildRoleDeleteChan for GUILD_ROLE_DELETE. Guild role was deleted.
func (*Dispatch) GuildRoleUpdateChan ¶
func (d *Dispatch) GuildRoleUpdateChan() <-chan *GuildRoleUpdate
GuildRoleUpdateChan for GUILD_ROLE_UPDATE. Guild role was updated.
func (*Dispatch) GuildUpdateChan ¶
func (d *Dispatch) GuildUpdateChan() <-chan *GuildUpdate
GuildUpdateChan for GUILD_UPDATE. Guild was updated
func (*Dispatch) MessageCreateChan ¶
func (d *Dispatch) MessageCreateChan() <-chan *MessageCreate
MessageCreateChan for MESSAGE_CREATE. New message was created.
func (*Dispatch) MessageDeleteBulkChan ¶
func (d *Dispatch) MessageDeleteBulkChan() <-chan *MessageDeleteBulk
MessageDeleteBulkChan for MESSAGE_DELETE_BULK. Multiple messages were deleted at once.
func (*Dispatch) MessageDeleteChan ¶
func (d *Dispatch) MessageDeleteChan() <-chan *MessageDelete
MessageDeleteChan for MESSAGE_DELETE. Message was deleted.
func (*Dispatch) MessageReactionAddChan ¶
func (d *Dispatch) MessageReactionAddChan() <-chan *MessageReactionAdd
MessageReactionAddChan for MESSAGE_REACTION_ADD. A user reacted to a message.
func (*Dispatch) MessageReactionRemoveAllChan ¶
func (d *Dispatch) MessageReactionRemoveAllChan() <-chan *MessageReactionRemoveAll
MessageReactionRemoveAllChan for MESSAGE_REACTION_REMOVE_ALL. All reactions were explicitly removed from a message
func (*Dispatch) MessageReactionRemoveChan ¶
func (d *Dispatch) MessageReactionRemoveChan() <-chan *MessageReactionRemove
MessageReactionRemoveChan for MESSAGE_REACTION_REMOVE. A user removed a a reaction to a message.
func (*Dispatch) MessageUpdateChan ¶
func (d *Dispatch) MessageUpdateChan() <-chan *MessageUpdate
MessageUpdateChan for MESSAGE_UPDATE. Message was updated.
func (*Dispatch) PresenceUpdateChan ¶
func (d *Dispatch) PresenceUpdateChan() <-chan *PresenceUpdate
PresenceUpdateChan for PRESENCE_UPDATE. A user's presence was updated in a guild.
func (*Dispatch) ResumedChan ¶
ResumedChan for RESUME events
func (*Dispatch) TypingStartChan ¶
func (d *Dispatch) TypingStartChan() <-chan *TypingStart
TypingStartChan for TYPING_START. A user started typing in a channel.
func (*Dispatch) UserUpdateChan ¶
func (d *Dispatch) UserUpdateChan() <-chan *UserUpdate
UserUpdateChan for USER_UPDATE. Properties about a user changed
func (*Dispatch) VoiceServerUpdateChan ¶
func (d *Dispatch) VoiceServerUpdateChan() <-chan *VoiceServerUpdate
VoiceServerUpdateChan for VOICE_SERVER_UPDATE. Guild's voice server was updated
func (*Dispatch) VoiceStateUpdateChan ¶
func (d *Dispatch) VoiceStateUpdateChan() <-chan *VoiceStateUpdate
VoiceStateUpdateChan for VOICE_STATE_UPDATE. Someone joined, left, or moved a voice channel
func (*Dispatch) WebhooksUpdateChan ¶
func (d *Dispatch) WebhooksUpdateChan() <-chan *WebhooksUpdate
WebhooksUpdateChan for WEBHOOK_UPDATE. A guild channel webhook was created, update, or deleted
type EditChannelPermissionsParams ¶ added in v0.6.0
type EditChannelPermissionsParams struct { Allow int `json:"allow"` // the bitwise value of all allowed permissions Deny int `json:"deny"` // the bitwise value of all disallowed permissions Type string `json:"type"` // "member" for a user or "role" for a role }
EditChannelPermissionsParams https://discordapp.com/developers/docs/resources/channel#edit-channel-permissions-json-params
type EditMessageParams ¶ added in v0.6.0
type EditMessageParams struct { Content string `json:"content,omitempty"` Embed *ChannelEmbed `json:"embed,omitempty"` // embedded rich content }
EditMessageParams https://discordapp.com/developers/docs/resources/channel#edit-message-json-params
type Emoji ¶ added in v0.6.0
type Emoji struct { ID Snowflake `json:"id"` Name string `json:"name"` Roles []Snowflake `json:"roles,omitempty"` User *User `json:"user,omitempty"` // the user who created the emoji RequireColons bool `json:"require_colons,omitempty"` Managed bool `json:"managed,omitempty"` Animated bool `json:"animated,omitempty"` }
Emoji
func CreateGuildEmoji ¶ added in v0.6.0
func CreateGuildEmoji(client httd.Poster, guildID Snowflake, params *CreateGuildEmojiParams) (ret *Emoji, err error)
CreateGuildEmoji [POST] Create a new emoji for the guild. Requires the
'MANAGE_EMOJIS' permission. Returns the new emoji object on success. Fires a Guild Emojis Update Gateway event.
Endpoint /guilds/{guild.id}/emojis Rate limiter [MAJOR] /guilds/{guild.id} // TODO: no idea if this is correct Discord documentation https://discordapp.com/developers/docs/resources/emoji#create-guild-emoji Reviewed 2018-06-10 Comment Emojis and animated emojis have a maximum file size of 256kb.
Attempting to upload an emoji larger than this limit will fail and return 400 Bad Request and an error message, but not a JSON status code.
func GetGuildEmoji ¶ added in v0.6.0
GetGuildEmoji [GET] Returns an emoji object for the given guild and emoji IDs. Endpoint /guilds/{guild.id}/emojis/{emoji.id} Rate limiter [MAJOR] /guilds/{guild.id} // TODO: no idea if this is correct Discord documentation https://discordapp.com/developers/docs/resources/emoji#get-guild-emoji Reviewed 2018-06-10 Comment -
func ListGuildEmojis ¶ added in v0.6.0
ListGuildEmojis [GET] Returns a list of emoji objects for the given guild. Endpoint /guilds/{guild.id}/emojis Rate limiter [MAJOR] /guilds/{guild.id} // TODO: no idea if this is correct Discord documentation https://discordapp.com/developers/docs/resources/emoji#list-guild-emojis Reviewed 2018-06-10 Comment -
func ModifyGuildEmoji ¶ added in v0.6.0
func ModifyGuildEmoji(client httd.Patcher, guildID, emojiID Snowflake, params *ModifyGuildEmojiParams) (ret *Emoji, err error)
ModifyGuildEmoji [PATCH] Modify the given emoji. Requires the 'MANAGE_EMOJIS'
permission. Returns the updated emoji object on success. Fires a Guild Emojis Update Gateway event.
Endpoint /guilds/{guild.id}/emojis/{emoji.id} Rate limiter [MAJOR] /guilds/{guild.id} // TODO: no idea if this is correct Discord documentation https://discordapp.com/developers/docs/resources/emoji#modify-guild-emoji Reviewed 2018-06-10 Comment -
func (*Emoji) MentionAnimated ¶ added in v0.6.0
MentionAnimated add the animation prefix if a animated emoji TODO: review
type EventCallback ¶
type EventCallback = func(session Session, box interface{})
EventCallback is triggered on every event type
type EvtDispatcher ¶
type EvtDispatcher interface { AllChan() <-chan interface{} // any event ReadyChan() <-chan *Ready ResumedChan() <-chan *Resumed ChannelCreateChan() <-chan *ChannelCreate ChannelUpdateChan() <-chan *ChannelUpdate ChannelDeleteChan() <-chan *ChannelDelete ChannelPinsUpdateChan() <-chan *ChannelPinsUpdate GuildCreateChan() <-chan *GuildCreate GuildUpdateChan() <-chan *GuildUpdate GuildDeleteChan() <-chan *GuildDelete GuildBanAddChan() <-chan *GuildBanAdd GuildBanRemoveChan() <-chan *GuildBanRemove GuildEmojisUpdateChan() <-chan *GuildEmojisUpdate GuildIntegrationsUpdateChan() <-chan *GuildIntegrationsUpdate GuildMemberAddChan() <-chan *GuildMemberAdd GuildMemberRemoveChan() <-chan *GuildMemberRemove GuildMemberUpdateChan() <-chan *GuildMemberUpdate GuildMembersChunkChan() <-chan *GuildMembersChunk GuildRoleUpdateChan() <-chan *GuildRoleUpdate GuildRoleCreateChan() <-chan *GuildRoleCreate GuildRoleDeleteChan() <-chan *GuildRoleDelete MessageCreateChan() <-chan *MessageCreate MessageUpdateChan() <-chan *MessageUpdate MessageDeleteChan() <-chan *MessageDelete MessageDeleteBulkChan() <-chan *MessageDeleteBulk MessageReactionAddChan() <-chan *MessageReactionAdd MessageReactionRemoveChan() <-chan *MessageReactionRemove MessageReactionRemoveAllChan() <-chan *MessageReactionRemoveAll PresenceUpdateChan() <-chan *PresenceUpdate TypingStartChan() <-chan *TypingStart UserUpdateChan() <-chan *UserUpdate VoiceStateUpdateChan() <-chan *VoiceStateUpdate VoiceServerUpdateChan() <-chan *VoiceServerUpdate WebhooksUpdateChan() <-chan *WebhooksUpdate AddHandler(evtName string, listener interface{}) AddHandlerOnce(evtName string, listener interface{}) }
EvtDispatcher interface for developers using the module. Gives access to channels and the option to add callbacks to specific event types.
type ExecuteWebhookParams ¶ added in v0.6.0
type ExecuteWebhookParams struct { WebhookID Snowflake `json:"-"` Token string `json:"-"` Content string `json:"content"` Username string `json:"username"` AvatarURL string `json:"avatar_url"` TTS bool `json:"tts"` File interface{} `json:"file"` Embeds []*ChannelEmbed `json:"embeds"` }
ExecuteWebhookParams JSON params for func ExecuteWebhook
func NewExecuteWebhookParams ¶ added in v0.6.0
func NewExecuteWebhookParams(id Snowflake, token string) (ret *ExecuteWebhookParams, err error)
NewExecuteWebhookParams creates params for func ExecuteWebhook
type ExplicitContentFilterLvl ¶ added in v0.6.0
type ExplicitContentFilterLvl uint
ExplicitContentFilterLvl ... https://discordapp.com/developers/docs/resources/guild#guild-object-explicit-content-filter-level
func (*ExplicitContentFilterLvl) AllMembers ¶ added in v0.6.0
func (ecfl *ExplicitContentFilterLvl) AllMembers() bool
func (*ExplicitContentFilterLvl) Disabled ¶ added in v0.6.0
func (ecfl *ExplicitContentFilterLvl) Disabled() bool
func (*ExplicitContentFilterLvl) MembersWithoutRoles ¶ added in v0.6.0
func (ecfl *ExplicitContentFilterLvl) MembersWithoutRoles() bool
type GetChannelMessagesParams ¶ added in v0.6.0
type GetChannelMessagesParams struct { Around Snowflake `urlparam:"around,omitempty"` Before Snowflake `urlparam:"before,omitempty"` After Snowflake `urlparam:"after,omitempty"` Limit int `urlparam:"limit,omitempty"` }
GetChannelMessagesParams https://discordapp.com/developers/docs/resources/channel#get-channel-messages-query-string-params TODO: ensure limits
func (*GetChannelMessagesParams) GetQueryString ¶ added in v0.6.0
func (params *GetChannelMessagesParams) GetQueryString() string
GetQueryString .
type GetCurrentUserGuildsParams ¶ added in v0.6.0
type GetCurrentUserGuildsParams struct { Before Snowflake `urlparam:"before,omitempty"` After Snowflake `urlparam:"after,omitempty"` Limit int `urlparam:"limit,omitempty"` }
GetCurrentUserGuildsParams JSON params for func GetCurrentUserGuilds
func (*GetCurrentUserGuildsParams) GetQueryString ¶ added in v0.6.0
func (params *GetCurrentUserGuildsParams) GetQueryString() string
GetQueryString .
type GetReactionURLParams ¶ added in v0.6.0
type GetReactionURLParams struct { Before Snowflake `urlparam:"before,omitempty"` // get users before this user Snowflake After Snowflake `urlparam:"after,omitempty"` // get users after this user Snowflake Limit int `urlparam:"limit,omitempty"` // max number of users to return (1-100) }
GetReactionURLParams https://discordapp.com/developers/docs/resources/channel#get-reactions-query-string-params
func (*GetReactionURLParams) GetQueryString ¶ added in v0.6.0
func (params *GetReactionURLParams) GetQueryString() string
GetQueryString .
type GroupDMAddRecipientParams ¶ added in v0.6.0
type GroupDMAddRecipientParams struct { AccessToken string `json:"access_token"` // access token of a user that has granted your app the gdm.join scope Nickname string `json:"nick"` // nickname of the user being added }
GroupDMAddRecipientParams JSON params for GroupDMAddRecipient
type Guild ¶ added in v0.6.0
type Guild struct { ID Snowflake `json:"id"` ApplicationID *Snowflake `json:"application_id"` // |? Name string `json:"name"` Icon *string `json:"icon"` // |?, icon hash Splash *string `json:"splash"` // |?, image hash Owner bool `json:"owner,omitempty"` // ?| OwnerID Snowflake `json:"owner_id"` Permissions uint64 `json:"permissions,omitempty"` // ?|, permission flags for connected user `/users/@me/guilds` Region string `json:"region"` AfkChannelID *Snowflake `json:"afk_channel_id"` // |? AfkTimeout uint `json:"afk_timeout"` EmbedEnabled bool `json:"embed_enabled,omit_empty"` EmbedChannelID Snowflake `json:"embed_channel_id,omit_empty"` VerificationLevel VerificationLvl `json:"verification_level"` DefaultMessageNotifications DefaultMessageNotificationLvl `json:"default_message_notifications"` ExplicitContentFilter ExplicitContentFilterLvl `json:"explicit_content_filter"` Roles []*Role `json:"roles"` Emojis []*Emoji `json:"emojis"` Features []string `json:"features"` MFALevel MFALvl `json:"mfa_level"` WidgetEnabled bool `json:"widget_enabled,omit_empty"` // | WidgetChannelID Snowflake `json:"widget_channel_id,omit_empty"` // | SystemChannelID *Snowflake `json:"system_channel_id,omitempty"` // |? // JoinedAt must be a pointer, as we can't hide non-nil structs JoinedAt *Timestamp `json:"joined_at,omitempty"` // ?*| Large bool `json:"large,omitempty"` // ?*| MemberCount uint `json:"member_count,omitempty"` // ?*| VoiceStates []*VoiceState `json:"voice_states,omitempty"` // ?*| Members []*Member `json:"members,omitempty"` // ?*| Channels []*Channel `json:"channels,omitempty"` // ?*| Presences []*UserPresence `json:"presences,omitempty"` // ?*| PresencesMutex sync.RWMutex `json:"-"` // contains filtered or unexported fields }
func CreateGuild ¶ added in v0.6.0
func CreateGuild(client httd.Poster, params *CreateGuildParams) (ret *Guild, err error)
CreateGuild [POST] Create a new guild. Returns a guild object on success. Fires a Guild Create Gateway event. Endpoint /guilds Rate limiter /guilds Discord documentation https://discordapp.com/developers/docs/resources/guild#create-guild Reviewed 2018-08-16 Comment This endpoint. can be used only by bots in less than 10 guilds. Creating channel
categories from this endpoint. is not supported.
func GetCurrentUserGuilds ¶ added in v0.6.0
func GetCurrentUserGuilds(client httd.Getter, params *GetCurrentUserGuildsParams) (ret []*Guild, err error)
GetCurrentUserGuilds [GET] Returns a list of partial guild objects the current user is a member of.
Requires the guilds OAuth2 scope.
Endpoint /users/@me/guilds Rate limiter /users TODO: is this correct? Discord documentation https://discordapp.com/developers/docs/resources/user#get-current-user-guilds Reviewed 2018-06-10 Comment This endpoint. returns 100 guilds by default, which is the maximum number of
guilds a non-bot user can join. Therefore, pagination is not needed for integrations that need to get a list of users' guilds.
func GetGuild ¶ added in v0.6.0
GetGuild [GET] Returns the guild object for the given id. Endpoint /guilds/{guild.id} Rate limiter /guilds/{guild.id} Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild Reviewed 2018-08-17 Comment -
func ModifyGuild ¶ added in v0.6.0
func ModifyGuild(client httd.Patcher, id Snowflake, params *ModifyGuildParams) (ret *Guild, err error)
ModifyGuild [PATCH] Modify a guild's settings. Requires the 'MANAGE_GUILD' permission. Returns the updated
guild object on success. Fires a Guild Update Gateway event.
Endpoint /guilds/{guild.id} Rate limiter /guilds/{guild.id} Discord documentation https://discordapp.com/developers/docs/resources/guild#modify-guild Reviewed 2018-08-17 Comment All parameters to this endpoint. are optional
func ModifyGuildChannelPositions ¶ added in v0.6.0
func ModifyGuildChannelPositions(client httd.Patcher, id Snowflake, params *ModifyGuildChannelPositionsParams) (ret *Guild, err error)
ModifyGuildChannelPositions [PATCH] Modify the positions of a set of channel objects for the guild. Requires
'MANAGE_CHANNELS' permission. Returns a 204 empty response on success. Fires multiple Channel Update Gateway events.
Endpoint /guilds/{guild.id}/channels Rate limiter /guilds/{guild.id}/channels Discord documentation https://discordapp.com/developers/docs/resources/guild#modify-guild-channel-positions Reviewed 2018-08-17 Comment Only channels to be modified are required, with the minimum being a swap
between at least two channels.
func NewGuildFromJSON ¶ added in v0.6.0
func NewGuildFromUnavailable ¶ added in v0.6.0
func NewGuildFromUnavailable(gu *GuildUnavailable) *Guild
func NewPartialGuild ¶ added in v0.6.0
func (*Guild) AddChannel ¶ added in v0.6.0
func (*Guild) DeleteChannel ¶ added in v0.6.0
func (*Guild) DeleteChannelByID ¶ added in v0.6.0
func (*Guild) DeleteRoleByID ¶ added in v0.6.0
func (*Guild) MarshalJSON ¶ added in v0.6.0
TODO: fix copying of mutex lock
func (*Guild) MemberByName ¶ added in v0.6.0
MemberByName retrieve a slice of members with same username or nickname
func (*Guild) RoleByName ¶ added in v0.6.0
RoleByTitle retrieves a slice of roles with same name
func (*Guild) UpdatePresence ¶ added in v0.6.0
func (g *Guild) UpdatePresence(p *UserPresence)
func (*Guild) UpdateRole ¶ added in v0.6.0
type GuildAuditLogsParams ¶ added in v0.6.0
type GuildAuditLogsParams struct { UserID Snowflake `urlparam:"user_id,omitempty"` // filter the log for a user id ActionType uint `urlparam:"action_type,omitempty"` // the type of audit log event Before Snowflake `urlparam:"before,omitempty"` // filter the log before a certain entry id Limit int `urlparam:"limit,omitempty"` // how many entries are returned (default 50, minimum 1, maximum 100) }
GuildAuditLogsParams set params used in endpoint request https://discordapp.com/developers/docs/resources/audit-log#get-guild-audit-log-query-string-parameters
func (*GuildAuditLogsParams) GetQueryString ¶ added in v0.6.0
func (params *GuildAuditLogsParams) GetQueryString() string
GetQueryString .
type GuildBanAdd ¶ added in v0.6.0
GuildBanAdd user was banned from a guild
type GuildBanAddCallback ¶
type GuildBanAddCallback = func(session Session, gba *GuildBanAdd)
GuildBanAddCallback triggered on GUILD_BAN_ADD events
type GuildBanRemove ¶ added in v0.6.0
GuildBanRemove user was unbanned from a guild
type GuildBanRemoveCallback ¶
type GuildBanRemoveCallback = func(session Session, gbr *GuildBanRemove)
GuildBanRemoveCallback triggered on GUILD_BAN_REMOVE events
type GuildCreate ¶ added in v0.6.0
GuildCreate This event can be sent in three different scenarios:
- When a user is initially connecting, to lazily load and backfill information for all unavailable guilds sent in the Ready event.
- When a Guild becomes available again to the client.
- When the current user joins a new Guild.
type GuildCreateCallback ¶
type GuildCreateCallback = func(session Session, gc *GuildCreate)
GuildCreateCallback triggered on GUILD_CREATE events
type GuildDelete ¶ added in v0.6.0
GuildDelete guild became unavailable, or user left/was removed from a guild
type GuildDeleteCallback ¶
type GuildDeleteCallback = func(session Session, gd *GuildDelete)
GuildDeleteCallback triggered on GUILD_DELETE events
type GuildEmbed ¶ added in v0.6.0
------------ GuildEmbed https://discordapp.com/developers/docs/resources/guild#guild-embed-object
func GetGuildEmbed ¶ added in v0.6.0
func GetGuildEmbed(client httd.Getter, guildID Snowflake) (ret *GuildEmbed, err error)
GetGuildEmbed [GET] Returns the guild embed object. Requires the 'MANAGE_GUILD' permission. Endpoint /guilds/{guild.id}/embed Rate limiter /guilds/{guild.id}/embed Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-embed Reviewed 2018-08-18 Comment -
func ModifyGuildEmbed ¶ added in v0.6.0
func ModifyGuildEmbed(client httd.Patcher, guildID Snowflake, params *GuildEmbed) (ret *GuildEmbed, err error)
ModifyGuildEmbed [PATCH] Modify a guild embed object for the guild. All attributes may be passed in
with JSON and modified. Requires the 'MANAGE_GUILD' permission. Returns the updated guild embed object.
Endpoint /guilds/{guild.id}/embed Rate limiter /guilds/{guild.id}/embed Discord documentation https://discordapp.com/developers/docs/resources/guild#modify-guild-embed Reviewed 2018-08-18 Comment -
type GuildEmojisUpdate ¶ added in v0.6.0
type GuildEmojisUpdate struct { GuildID Snowflake `json:"guild_id"` Emojis []*Emoji `json:"emojis"` Ctx context.Context `json:"-"` }
GuildEmojisUpdate guild emojis were updated
type GuildEmojisUpdateCallback ¶
type GuildEmojisUpdateCallback = func(session Session, geu *GuildEmojisUpdate)
GuildEmojisUpdateCallback triggered on GUILD_EMOJIS_UPDATE events
type GuildIntegrationsUpdate ¶ added in v0.6.0
type GuildIntegrationsUpdate struct { GuildID Snowflake `json:"guild_id"` Ctx context.Context `json:"-"` }
GuildIntegrationsUpdate guild integration was updated
type GuildIntegrationsUpdateCallback ¶
type GuildIntegrationsUpdateCallback = func(session Session, giu *GuildIntegrationsUpdate)
GuildIntegrationsUpdateCallback triggered on GUILD_INTEGRATIONS_UPDATE events
type GuildInterface ¶ added in v0.6.0
type GuildInterface interface {
Channel(ID Snowflake)
}
type GuildMemberAdd ¶ added in v0.6.0
GuildMemberAdd new user joined a guild
type GuildMemberAddCallback ¶
type GuildMemberAddCallback = func(session Session, gma *GuildMemberAdd)
GuildMemberAddCallback triggered on GUILD_MEMBER_ADD events
type GuildMemberRemove ¶ added in v0.6.0
type GuildMemberRemove struct { GuildID Snowflake `json:"guild_id"` User *User `json:"user"` Ctx context.Context `json:"-"` }
GuildMemberRemove user was removed from a guild
type GuildMemberRemoveCallback ¶
type GuildMemberRemoveCallback = func(session Session, gmr *GuildMemberRemove)
GuildMemberRemoveCallback triggered on GUILD_MEMBER_REMOVE events
type GuildMemberUpdate ¶ added in v0.6.0
type GuildMemberUpdate struct { GuildID Snowflake `json:"guild_id"` Roles []*Role `json:"roles"` User *User `json:"user"` Nick string `json:"nick"` Ctx context.Context `json:"-"` }
GuildMemberUpdate guild member was updated
type GuildMemberUpdateCallback ¶
type GuildMemberUpdateCallback = func(session Session, gmu *GuildMemberUpdate)
GuildMemberUpdateCallback triggered on GUILD_MEMBER_UPDATE events
type GuildMembersChunk ¶ added in v0.6.0
type GuildMembersChunk struct { GuildID Snowflake `json:"guild_id"` Members []*Member `json:"members"` Ctx context.Context `json:"-"` }
GuildMembersChunk response to Request Guild Members
type GuildMembersChunkCallback ¶
type GuildMembersChunkCallback = func(session Session, gmc *GuildMembersChunk)
GuildMembersChunkCallback triggered on GUILD_MEMBERS_CHUNK events
type GuildPruneCount ¶ added in v0.6.0
type GuildPruneCount struct {
Pruned int `json:"pruned"`
}
func BeginGuildPrune ¶ added in v0.6.0
func BeginGuildPrune(client httd.Poster, id Snowflake, params *GuildPruneParams) (ret *GuildPruneCount, err error)
BeginGuildPrune [POST] Begin a prune operation. Requires the 'KICK_MEMBERS' permission. Returns an object
with one 'pruned' key indicating the number of members that were removed in the prune operation. Fires multiple Guild Member Remove Gateway events.
Endpoint /guilds/{guild.id}/prune Rate limiter /guilds/{guild.id}/prune Discord documentation https://discordapp.com/developers/docs/resources/guild#begin-guild-prune Reviewed 2018-08-18 Comment -
func GetGuildPruneCount ¶ added in v0.6.0
func GetGuildPruneCount(client httd.Getter, id Snowflake, params *GuildPruneParams) (ret *GuildPruneCount, err error)
GetGuildPruneCount [GET] Returns an object with one 'pruned' key indicating the number of members that would
be removed in a prune operation. Requires the 'KICK_MEMBERS' permission.
Endpoint /guilds/{guild.id}/prune Rate limiter /guilds/{guild.id}/prune Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-prune-count Reviewed 2018-08-18 Comment -
type GuildPruneParams ¶ added in v0.6.0
type GuildPruneParams struct {
Days int `urlparam:"days"` // number of days to count prune for (1 or more)
}
GuildPruneParams https://discordapp.com/developers/docs/resources/guild#get-guild-prune-count-query-string-params
func (*GuildPruneParams) GetQueryString ¶ added in v0.6.0
func (params *GuildPruneParams) GetQueryString() string
GetQueryString .
type GuildRoleCreate ¶ added in v0.6.0
type GuildRoleCreate struct { GuildID Snowflake `json:"guild_id"` Role *Role `json:"role"` Ctx context.Context `json:"-"` }
GuildRoleCreate guild role was created
type GuildRoleCreateCallback ¶
type GuildRoleCreateCallback = func(session Session, grc *GuildRoleCreate)
GuildRoleCreateCallback triggered on GUILD_ROLE_CREATE events
type GuildRoleDelete ¶ added in v0.6.0
type GuildRoleDelete struct { GuildID Snowflake `json:"guild_id"` RoleID Snowflake `json:"role_id"` Ctx context.Context `json:"-"` }
GuildRoleDelete guild role was deleted
type GuildRoleDeleteCallback ¶
type GuildRoleDeleteCallback = func(session Session, grd *GuildRoleDelete)
GuildRoleDeleteCallback triggered on GUILD_ROLE_DELETE events
type GuildRoleUpdate ¶ added in v0.6.0
type GuildRoleUpdate struct { GuildID Snowflake `json:"guild_id"` Role *Role `json:"role"` Ctx context.Context `json:"-"` }
GuildRoleUpdate guild role was updated
type GuildRoleUpdateCallback ¶
type GuildRoleUpdateCallback = func(session Session, gru *GuildRoleUpdate)
GuildRoleUpdateCallback triggered on GUILD_ROLE_UPDATE events
type GuildUnavailable ¶ added in v0.6.0
type GuildUnavailable struct {}
func NewGuildUnavailable ¶ added in v0.6.0
func NewGuildUnavailable(ID Snowflake) *GuildUnavailable
type GuildUpdate ¶ added in v0.6.0
GuildUpdate guild was updated
type GuildUpdateCallback ¶
type GuildUpdateCallback = func(session Session, gu *GuildUpdate)
GuildUpdateCallback triggered on GUILD_UPDATE events
type Hello ¶ added in v0.6.0
type Hello struct { HeartbeatInterval uint `json:"heartbeat_interval"` Trace []string `json:"_trace"` Ctx context.Context `json:"-"` }
Hello defines the heartbeat interval
type HelloCallback ¶
HelloCallback triggered in hello events
type Integration ¶ added in v0.6.0
type Integration struct { ID Snowflake `json:"id"` Name string `json:"name"` Type string `json:"type"` Enabled bool `json:"enabled"` Syncing bool `json:"syncing"` RoleID Snowflake `json:"role_id"` ExpireBehavior int `json:"expire_behavior"` ExpireGracePeriod int `json:"expire_grace_period"` User *User `json:"user"` Account *IntegrationAccount `json:"account"` }
------- Integration https://discordapp.com/developers/docs/resources/guild#integration-object
func GetGuildIntegrations ¶ added in v0.6.0
func GetGuildIntegrations(client httd.Getter, id Snowflake) (ret []*Integration, err error)
GetGuildIntegrations [GET] Returns a list of integration objects for the guild.
Requires the 'MANAGE_GUILD' permission.
Endpoint /guilds/{guild.id}/integrations Rate limiter /guilds/{guild.id}/integrations Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-integrations Reviewed 2018-08-18 Comment -
type IntegrationAccount ¶ added in v0.6.0
type IntegrationAccount struct { ID string `json:"id"` // id of the account Name string `json:"name"` // name of the account }
IntegrationAccount https://discordapp.com/developers/docs/resources/guild#integration-account-object
type InvalidSession ¶ added in v0.6.0
InvalidSession failure response to Identify or Resume or invalid active session
type InvalidSessionCallback ¶
type InvalidSessionCallback = func(session Session, is *InvalidSession)
InvalidSessionCallback triggered on INVALID_SESSION events
type Invite ¶ added in v0.6.0
type Invite struct { // Code the invite code (unique Snowflake) Code string `json:"code"` // Guild the guild this invite is for Guild *PartialGuild `json:"guild"` // Channel the channel this invite is for Channel *PartialChannel `json:"channel"` // ApproximatePresenceCount approximate count of online members ApproximatePresenceCount int `json:"approximate_presence_count,omitempty"` // ApproximatePresenceCount approximate count of total members ApproximateMemberCount int `json:"approximate_member_count,omitempty"` }
Invite Represents a code that when used, adds a user to a guild. https://discordapp.com/developers/docs/resources/invite#invite-object Reviewed: 2018-06-10
func CreateChannelInvites ¶ added in v0.6.0
func CreateChannelInvites(client httd.Poster, id Snowflake, params *CreateChannelInvitesParams) (ret *Invite, err error)
CreateChannelInvites [POST] Create a new invite object for the channel. Only usable for guild channels.
Requires the CREATE_INSTANT_INVITE permission. All JSON parameters for this route are optional, however the request body is not. If you are not sending any fields, you still have to send an empty JSON object ({}). Returns an invite object.
Endpoint /channels/{channel.id}/invites Rate limiter [MAJOR] /channels/{channel.id}/invites Discord documentation https://discordapp.com/developers/docs/resources/channel#create-channel-invite Reviewed 2018-06-07 Comment -
func DeleteInvite ¶ added in v0.6.0
DeleteInvite [DELETE] Delete an invite. Requires the MANAGE_CHANNELS permission. Returns an invite
object on success.
Endpoint /invites/{invite.code} Rate limiter /invites Discord documentation https://discordapp.com/developers/docs/resources/invite#delete-invite Reviewed 2018-06-10 Comment -
func GetChannelInvites ¶ added in v0.6.0
GetChannelInvites [GET] Returns a list of invite objects (with invite metadata) for the channel.
Only usable for guild channels. Requires the 'MANAGE_CHANNELS' permission.
Endpoint /channels/{channel.id}/invites Rate limiter [MAJOR] /channels/{channel.id}/invites Discord documentation https://discordapp.com/developers/docs/resources/channel#get-channel-invites Reviewed 2018-06-07 Comment -
func GetGuildInvites ¶ added in v0.6.0
GetGuildInvites [GET] Returns a list of invite objects (with invite metadata) for the guild.
Requires the 'MANAGE_GUILD' permission.
Endpoint /guilds/{guild.id}/invites Rate limiter /guilds/{guild.id}/invites Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-invites Reviewed 2018-08-18 Comment -
func GetInvite ¶ added in v0.6.0
GetInvite [GET] Returns an invite object for the given code. Endpoint /invites/{invite.code} Rate limiter /invites Discord documentation https://discordapp.com/developers/docs/resources/invite#get-invite Reviewed 2018-06-10 Comment -
withCounts whether the invite should contain approximate member counts
type InviteMetadata ¶ added in v0.6.0
type InviteMetadata struct { // Inviter user who created the invite Inviter *User `json:"inviter"` // Uses number of times this invite has been used Uses int `json:"uses"` // MaxUses max number of times this invite can be used MaxUses int `json:"max_uses"` // MaxAge duration (in seconds) after which the invite expires MaxAge int `json:"max_age"` // Temporary whether this invite only grants temporary membership Temporary bool `json:"temporary"` // CreatedAt when this invite was created CreatedAt Timestamp `json:"created_at"` // Revoked whether this invite is revoked Revoked bool `json:"revoked"` }
InviteMetadata Object https://discordapp.com/developers/docs/resources/invite#invite-metadata-object Reviewed: 2018-06-10
type MFALvl ¶ added in v0.6.0
type MFALvl uint
MFA ... https://discordapp.com/developers/docs/resources/guild#guild-object-mfa-level
type Member ¶ added in v0.6.0
type Member struct { GuildID Snowflake `json:"guild_id,omitempty"` User *User `json:"user"` Nick string `json:"nick,omitempty"` // ?| Roles []Snowflake `json:"roles"` JoinedAt Timestamp `json:"joined_at,omitempty"` Deaf bool `json:"deaf"` Mute bool `json:"mute"` sync.RWMutex `json:"-"` }
Member https://discordapp.com/developers/docs/resources/guild#guild-member-object
func AddGuildMember ¶ added in v0.6.0
func AddGuildMember(client httd.Puter, guildID, userID Snowflake, params *AddGuildMemberParams) (ret *Member, err error)
AddGuildMember [PUT] Adds a user to the guild, provided you have a valid oauth2 access token for the user
with the guilds.join scope. Returns a 201 Created with the guild member as the body, or 204 No Content if the user is already a member of the guild. Fires a Guild Member Add Gateway event. Requires the bot to have the CREATE_INSTANT_INVITE permission.
Endpoint /guilds/{guild.id}/members/{user.id} Rate limiter /guilds/{guild.id}/members Discord documentation https://discordapp.com/developers/docs/resources/guild#add-guild-member Reviewed 2018-08-18 Comment All parameters to this endpoint. except for access_token are optional.
func GetGuildMember ¶ added in v0.6.0
GetGuildMember [GET] Returns a guild member object for the specified user. Endpoint /guilds/{guild.id}/members/{user.id} Rate limiter /guilds/{guild.id}/members Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-member Reviewed 2018-08-17 Comment -
func GetGuildMembers ¶ added in v0.6.0
func GetGuildMembers(client httd.Getter, guildID, after Snowflake, limit int) (ret []*Member, err error)
GetGuildMembers [GET] Returns a list of guild member objects that are members of the guild. Endpoint /guilds/{guild.id}/members Rate limiter /guilds/{guild.id}/members Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-members Reviewed 2018-08-17 Comment All parameters to this endpoint. are optional Comment#2 "List Guild Members" Comment#3 https://discordapp.com/developers/docs/resources/guild#list-guild-members-query-string-params
type Message ¶ added in v0.6.0
type Message struct { ID Snowflake `json:"id"` ChannelID Snowflake `json:"channel_id"` Author *User `json:"author"` Content string `json:"content"` Timestamp time.Time `json:"timestamp"` EditedTimestamp time.Time `json:"edited_timestamp"` // ? Tts bool `json:"tts"` MentionEveryone bool `json:"mention_everyone"` Mentions []*User `json:"mentions"` MentionRoles []Snowflake `json:"mention_roles"` Attachments []*Attachment `json:"attachments"` Embeds []*ChannelEmbed `json:"embeds"` Reactions []*Reaction `json:"reactions"` // ? Nonce Snowflake `json:"nonce"` // ?, used for validating a message was sent Pinned bool `json:"pinned"` WebhookID Snowflake `json:"webhook_id"` // ? Type uint `json:"type"` Activity MessageActivity `json:"activity"` Application MessageApplication `json:"application"` sync.RWMutex `json:"-"` }
Message https://discordapp.com/developers/docs/resources/channel#message-object-message-structure
func CreateChannelMessage ¶ added in v0.6.0
func CreateChannelMessage(client httd.Poster, channelID Snowflake, params *CreateChannelMessageParams) (ret *Message, err error)
CreateChannelMessage [POST] Post a message to a guild text or DM channel. If operating on a guild channel,
this endpoint requires the 'SEND_MESSAGES' permission to be present on the current user. If the tts field is set to true, the SEND_TTS_MESSAGES permission is required for the message to be spoken. Returns a message object. Fires a Message Create Gateway event. See message formatting for more information on how to properly format messages. The maximum request size when sending a message is 8MB.
Endpoint /channels/{channel.id}/messages Rate limiter [MAJOR] /channels/{channel.id}/messages Discord documentation https://discordapp.com/developers/docs/resources/channel#create-message Reviewed 2018-06-10 Comment Before using this endpoint, you must connect to and identify with a gateway
at least once. This endpoint supports both JSON and form data bodies. It does require multipart/form-data requests instead of the normal JSON request type when uploading files. Make sure you set your Content-Type to multipart/form-data if you're doing that. Note that in that case, the embed field cannot be used, but you can pass an url-encoded JSON body as a form value for payload_json.
func EditMessage ¶ added in v0.6.0
func EditMessage(client httd.Patcher, chanID, msgID Snowflake, params *EditMessageParams) (ret *Message, err error)
EditMessage [PATCH] Edit a previously sent message. You can only edit messages that have been sent by
the current user. Returns a message object. Fires a Message Update Gateway event.
Endpoint /channels/{channel.id}/messages/{message.id} Rate limiter [MAJOR] /channels/{channel.id}/messages Discord documentation https://discordapp.com/developers/docs/resources/channel#edit-message Reviewed 2018-06-10 Comment All parameters to this endpoint are optional.
func GetChannelMessage ¶ added in v0.6.0
func GetChannelMessage(client httd.Getter, channelID, messageID Snowflake) (ret *Message, err error)
GetChannelMessage [GET] Returns a specific message in the channel. If operating on a guild channel,
this endpoints requires the 'READ_MESSAGE_HISTORY' permission to be present on the current user. Returns a message object on success.
Endpoint /channels/{channel.id}/messages/{message.id} Rate limiter [MAJOR] /channels/{channel.id}/messages Discord documentation https://discordapp.com/developers/docs/resources/channel#get-channel-message Reviewed 2018-06-10 Comment -
func GetChannelMessages ¶ added in v0.6.0
func GetChannelMessages(client httd.Getter, channelID Snowflake, params URLParameters) (ret []*Message, err error)
GetChannelMessages [GET] Returns the messages for a channel. If operating on a guild channel, this
endpoint requires the 'VIEW_CHANNEL' permission to be present on the current user. If the current user is missing the 'READ_MESSAGE_HISTORY' permission in the channel then this will return no messages (since they cannot read the message history). Returns an array of message objects on success.
Endpoint /channels/{channel.id}/messages Rate limiter [MAJOR] /channels/{channel.id}/messages Discord documentation https://discordapp.com/developers/docs/resources/channel#get-channel-messages Reviewed 2018-06-10 Comment The before, after, and around keys are mutually exclusive, only one may
be passed at a time. see ReqGetChannelMessagesParams.
func GetPinnedMessages ¶ added in v0.6.0
GetPinnedMessages [GET] Returns all pinned messages in the channel as an array of message objects. Endpoint /channels/{channel.id}/pins Rate limiter [MAJOR] /channels/{channel.id}/pins Discord documentation https://discordapp.com/developers/docs/resources/channel#get-pinned-messages Reviewed 2018-06-10 Comment -
func NewMessage ¶ added in v0.6.0
func NewMessage() *Message
func (*Message) AddReaction ¶ added in v0.6.0
func (*Message) Delete ¶ added in v0.6.0
func (m *Message) Delete(client MessageDeleter) (err error)
Delete sends a delete request to Discord for the related message
func (*Message) MarshalJSON ¶ added in v0.6.0
func (*Message) RemoveReaction ¶ added in v0.6.0
func (*Message) Respond ¶ added in v0.6.0
func (m *Message) Respond(client MessageSender, message *Message) (msg *Message, err error)
func (*Message) RespondString ¶ added in v0.6.0
func (m *Message) RespondString(client MessageSender, content string) (msg *Message, err error)
type MessageActivity ¶ added in v0.6.0
https://discordapp.com/developers/docs/resources/channel#message-object-message-activity-structure
type MessageApplication ¶ added in v0.6.0
type MessageCreate ¶ added in v0.6.0
MessageCreate message was created
type MessageCreateCallback ¶
type MessageCreateCallback = func(session Session, mc *MessageCreate)
MessageCreateCallback triggered on MESSAGE_CREATE events
type MessageDelete ¶ added in v0.6.0
type MessageDelete struct { MessageID Snowflake `json:"id"` ChannelID Snowflake `json:"channel_id"` Ctx context.Context `json:"-"` }
MessageDelete message was deleted
type MessageDeleteBulk ¶ added in v0.6.0
type MessageDeleteBulk struct { MessageIDs []Snowflake `json:"ids"` ChannelID Snowflake `json:"channel_id"` Ctx context.Context `json:"-"` }
MessageDeleteBulk multiple messages were deleted at once
type MessageDeleteBulkCallback ¶
type MessageDeleteBulkCallback = func(session Session, mdb *MessageDeleteBulk)
MessageDeleteBulkCallback triggered on MESSAGE_DELETE_BULK events
type MessageDeleteCallback ¶
type MessageDeleteCallback = func(session Session, md *MessageDelete)
MessageDeleteCallback triggered on MESSAGE_DELETE events
type MessageDeleter ¶ added in v0.6.0
type MessageReactionAdd ¶ added in v0.6.0
type MessageReactionAdd struct { UserID Snowflake `json:"user_id"` ChannelID Snowflake `json:"channel_id"` MessageID Snowflake `json:"message_id"` // PartialEmoji id and name. id might be nil PartialEmoji *Emoji `json:"emoji"` Ctx context.Context `json:"-"` }
MessageReactionAdd user reacted to a message
type MessageReactionAddCallback ¶
type MessageReactionAddCallback = func(session Session, mra *MessageReactionAdd)
MessageReactionAddCallback triggered on MESSAGE_REACTION_ADD events
type MessageReactionRemove ¶ added in v0.6.0
type MessageReactionRemove struct { UserID Snowflake `json:"user_id"` ChannelID Snowflake `json:"channel_id"` MessageID Snowflake `json:"message_id"` // PartialEmoji id and name. id might be nil PartialEmoji *Emoji `json:"emoji"` Ctx context.Context `json:"-"` }
MessageReactionRemove user removed a reaction from a message
type MessageReactionRemoveAll ¶ added in v0.6.0
type MessageReactionRemoveAll struct { ChannelID Snowflake `json:"channel_id"` MessageID Snowflake `json:"id"` Ctx context.Context `json:"-"` }
MessageReactionRemoveAll all reactions were explicitly removed from a message
type MessageReactionRemoveAllCallback ¶
type MessageReactionRemoveAllCallback = func(session Session, mrra *MessageReactionRemoveAll)
MessageReactionRemoveAllCallback triggered on MESSAGE_REACTION_REMOVE_ALL events
type MessageReactionRemoveCallback ¶
type MessageReactionRemoveCallback = func(session Session, mrr *MessageReactionRemove)
MessageReactionRemoveCallback triggered on MESSAGE_REACTION_REMOVE events
type MessageSender ¶ added in v0.6.0
type MessageUpdate ¶ added in v0.6.0
MessageUpdate message was edited
type MessageUpdateCallback ¶
type MessageUpdateCallback = func(session Session, mu *MessageUpdate)
MessageUpdateCallback triggered on MESSAGE_UPDATE events
type MessageUpdater ¶ added in v0.6.0
type ModifyChannelParams ¶ added in v0.6.0
type ModifyChannelParams = Channel
ModifyChannelParams https://discordapp.com/developers/docs/resources/channel#modify-channel-json-params
type ModifyCurrentUserNickParams ¶ added in v0.6.0
type ModifyCurrentUserNickParams struct {
Nick string `json:"nick"` // :CHANGE_NICKNAME
}
ModifyCurrentUserNickParams https://discordapp.com/developers/docs/resources/guild#modify-guild-member-json-params
type ModifyCurrentUserParams ¶ added in v0.6.0
type ModifyCurrentUserParams struct { Username string `json:"username,omitempty"` Avatar string `json:"avatar,omitempty"` }
ModifyCurrentUserParams JSON params for func ModifyCurrentUser
type ModifyGuildChannelPositionsParams ¶ added in v0.6.0
type ModifyGuildChannelPositionsParams struct { ID Snowflake `json:"id"` Position int `json:"position"` }
ModifyGuildChannelPositionsParams https://discordapp.com/developers/docs/resources/guild#modify-guild-channel-positions-json-params
type ModifyGuildEmojiParams ¶ added in v0.6.0
ModifyGuildEmojiParams JSON params for func ModifyGuildEmoji
type ModifyGuildIntegrationParams ¶ added in v0.6.0
type ModifyGuildIntegrationParams struct { ExpireBehavior int `json:"expire_behavior"` ExpireGracePeriod int `json:"expire_grace_period"` EnableEmoticons bool `json:"enable_emoticons"` }
ModifyGuildIntegrationParams https://discordapp.com/developers/docs/resources/guild#modify-guild-integration-json-params
type ModifyGuildMemberParams ¶ added in v0.6.0
type ModifyGuildMemberParams struct { Nick string `json:"nick,omitempty"` // :MANAGE_NICKNAMES Roles []Snowflake `json:"roles,omitempty"` // :MANAGE_ROLES Mute bool `json:"mute,omitempty"` // :MUTE_MEMBERS Deaf bool `json:"deaf,omitempty"` // :DEAFEN_MEMBERS ChannelID Snowflake `json:"channel_id,omitempty"` // :MOVE_MEMBERS }
ModifyGuildMemberParams https://discordapp.com/developers/docs/resources/guild#modify-guild-member-json-params
type ModifyGuildParams ¶ added in v0.6.0
type ModifyGuildParams struct { Name string `json:"name,omitempty"` Region string `json:"region,omitempty"` VerificationLvl int `json:"verification_level,omitempty"` DefaultMsgNotifications DefaultMessageNotificationLvl `json:"default_message_notifications,omitempty"` ExplicitContentFilter ExplicitContentFilterLvl `json:"explicit_content_filter,omitempty"` AFKChannelID Snowflake `json:"afk_channel_id,omitempty"` AFKTimeout int `json:"afk_timeout,omitempty"` Icon string `json:"icon,omitempty"` OwnerID Snowflake `json:"owner_id,omitempty"` Splash string `json:"splash,omitempty"` SystemChannelID Snowflake `json:"system_channel_id,omitempty"` }
ModifyGuildParams https://discordapp.com/developers/docs/resources/guild#modify-guild-json-params
type ModifyGuildRoleParams ¶ added in v0.6.0
type ModifyGuildRoleParams struct { Name string `json:"name,omitempty"` Permissions int `json:"permissions,omitempty"` Color int `json:"color,omitempty"` Hoist bool `json:"hoist,omitempty"` Mentionable bool `json:"mentionable,omitempty"` }
ModifyGuildRoleParams JSON params for func ModifyGuildRole
type ModifyGuildRolePositionsParams ¶ added in v0.6.0
type ModifyGuildRolePositionsParams struct { ID Snowflake `json:"id"` Position int `json:"position"` }
ModifyGuildRolePositionsParams https://discordapp.com/developers/docs/resources/guild#modify-guild-role-positions-json-params
type PartialChannel ¶ added in v0.6.0
type PartialChannel = Channel
type PartialEmoji ¶ added in v0.6.0
type PartialEmoji = Emoji
type PartialGuild ¶ added in v0.6.0
type PartialGuild = Guild
Guild Guilds in Discord represent an isolated collection of users and channels,
and are often referred to as "servers" in the UI.
https://discordapp.com/developers/docs/resources/guild#guild-object Fields with `*` are only sent within the GUILD_CREATE event TODO: lazyload everything reviewed: 2018-08-25
type PartialInvite ¶ added in v0.6.0
type PartialInvite = Invite
PartialInvite
{ "code": "abc" }
func GetGuildVanityURL ¶ added in v0.6.0
func GetGuildVanityURL(client httd.Getter, guildID Snowflake) (ret *PartialInvite, err error)
GetGuildVanityURL [GET] Returns a partial invite object for guilds with that feature enabled.
Requires the 'MANAGE_GUILD' permission.
Endpoint /guilds/{guild.id}/vanity-url Rate limiter /guilds/{guild.id}/vanity-url Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-vanity-url Reviewed 2018-08-18 Comment -
type PermissionOverwrite ¶ added in v0.6.0
type PermissionOverwrite struct { ID Snowflake `json:"id"` // role or user id Type string `json:"type"` // either `role` or `member` Allow int `json:"allow"` // permission bit set Deny int `json:"deny"` // permission bit set }
Overwrite: https://discordapp.com/developers/docs/resources/channel#overwrite-object
func (*PermissionOverwrite) Clear ¶ added in v0.6.0
func (pmo *PermissionOverwrite) Clear()
type PresenceUpdate ¶ added in v0.6.0
type PresenceUpdate struct { User *User `json:"user"` RoleIDs []Snowflake `json:"roles"` Game *UserActivity `json:"game"` GuildID Snowflake `json:"guild_id"` // Status either "idle", "dnd", "online", or "offline" // TODO: constants somewhere.. Status string `json:"status"` Ctx context.Context `json:"-"` }
PresenceUpdate user's presence was updated in a guild
type PresenceUpdateCallback ¶
type PresenceUpdateCallback = func(session Session, pu *PresenceUpdate)
PresenceUpdateCallback triggered on PRESENCE_UPDATE events
type Reaction ¶ added in v0.6.0
type Reaction struct { Count uint `json:"count"` Me bool `json:"me"` Emoji *PartialEmoji `json:"Emoji"` }
https://discordapp.com/developers/docs/resources/channel#reaction-object
func CreateReaction ¶ added in v0.6.0
func CreateReaction(client httd.Puter, channelID, messageID Snowflake, emoji interface{}) (ret *Reaction, err error)
CreateReaction [PUT] Create a reaction for the message. This endpoint requires the 'READ_MESSAGE_HISTORY'
permission to be present on the current user. Additionally, if nobody else has reacted to the message using this emoji, this endpoint requires the 'ADD_REACTIONS' permission to be present on the current user. Returns a 204 empty response on success. The maximum request size when sending a message is 8MB.
Endpoint /channels/{channel.id}/messages/{message.id}/reactions/{emoji}/@me Rate limiter [MAJOR] /channels/{channel.id}/messages TODO: I have no idea what the key is Discord documentation https://discordapp.com/developers/docs/resources/channel#create-reaction Reviewed 2018-06-07 Comment - emoji either unicode (string) or *Emoji with an snowflake Snowflake if it's custom
type Ready ¶ added in v0.6.0
type Ready struct { APIVersion int `json:"v"` User *User `json:"user"` Guilds []*GuildUnavailable `json:"guilds"` // not really needed, as it is handled on the socket layer. SessionID string `json:"session_id"` Trace []string `json:"_trace"` sync.RWMutex `json:"-"` Ctx context.Context `json:"-"` }
Ready contains the initial state information
type ReadyCallback ¶
ReadyCallback triggered on READY events
type ResumedCallback ¶
ResumedCallback triggered on RESUME events
type Role ¶ added in v0.6.0
type Role struct { ID Snowflake `json:"id"` Name string `json:"name"` Color int `json:"color"` Hoist bool `json:"hoist"` Position int `json:"position"` Permissions uint64 `json:"permissions"` Managed bool `json:"managed"` Mentionable bool `json:"mentionable"` }
Role https://discordapp.com/developers/docs/topics/permissions#role-object
func CreateGuildRole ¶ added in v0.6.0
func CreateGuildRole(client httd.Poster, id Snowflake, params *CreateGuildRoleParams) (ret *Role, err error)
CreateGuildRole [POST] Create a new role for the guild. Requires the 'MANAGE_ROLES' permission.
Returns the new role object on success. Fires a Guild Role Create Gateway event.
Endpoint /guilds/{guild.id}/roles Rate limiter /guilds/{guild.id}/roles Discord documentation https://discordapp.com/developers/docs/resources/guild#create-guild-role Reviewed 2018-08-18 Comment All JSON params are optional.
func GetGuildRoles ¶ added in v0.6.0
GetGuildRoles [GET] Returns a list of role objects for the guild. Endpoint /guilds/{guild.id}/roles Rate limiter /guilds/{guild.id}/roles Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-roles Reviewed 2018-08-18 Comment -
func ModifyGuildRole ¶ added in v0.6.0
func ModifyGuildRole(client httd.Patcher, guildID, roleID Snowflake, params *ModifyGuildRoleParams) (ret []*Role, err error)
ModifyGuildRole [PATCH] Modify a guild role. Requires the 'MANAGE_ROLES' permission. Returns the updated
role on success. Fires a Guild Role Update Gateway event.
Endpoint /guilds/{guild.id}/roles/{role.id} Rate limiter /guilds/{guild.id}/roles Discord documentation https://discordapp.com/developers/docs/resources/guild#modify-guild-role Reviewed 2018-08-18 Comment -
func ModifyGuildRolePositions ¶ added in v0.6.0
func ModifyGuildRolePositions(client httd.Patcher, guildID Snowflake, params *ModifyGuildRolePositionsParams) (ret []*Role, err error)
ModifyGuildRolePositions [PATCH] Modify the positions of a set of role objects for the guild. Requires the
'MANAGE_ROLES' permission. Returns a list of all of the guild's role objects on success. Fires multiple Guild Role Update Gateway events.
Endpoint /guilds/{guild.id}/roles Rate limiter /guilds/{guild.id}/roles Discord documentation https://discordapp.com/developers/docs/resources/guild#modify-guild-role-positions Reviewed 2018-08-18 Comment -
type Session ¶
type Session interface { // Request For interacting with Discord. Sending messages, creating channels, guilds, etc. // To read object state such as guilds, State() should be used in stead. However some data // might not exist in the state. If so it should be requested. Note that this only holds http // CRUD operation and not the actual rest endpoints for discord (See Rest()). Req() httd.Requester // Event let's developers listen for specific events, event groups, or every event as one listener. // Supports both channels and callbacks Evt() EvtDispatcher // State reflects the latest changes received from Discord gateway. // Should be used instead of requesting objects. State() Cacher // RateLimiter the ratelimiter for the discord REST API RateLimiter() httd.RateLimiter // Discord Gateway, web socket // Connect() error Disconnect() error DisconnectOnInterrupt() error // event callbacks AddListener(evtName string, callback interface{}) AddListenerOnce(evtName string, callback interface{}) // all discord REST functions // TODO: support caching for each // Audit-log GetGuildAuditLogs(guildID Snowflake, params *GuildAuditLogsParams) (log *AuditLog, err error) // Channel GetChannel(id Snowflake) (ret *Channel, err error) ModifyChannel(changes *ModifyChannelParams) (ret *Channel, err error) DeleteChannel(id Snowflake) (err error) EditChannelPermissions(chanID, overwriteID Snowflake, params *EditChannelPermissionsParams) (err error) GetChannelInvites(id Snowflake) (ret []*Invite, err error) CreateChannelInvites(id Snowflake, params *CreateChannelInvitesParams) (ret *Invite, err error) DeleteChannelPermission(channelID, overwriteID Snowflake) (err error) TriggerTypingIndicator(channelID Snowflake) (err error) GetPinnedMessages(channelID Snowflake) (ret []*Message, err error) AddPinnedChannelMessage(channelID, msgID Snowflake) (err error) DeletePinnedChannelMessage(channelID, msgID Snowflake) (err error) GroupDMAddRecipient(channelID, userID Snowflake, params *GroupDMAddRecipientParams) (err error) GroupDMRemoveRecipient(channelID, userID Snowflake) (err error) GetChannelMessages(channelID Snowflake, params URLParameters) (ret []*Message, err error) GetChannelMessage(channelID, messageID Snowflake) (ret *Message, err error) CreateChannelMessage(channelID Snowflake, params *CreateChannelMessageParams) (ret *Message, err error) EditMessage(chanID, msgID Snowflake, params *EditMessageParams) (ret *Message, err error) DeleteMessage(channelID, msgID Snowflake) (err error) BulkDeleteMessages(chanID Snowflake, params *BulkDeleteMessagesParams) (err error) CreateReaction(channelID, messageID Snowflake, emoji interface{}) (ret *Reaction, err error) DeleteOwnReaction(channelID, messageID Snowflake, emoji interface{}) (err error) DeleteUserReaction(channelID, messageID, userID Snowflake, emoji interface{}) (err error) GetReaction(channelID, messageID Snowflake, emoji interface{}, params URLParameters) (ret []*User, err error) DeleteAllReactions(channelID, messageID Snowflake) (err error) // Emoji GetGuildEmojis(id Snowflake) (ret []*Emoji, err error) GetGuildEmoji(guildID, emojiID Snowflake) (ret *Emoji, err error) CreateGuildEmoji(guildID Snowflake, params *CreateGuildEmojiParams) (ret *Emoji, err error) ModifyGuildEmoji(guildID, emojiID Snowflake, params *ModifyGuildEmojiParams) (ret *Emoji, err error) DeleteGuildEmoji(guildID, emojiID Snowflake) (err error) // Guild CreateGuild(params *CreateGuildParams) (ret *Guild, err error) GetGuild(id Snowflake) (ret *Guild, err error) ModifyGuild(id Snowflake, params *ModifyGuildParams) (ret *Guild, err error) DeleteGuild(id Snowflake) (err error) GetGuildChannels(id Snowflake) (ret []*Channel, err error) CreateGuildChannel(id Snowflake, params *CreateGuildChannelParams) (ret *Channel, err error) GetGuildMember(guildID, userID Snowflake) (ret *Member, err error) GetGuildMembers(guildID, after Snowflake, limit int) (ret []*Member, err error) AddGuildMember(guildID, userID Snowflake, params *AddGuildMemberParams) (ret *Member, err error) ModifyGuildMember(guildID, userID Snowflake, params *ModifyGuildMemberParams) (err error) ModifyCurrentUserNick(id Snowflake, params *ModifyCurrentUserNickParams) (nick string, err error) AddGuildMemberRole(guildID, userID, roleID Snowflake) (err error) RemoveGuildMemberRole(guildID, userID, roleID Snowflake) (err error) RemoveGuildMember(guildID, userID Snowflake) (err error) GetGuildBans(id Snowflake) (ret []*Ban, err error) GetGuildBan(guildID, userID Snowflake) (ret *Ban, err error) CreateGuildBan(guildID, userID Snowflake, params *CreateGuildBanParams) (err error) RemoveGuildBan(guildID, userID Snowflake) (err error) GetGuildRoles(guildID Snowflake) (ret []*Role, err error) CreateGuildRole(id Snowflake, params *CreateGuildRoleParams) (ret *Role, err error) ModifyGuildRolePositions(guildID Snowflake, params *ModifyGuildRolePositionsParams) (ret []*Role, err error) ModifyGuildRole(guildID, roleID Snowflake, params *ModifyGuildRoleParams) (ret []*Role, err error) DeleteGuildRole(guildID, roleID Snowflake) (err error) GetGuildPruneCount(id Snowflake, params *GuildPruneParams) (ret *GuildPruneCount, err error) BeginGuildPrune(id Snowflake, params *GuildPruneParams) (ret *GuildPruneCount, err error) GetGuildVoiceRegions(id Snowflake) (ret []*VoiceRegion, err error) GetGuildInvites(id Snowflake) (ret []*Invite, err error) GetGuildIntegrations(id Snowflake) (ret []*Integration, err error) CreateGuildIntegration(guildID Snowflake, params *CreateGuildIntegrationParams) (err error) ModifyGuildIntegration(guildID, integrationID Snowflake, params *ModifyGuildIntegrationParams) (err error) DeleteGuildIntegration(guildID, integrationID Snowflake) (err error) SyncGuildIntegration(guildID, integrationID Snowflake) (err error) GetGuildEmbed(guildID Snowflake) (ret *GuildEmbed, err error) ModifyGuildEmbed(guildID Snowflake, params *GuildEmbed) (ret *GuildEmbed, err error) GetGuildVanityURL(guildID Snowflake) (ret *PartialInvite, err error) // Invite GetInvite(inviteCode string, withCounts bool) (invite *Invite, err error) DeleteInvite(inviteCode string) (invite *Invite, err error) // User GetCurrentUser() (ret *User, err error) GetUser(id Snowflake) (ret *User, err error) ModifyCurrentUser(params *ModifyCurrentUserParams) (ret *User, err error) GetCurrentUserGuilds(params *GetCurrentUserGuildsParams) (ret []*Guild, err error) LeaveGuild(id Snowflake) (err error) GetUserDMs() (ret []*Channel, err error) CreateDM(recipientID Snowflake) (ret *Channel, err error) CreateGroupDM(params *CreateGroupDMParams) (ret *Channel, err error) GetUserConnections() (ret []*UserConnection, err error) // Voice GetVoiceRegions() (ret []*VoiceRegion, err error) // Webhook CreateWebhook(channelID Snowflake, params *CreateWebhookParams) (ret *Webhook, err error) GetChannelWebhooks(channelID Snowflake) (ret []*Webhook, err error) GetGuildWebhooks(guildID Snowflake) (ret []*Webhook, err error) GetWebhook(id Snowflake) (ret *Webhook, err error) GetWebhookWithToken(id Snowflake, token string) (ret *Webhook, err error) ModifyWebhook(newWebhook *Webhook) (ret *Webhook, err error) ModifyWebhookWithToken(newWebhook *Webhook) (ret *Webhook, err error) DeleteWebhook(webhookID Snowflake) (err error) DeleteWebhookWithToken(id Snowflake, token string) (err error) ExecuteWebhook(params *ExecuteWebhookParams, wait bool, URLSuffix string) (err error) ExecuteSlackWebhook(params *ExecuteWebhookParams, wait bool) (err error) ExecuteGitHubWebhook(params *ExecuteWebhookParams, wait bool) (err error) // Custom SendMsg(channelID Snowflake, message *Message) (msg *Message, err error) SendMsgString(channelID Snowflake, content string) (msg *Message, err error) UpdateMessage(message *Message) (msg *Message, err error) UpdateChannel(channel *Channel) (err error) }
Session the discord api is split in two. socket for keeping the client up to date, and http api for requests.
func NewSession ¶
NewSession create a client and return the Session interface
func NewSessionMustCompile ¶
NewSessionMustCompile same as NewClientMustCompile, but with the Session interface
type Snowflake ¶ added in v0.6.0
Snowflake twitter snowflake identification for Discord
func GetSnowflake ¶ added in v0.6.0
func NewSnowflake ¶ added in v0.6.0
func ParseSnowflakeString ¶ added in v0.6.0
type Timestamp ¶ added in v0.6.0
func (Timestamp) MarshalJSON ¶ added in v0.6.0
error: https://stackoverflow.com/questions/28464711/go-strange-json-hyphen-unmarshall-error
func (Timestamp) String ¶ added in v0.6.0
String converts the timestamp into a discord formatted timestamp. time.RFC3331 does not suffice
func (Timestamp) Time ¶ added in v0.6.0
Time converts the DiscordTimestamp into a time.Time type.......
func (*Timestamp) UnmarshalJSON ¶ added in v0.6.0
type TypingStart ¶ added in v0.6.0
type TypingStart struct { ChannelID Snowflake `json:"channel_id"` UserID Snowflake `json:"user_id"` TimestampUnix int `json:"timestamp"` Ctx context.Context `json:"-"` }
TypingStart user started typing in a channel
type TypingStartCallback ¶
type TypingStartCallback = func(session Session, ts *TypingStart)
TypingStartCallback triggered on TYPING_START events
type URLParameters ¶ added in v0.6.0
type URLParameters interface {
GetQueryString() string
}
URLParameters converts a struct of values to a valid URL query string
type Unmarshaler ¶ added in v0.6.0
type User ¶ added in v0.6.0
type User struct { ID Snowflake `json:"id,omitempty"` Username string `json:"username,omitempty"` Discriminator string `json:"discriminator,omitempty"` Email string `json:"email,omitempty"` Avatar *string `json:"avatar"` // _ENCODED_JPEG_IMAGE_DATA //TODO: pointer? Token string `json:"token,omitempty"` Verified bool `json:"verified,omitempty"` MFAEnabled bool `json:"mfa_enabled,omitempty"` Bot bool `json:"bot,omitempty"` sync.RWMutex `json:"-"` }
func GetCurrentUser ¶ added in v0.6.0
GetCurrentUser [GET] Returns the user object of the requester's account. For OAuth2, this requires
the identify scope, which will return the object without an email, and optionally the email scope, which returns the object with an email.
Endpoint /users/@me Rate limiter /users Discord documentation https://discordapp.com/developers/docs/resources/user#get-current-user Reviewed 2018-06-10 Comment -
func GetReaction ¶ added in v0.6.0
func GetReaction(client httd.Getter, channelID, messageID Snowflake, emoji interface{}, params URLParameters) (ret []*User, err error)
GetReaction [GET] Get a list of users that reacted with this emoji. Returns an array of user objects on success. Endpoint /channels/{channel.id}/messages/{message.id}/reactions/{emoji} Rate limiter [MAJOR] /channels/{channel.id}/messages TODO: I have no idea if this is the correct key Discord documentation https://discordapp.com/developers/docs/resources/channel#get-reactions Reviewed 2018-06-07 Comment - emoji either unicode (string) or *Emoji with an snowflake Snowflake if it's custom
func GetUser ¶ added in v0.6.0
GetUser [GET] Returns a user object for a given user Snowflake. Endpoint /users/{user.id} Rate limiter /users Discord documentation https://discordapp.com/developers/docs/resources/user#get-user Reviewed 2018-06-10 Comment -
func ModifyCurrentUser ¶ added in v0.6.0
func ModifyCurrentUser(client httd.Patcher, params *ModifyCurrentUserParams) (ret *User, err error)
ModifyCurrentUser [PATCH] Modify the requester's user account settings. Returns a user object on success. Endpoint /users/@me Rate limiter /users Discord documentation https://discordapp.com/developers/docs/resources/user#modify-current-user Reviewed 2018-06-10 Comment -
func NewUser ¶ added in v0.6.0
func NewUser() *User
TODO: should a user object always have a Snowflake?
func (*User) MarshalJSON ¶ added in v0.6.0
func (*User) MentionNickname ¶ added in v0.6.0
func (*User) Partial ¶ added in v0.6.0
Partial check if this is not a complete user object Assumption: has a snowflake.
func (*User) SendMsgString ¶ added in v0.6.0
type UserActivity ¶ added in v0.6.0
type UserActivity struct{}
TODO: https://discordapp.com/developers/docs/topics/gateway#activity-object-activity-structure
type UserConnection ¶ added in v0.6.0
type UserConnection struct { ID string `json:"id"` // id of the connection account Name string `json:"name"` // the username of the connection account Type string `json:"type"` // the service of the connection (twitch, youtube) Revoked bool `json:"revoked"` // whether the connection is revoked Integrations []*IntegrationAccount `json:"integrations"` // an array of partial server integrations }
func GetUserConnections ¶ added in v0.6.0
func GetUserConnections(client httd.Getter) (ret []*UserConnection, err error)
GetUserConnections [GET] Returns a list of connection objects. Requires the connections OAuth2 scope. Endpoint /users/@me/connections Rate limiter /users TODO: is this correct? Discord documentation https://discordapp.com/developers/docs/resources/user#get-user-connections Reviewed 2018-06-10 Comment -
type UserInterface ¶ added in v0.6.0
type UserPresence ¶ added in v0.6.0
type UserPresence struct { User *User `json:"user"` Roles []Snowflake `json:"roles"` Game *UserActivity `json:"activity"` GuildID Snowflake `json:"guild_id"` Nick string `json:"nick"` Status string `json:"status"` }
func NewUserPresence ¶ added in v0.6.0
func NewUserPresence() *UserPresence
func (*UserPresence) Clear ¶ added in v0.6.0
func (p *UserPresence) Clear()
func (*UserPresence) String ¶ added in v0.6.0
func (p *UserPresence) String() string
func (*UserPresence) Update ¶ added in v0.6.0
func (p *UserPresence) Update(status string)
type UserUpdate ¶ added in v0.6.0
UserUpdate properties about a user changed
type UserUpdateCallback ¶
type UserUpdateCallback = func(session Session, uu *UserUpdate)
UserUpdateCallback triggerd on USER_UPDATE events
type VerificationLvl ¶ added in v0.6.0
type VerificationLvl uint
Verification ... https://discordapp.com/developers/docs/resources/guild#guild-object-verification-level
func (*VerificationLvl) High ¶ added in v0.6.0
func (vl *VerificationLvl) High() bool
High (╯°□°)╯︵ ┻━┻ - must be a member of the server for longer than 10 minutes
func (*VerificationLvl) Low ¶ added in v0.6.0
func (vl *VerificationLvl) Low() bool
Low must have verified email on account
func (*VerificationLvl) Medium ¶ added in v0.6.0
func (vl *VerificationLvl) Medium() bool
Medium must be registered on Discord for longer than 5 minutes
func (*VerificationLvl) None ¶ added in v0.6.0
func (vl *VerificationLvl) None() bool
None unrestricted
func (*VerificationLvl) VeryHigh ¶ added in v0.6.0
func (vl *VerificationLvl) VeryHigh() bool
VeryHigh ┻━┻ミヽ(ಠ益ಠ)ノ彡┻━┻ - must have a verified phone number
type VoiceRegion ¶ added in v0.6.0
type VoiceRegion struct { // Snowflake unique Snowflake for the region ID string `json:"id"` // Name name of the region Name string `json:"name"` // SampleHostname an example hostname for the region SampleHostname string `json:"sample_hostname"` // SamplePort an example port for the region SamplePort uint `json:"sample_port"` // VIP true if this is a vip-only server VIP bool `json:"vip"` // Optimal true for a single server that is closest to the current user's client Optimal bool `json:"optimal"` // Deprecated whether this is a deprecated voice region (avoid switching to these) Deprecated bool `json:"deprecated"` // Custom whether this is a custom voice region (used for events/etc) Custom bool `json:"custom"` }
Region voice region structure https://discordapp.com/developers/docs/resources/voice#voice-region
func GetGuildVoiceRegions ¶ added in v0.6.0
func GetGuildVoiceRegions(client httd.Getter, id Snowflake) (ret []*VoiceRegion, err error)
GetGuildVoiceRegions [GET] Returns a list of voice region objects for the guild. Unlike the similar /voice
route, this returns VIP servers when the guild is VIP-enabled.
Endpoint /guilds/{guild.id}/regions Rate limiter /guilds/{guild.id}/regions Discord documentation https://discordapp.com/developers/docs/resources/guild#get-guild-voice-regions Reviewed 2018-08-18 Comment -
func ListVoiceRegions ¶ added in v0.6.0
func ListVoiceRegions(client httd.Getter) (ret []*VoiceRegion, err error)
ListVoiceRegions [GET] Returns an array of voice region objects that can be used when creating servers. Endpoint /voice/regions Rate limiter /voice/regions Discord documentation https://discordapp.com/developers/docs/resources/voice#list-voice-regions Reviewed 2018-08-21 Comment -
type VoiceServerUpdate ¶ added in v0.6.0
type VoiceServerUpdate struct { Token string `json:"token"` GuildID Snowflake `json:"guild_id"` Endpoint string `json:"endpoint"` Ctx context.Context `json:"-"` }
VoiceServerUpdate guild's voice server was updated Sent when a guild's voice server is updated. This is sent when initially connecting to voice, and when the current voice instance fails over to a new server.
type VoiceServerUpdateCallback ¶
type VoiceServerUpdateCallback = func(session Session, vsu *VoiceServerUpdate)
VoiceServerUpdateCallback triggered on VOICE_SERVER_UPDATE events
type VoiceState ¶ added in v0.6.0
type VoiceState struct { // GuildID the guild id this voice state is for GuildID Snowflake `json:"guild_id,omitempty"` // ? | // ChannelID the channel id this user is connected to ChannelID Snowflake `json:"channel_id"` // | // UserID the user id this voice state is for UserID Snowflake `json:"user_id"` // | // SessionID the session id for this voice state SessionID string `json:"session_id"` // | // Deaf whether this user is deafened by the server Deaf bool `json:"deaf"` // | // Mute whether this user is muted by the server Mute bool `json:"mute"` // | // SelfDeaf whether this user is locally deafened SelfDeaf bool `json:"self_deaf"` // | // SelfMute whether this user is locally muted SelfMute bool `json:"self_mute"` // | // Suppress whether this user is muted by the current user Suppress bool `json:"suppress"` // | }
State Voice State structure https://discordapp.com/developers/docs/resources/voice#voice-state-object
func (*VoiceState) Clear ¶ added in v0.6.0
func (vst *VoiceState) Clear()
type VoiceStateUpdate ¶ added in v0.6.0
type VoiceStateUpdate struct { VoiceState *VoiceState `json:"voice_state"` Ctx context.Context `json:"-"` }
VoiceStateUpdate someone joined, left, or moved a voice channel
type VoiceStateUpdateCallback ¶
type VoiceStateUpdateCallback = func(session Session, vsu *VoiceStateUpdate)
VoiceStateUpdateCallback triggered on VOICE_STATE_UPDATE events
type Webhook ¶ added in v0.6.0
type Webhook struct { ID Snowflake `json:"id"` // | GuildID Snowflake `json:"guild_id,omitempty"` // |? ChannelID Snowflake `json:"channel_id"` // | User *User `json:"user,omitempty"` // ?| Name string `json:"name"` // |? Avatar string `json:"avatar"` // |? Token string `json:"token"` // | }
Webhook Used to represent a webhook https://discordapp.com/developers/docs/resources/webhook#webhook-object
func CreateWebhook ¶ added in v0.6.0
func CreateWebhook(client httd.Poster, channelID Snowflake, params *CreateWebhookParams) (ret *Webhook, err error)
CreateWebhook [POST] Create a new webhook. Requires the 'MANAGE_WEBHOOKS' permission.
Returns a webhook object on success.
Endpoint /channels/{channel.id}/webhooks Rate limiter /channels/{channel.id}/webhooks Discord documentation https://discordapp.com/developers/docs/resources/webhook#create-webhook Reviewed 2018-08-14 Comment -
func GetChannelWebhooks ¶ added in v0.6.0
GetChannelWebhooks [GET] Returns a list of channel webhook objects. Requires the 'MANAGE_WEBHOOKS' permission. Endpoint /channels/{channel.id}/webhooks Rate limiter /channels/{channel.id}/webhooks Discord documentation https://discordapp.com/developers/docs/resources/webhook#get-channel-webhooks Reviewed 2018-08-14 Comment -
func GetGuildWebhooks ¶ added in v0.6.0
GetGuildWebhooks [GET] Returns a list of guild webhook objects. Requires the 'MANAGE_WEBHOOKS' permission. Endpoint /guilds/{guild.id}/webhooks Rate limiter /guilds/{guild.id}/webhooks Discord documentation https://discordapp.com/developers/docs/resources/webhook#get-guild-webhooks Reviewed 2018-08-14 Comment -
func GetWebhook ¶ added in v0.6.0
GetWebhook [GET] Returns the new webhook object for the given id. Endpoint /webhooks/{webhook.id} Rate limiter /webhooks/{webhook.id} Discord documentation https://discordapp.com/developers/docs/resources/webhook#get-webhook Reviewed 2018-08-14 Comment -
func GetWebhookWithToken ¶ added in v0.6.0
GetWebhookWithToken [GET] Same as GetWebhook, except this call does not require authentication and returns
no user in the webhook object.
Endpoint /webhooks/{webhook.id}/{webhook.token} Rate limiter /webhooks/{webhook.id} Discord documentation https://discordapp.com/developers/docs/resources/webhook#get-webhook-with-token Reviewed 2018-08-14 Comment -
func ModifyWebhook ¶ added in v0.6.0
ModifyWebhook [PATCH] Modify a webhook. Requires the 'MANAGE_WEBHOOKS' permission.
Returns the updated webhook object on success.
Endpoint /webhooks/{webhook.id} Rate limiter /webhooks/{webhook.id} Discord documentation https://discordapp.com/developers/docs/resources/webhook#modify-webhook Reviewed 2018-08-14 Comment All parameters to this endpoint. are optional. Not tested:extra json fields might
cause an issue. Consider writing a json params object.
func ModifyWebhookWithToken ¶ added in v0.6.0
ModifyWebhookWithToken [PATCH] Same as ModifyWebhook, except this call does not require authentication,
does not accept a channel_id parameter in the body, and does not return a user in the webhook object.
Endpoint /webhooks/{webhook.id}/{webhook.token} Rate limiter /webhooks/{webhook.id} Discord documentation https://discordapp.com/developers/docs/resources/webhook#modify-webhook-with-token Reviewed 2018-08-14 Comment All parameters to this endpoint. are optional. Not tested:extra json fields might
cause an issue. Consider writing a json params object.
type WebhooksUpdate ¶ added in v0.6.0
type WebhooksUpdate struct { GuildID Snowflake `json:"guild_id"` ChannelID Snowflake `json:"channel_id"` Ctx context.Context `json:"-"` }
WebhooksUpdate guild channel webhook was created, update, or deleted
type WebhooksUpdateCallback ¶
type WebhooksUpdateCallback = func(session Session, wu *WebhooksUpdate)
WebhooksUpdateCallback triggered on WEBHOOK_UPDATE events
Source Files ¶
- cache.go
- client.go
- disgord.go
- event.go
- event_dispatcher.go
- rest.go
- rest_auditlog.go
- rest_channel.go
- rest_emoji.go
- rest_guild.go
- rest_invite.go
- rest_user.go
- rest_voice.go
- rest_webhook.go
- struct.go
- struct_auditlog.go
- struct_channel.go
- struct_emoji.go
- struct_guild.go
- struct_helperTypes.go
- struct_invite.go
- struct_role.go
- struct_testing.go
- struct_user.go
- struct_voice.go
- struct_webhook.go