json

package
v20.0.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 22, 2021 License: MIT Imports: 15 Imported by: 2

Documentation

Index

Constants

This section is empty.

Variables

View Source
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 (d *DiscordJSONClient) CreateReaction(ctx context.Context, cid, mid snowflake.Snowflake, emoji string) (resp *http.Response, err error)

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"`
	Footer      EmbedFooter  `json:"footer,omitempty"`
}

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 {
	Text string `json:"text"`
}

EmbedFooter is a json object that represents the footer of an embed

type EmbedFooterResponse

type EmbedFooterResponse struct {
	Text         string `json:"text"`
	IconURL      string `json:"icon_url"`
	ProxyIconURL string `json:"proxy_icon_url"`
}

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

type EmbedProviderResponse struct {
	Name string `json:"name"`
	URL  string `json:"url"`
}

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"`
	Footer      EmbedFooterResponse   `json:"footer"`
	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

type GatewayResponse struct {
	URL    string `json:"url"`
	Shards int    `json:"shards"`
}

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

HTTPClient is the interface of an http client

type Logger

type Logger = interface {
	Log(keyvals ...interface{}) error
	Message(string, ...interface{})
	Err(string, error, ...interface{})
	Printf(string, ...interface{})
}

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

func (m Message) MarshalToJSON() ([]byte, error)

type MessageReference

type MessageReference struct {
	MessageID string `json:"message_id,omitempty"`
	ChannelID string `json:"channel_id,omitempty"`
	GuildID   string `json:"guild_id,omitempty"`
}

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

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL