Documentation ¶
Index ¶
- Variables
- type AttachmentResponse
- type ChannelMentionResponse
- type DiscordJSONClient
- func (d *DiscordJSONClient) CreateReaction(ctx context.Context, cid, mid snowflake.Snowflake, emoji string) (resp *http.Response, err error)
- func (d *DiscordJSONClient) GetGateway(ctx context.Context) (GatewayResponse, error)
- func (d *DiscordJSONClient) GetGuildMember(ctx context.Context, gid, uid snowflake.Snowflake) (respData GuildMemberResponse, err error)
- func (d *DiscordJSONClient) GetMessage(ctx context.Context, cid, mid snowflake.Snowflake) (respData MessageResponse, err error)
- func (d *DiscordJSONClient) SendMessage(ctx context.Context, cid snowflake.Snowflake, m marshaler) (respData MessageResponse, err error)
- func (d *DiscordJSONClient) SetDebug(val bool)
- type Embed
- type EmbedAuthorResponse
- type EmbedField
- type EmbedFieldResponse
- type EmbedFooter
- type EmbedFooterResponse
- type EmbedImageResponse
- type EmbedProviderResponse
- type EmbedResponse
- type EmojiResponse
- type GatewayResponse
- type GuildMemberResponse
- type HTTPClient
- type Logger
- type Message
- type MessageReference
- type MessageResponse
- type MessageWithEmbed
- type ReactionResponse
- type RoleResponse
- type UserResponse
Constants ¶
This section is empty.
Variables ¶
var ErrResponse = errors.New("error response")
ErrResponse is the error that is wrapped and returned when there is a non-200 api response
Functions ¶
This section is empty.
Types ¶
type AttachmentResponse ¶
type AttachmentResponse struct { ID string `json:"id"` Filename string `json:"filename"` Size int `json:"size"` URL string `json:"url"` ProxyURL string `json:"proxy_url"` Height int `json:"height"` Width int `json:"width"` IDSnowflake snowflake.Snowflake }
AttachmentResponse is the data about an attachment recevied from the json api
func (*AttachmentResponse) Snowflakify ¶
func (ar *AttachmentResponse) Snowflakify() error
type ChannelMentionResponse ¶
type ChannelMentionResponse struct { ID string `json:"id"` GuildID string `json:"guild_id"` Type int `json:"type"` Name string `json:"name"` IDSnowflake snowflake.Snowflake GuildIDSnowflake snowflake.Snowflake }
ChannelMentionResponse is the data about a channel mention recevied from the json api
func (*ChannelMentionResponse) Snowflakify ¶
func (cmr *ChannelMentionResponse) Snowflakify() error
type DiscordJSONClient ¶
type DiscordJSONClient struct {
// contains filtered or unexported fields
}
func NewDiscordJSONClient ¶
func NewDiscordJSONClient(deps dependencies, apiURL string) *DiscordJSONClient
func (*DiscordJSONClient) CreateReaction ¶
func (*DiscordJSONClient) GetGateway ¶
func (d *DiscordJSONClient) GetGateway(ctx context.Context) (GatewayResponse, error)
func (*DiscordJSONClient) GetGuildMember ¶
func (d *DiscordJSONClient) GetGuildMember(ctx context.Context, gid, uid snowflake.Snowflake) (respData GuildMemberResponse, err error)
func (*DiscordJSONClient) GetMessage ¶
func (d *DiscordJSONClient) GetMessage(ctx context.Context, cid, mid snowflake.Snowflake) (respData MessageResponse, err error)
func (*DiscordJSONClient) SendMessage ¶
func (d *DiscordJSONClient) SendMessage(ctx context.Context, cid snowflake.Snowflake, m marshaler) (respData MessageResponse, err error)
func (*DiscordJSONClient) SetDebug ¶
func (d *DiscordJSONClient) SetDebug(val bool)
type Embed ¶
type Embed struct { Title string `json:"title,omitempty"` Description string `json:"description,omitempty"` URL string `json:"url"` Timestamp string `json:"timestamp,omitempty"` Color int `json:"color,omitempty"` Fields []EmbedField `json:"fields"` }
Embed is a json object that represents an embed in a MessageWithEmbed
type EmbedAuthorResponse ¶
type EmbedAuthorResponse struct { Name string `json:"name"` URL string `json:"url"` IconURL string `json:"icon_url"` ProxyIconURL string `json:"proxy_icon_url"` }
EmbedAuthorResponse is the data about an embed author recevied from the json api
type EmbedField ¶
type EmbedField struct { Name string `json:"name"` Value string `json:"value"` Inline bool `json:"inline"` }
EmbedField is a json object that represents a field in an Embed
type EmbedFieldResponse ¶
type EmbedFieldResponse struct { Name string `json:"name"` Value string `json:"value"` Inline bool `json:"inline"` }
EmbedFieldResponse is the data about an embed field received from the json api
type EmbedFooter ¶
type EmbedFooter struct {
}EmbedFooter is a json object that represents the footer of an embed
type EmbedFooterResponse ¶
type EmbedFooterResponse struct {}
EmbedFooterResponse is the data about an embed footer recevied from the json api
type EmbedImageResponse ¶
type EmbedImageResponse struct { URL string `json:"url"` ProxyURL string `json:"proxy_url"` Height int `json:"height"` Width int `json:"width"` }
EmbedImageResponse is the data about an embed thumbnail received from the json api
type EmbedProviderResponse ¶
EmbedProviderResponse is the data about an embed provider recevied from the json api
type EmbedResponse ¶
type EmbedResponse struct { Title string `json:"title"` Type string `json:"type"` Description string `json:"description"` URL string `json:"url"` Timestamp string `json:"timestamp"` // ISO8601 Color int `json:"color"` Image EmbedImageResponse `json:"image"` Thumbnail EmbedImageResponse `json:"thumbnail"` Video EmbedImageResponse `json:"video"` Provider EmbedProviderResponse `json:"provider"` Author EmbedAuthorResponse `json:"author"` Fields []EmbedFieldResponse `json:"fields"` }
EmbedResponse is the data about a message embed received from the json api
type EmojiResponse ¶
type EmojiResponse struct { ID string `json:"id"` Name string `json:"name"` Roles []RoleResponse `json:"roles"` User UserResponse `json:"user"` RequireColons bool `json:"require_colons"` Managed bool `json:"managed"` Animated bool `json:"animated"` Available bool `json:"available"` IDSnowflake snowflake.Snowflake }
EmojiResponse is the data about an emoji recevied from the json api
func (*EmojiResponse) Snowflakify ¶
func (er *EmojiResponse) Snowflakify() error
type GatewayResponse ¶
GatewayResponse is the json object received from the discord api when requesting gateway connection information
type GuildMemberResponse ¶
type GuildMemberResponse struct { User *UserResponse `json:"user"` Nick string `json:"nick"` Roles []string `json:"roles"` JoinedAt string `json:"joined_at"` // ISO8601 PremiumSince string `json:"premium_since"` // ISO8601 Deaf bool `json:"deaf"` Mute bool `json:"mute"` RoleSnowflakes []snowflake.Snowflake }
GuildMemberResponse is the data about a guild member recevied from the json api
func (GuildMemberResponse) HasRole ¶
func (gmr GuildMemberResponse) HasRole(rid snowflake.Snowflake) bool
func (*GuildMemberResponse) Snowflakify ¶
func (gmr *GuildMemberResponse) Snowflakify() error
type HTTPClient ¶
type HTTPClient interface { SetHeaders(http.Header) Get(context.Context, string, *http.Header) (*http.Response, error) GetBody(context.Context, string, *http.Header) (*http.Response, []byte, error) GetJSON(context.Context, string, *http.Header, interface{}) (*http.Response, error) Post(context.Context, string, *http.Header, io.Reader) (*http.Response, error) PostBody(context.Context, string, *http.Header, io.Reader) (*http.Response, []byte, error) PostJSON(context.Context, string, *http.Header, io.Reader, interface{}) (*http.Response, error) Put(context.Context, string, *http.Header, io.Reader) (*http.Response, error) PutBody(context.Context, string, *http.Header, io.Reader) (*http.Response, []byte, error) PutJSON(context.Context, string, *http.Header, io.Reader, interface{}) (*http.Response, error) }
HTTPClient is the interface of an http client
type Message ¶
type Message struct { Content string `json:"content"` Tts bool `json:"tts"` ReplyTo MessageReference `json:"message_reference,omitempty"` }
Message is the json object that is sent to the discord api to post a plain-text message to a server
func (Message) MarshalToJSON ¶
type MessageReference ¶
type MessageResponse ¶
type MessageResponse struct { ID string `json:"id"` ChannelID string `json:"channel_id"` GuildID string `json:"guild_id"` Author UserResponse `json:"author"` Member GuildMemberResponse `json:"member"` Content string `json:"content"` Timestamp string `json:"timestamp"` // ISO8601 EditedTimestamp string `json:"edited_timestamp"` // ISO8601 TTS bool `json:"tts"` MentionEveryone bool `json:"mention_everyone"` Mentions []UserResponse `json:"mentions"` MentionRoles []RoleResponse `json:"mention_roles"` MentionChannels []ChannelMentionResponse `json:"mention_channels"` Attachments []AttachmentResponse `json:"attachments"` Embeds []EmbedResponse `json:"embeds"` Reactions []ReactionResponse `json:"reactions"` Pinned bool `json:"pinned"` WebhookID string `json:"webhook_id"` Type int `json:"type"` Flags int `json:"flags"` IDSnowflake snowflake.Snowflake ChannelIDSnowflake snowflake.Snowflake GuildIDSnowflake snowflake.Snowflake WebhookIDSnowflake snowflake.Snowflake }
MessageResponse is the data that is received back from the discord api
func (*MessageResponse) Snowflakify ¶
func (mr *MessageResponse) Snowflakify() error
type MessageWithEmbed ¶
type MessageWithEmbed struct { Content string `json:"content"` Tts bool `json:"tts"` Embed Embed `json:"embed"` ReplyTo MessageReference `json:"message_reference,omitempty"` }
MessageWithEmbed is the json object that is sent to the discord api to post an embed message to a server
func (MessageWithEmbed) MarshalToJSON ¶
func (m MessageWithEmbed) MarshalToJSON() ([]byte, error)
type ReactionResponse ¶
type ReactionResponse struct { Count int `json:"count"` Me bool `json:"me"` Emoji EmojiResponse `json:"emoji"` }
ReactionResponse is the data about a reaction received from the json api
func (*ReactionResponse) Snowflakify ¶
func (rr *ReactionResponse) Snowflakify() error
type RoleResponse ¶
type RoleResponse struct { ID string `json:"id"` Name string `json:"name"` Color int `json:"color"` Hoist bool `json:"hoist"` Position int `json:"position"` Permissions int `json:"permissions"` Managed bool `json:"managed"` Mentionable bool `json:"mentionable"` IDSnowflake snowflake.Snowflake }
RoleResponse is the data about a role recevied from the json api
func (*RoleResponse) Snowflakify ¶
func (rr *RoleResponse) Snowflakify() error
type UserResponse ¶
type UserResponse struct { ID string `json:"id"` Username string `json:"username"` Discriminator string `json:"discriminator"` Avatar string `json:"avatar"` Bot bool `json:"bot"` System bool `json:"system"` MFAEnabled bool `json:"mfa_enabled"` Locale string `json:"locale"` Verified bool `json:"verified"` Email string `json:"email"` Flags int `json:"flags"` PremiumType int `json:"premium_type"` PublicFlags int `json:"public_flags"` Member *GuildMemberResponse `json:"member"` IDSnowflake snowflake.Snowflake }
UserResponse is the data about a user recevied from the json api
func (*UserResponse) Snowflakify ¶
func (ur *UserResponse) Snowflakify() error