Documentation ¶
Index ¶
- Constants
- Variables
- type AppHomeOpenedEvent
- type AppMentionEvent
- type AppUninstalledEvent
- type ChallengeResponse
- type ChannelCreatedEvent
- type ChannelCreatedInfo
- type Comment
- type Config
- type Edited
- type EmojiChangedEvent
- type EventsAPIAppRateLimited
- type EventsAPICallbackEvent
- type EventsAPIEvent
- type EventsAPIInnerEvent
- type EventsAPIURLVerificationEvent
- type File
- type GridMigrationFinishedEvent
- type GridMigrationStartedEvent
- type Icon
- type Item
- type ItemMessage
- type JSONTime
- type LinkSharedEvent
- type MemberJoinedChannelEvent
- type MemberLeftChannelEvent
- type MessageAction
- type MessageActionEntity
- type MessageActionResponse
- type MessageEvent
- type Option
- type PinAddedEvent
- type PinRemovedEvent
- type ReactionAddedEvent
- type ReactionRemovedEvent
- type TokenComparator
- type TokensRevokedEvent
Constants ¶
const ( // AppMention is an Events API subscribable event AppMention = "app_mention" // AppHomeOpened Your Slack app home was opened AppHomeOpened = "app_home_opened" // AppUninstalled Your Slack app was uninstalled. AppUninstalled = "app_uninstalled" // ChannelCreated is sent when a new channel is created. ChannelCreated = "channel_created" // GridMigrationFinished An enterprise grid migration has finished on this workspace. GridMigrationFinished = "grid_migration_finished" // GridMigrationStarted An enterprise grid migration has started on this workspace. GridMigrationStarted = "grid_migration_started" LinkShared = "link_shared" // Message A message was posted to a channel, private channel (group), im, or mim Message = "message" // Member Joined Channel MemberJoinedChannel = "member_joined_channel" // Member Left Channel MemberLeftChannel = "member_left_channel" // PinAdded An item was pinned to a channel PinAdded = "pin_added" // PinRemoved An item was unpinned from a channel PinRemoved = "pin_removed" // ReactionAdded An reaction was added to a message ReactionAdded = "reaction_added" // ReactionRemoved An reaction was removed from a message ReactionRemoved = "reaction_removed" // TokensRevoked APP's API tokes are revoked TokensRevoked = "tokens_revoked" // EmojiChanged A custom emoji has been added or changed EmojiChanged = "emoji_changed" )
const ( // CallbackEvent is the "outer" event of an EventsAPI event. CallbackEvent = "event_callback" // URLVerification is an event used when configuring your EventsAPI app URLVerification = "url_verification" // AppRateLimited indicates your app's event subscriptions are being rate limited AppRateLimited = "app_rate_limited" )
Variables ¶
var EventsAPIEventMap = map[string]interface{}{ CallbackEvent: EventsAPICallbackEvent{}, URLVerification: EventsAPIURLVerificationEvent{}, AppRateLimited: EventsAPIAppRateLimited{}, }
EventsAPIEventMap maps OUTTER Event API events to their corresponding struct implementations. The structs should be instances of the unmarshalling target for the matching event type.
var EventsAPIInnerEventMapping = map[string]interface{}{ AppMention: AppMentionEvent{}, AppHomeOpened: AppHomeOpenedEvent{}, AppUninstalled: AppUninstalledEvent{}, ChannelCreated: ChannelCreatedEvent{}, GridMigrationFinished: GridMigrationFinishedEvent{}, GridMigrationStarted: GridMigrationStartedEvent{}, LinkShared: LinkSharedEvent{}, Message: MessageEvent{}, MemberJoinedChannel: MemberJoinedChannelEvent{}, MemberLeftChannel: MemberLeftChannelEvent{}, PinAdded: PinAddedEvent{}, PinRemoved: PinRemovedEvent{}, ReactionAdded: ReactionAddedEvent{}, ReactionRemoved: ReactionRemovedEvent{}, TokensRevoked: TokensRevokedEvent{}, EmojiChanged: EmojiChangedEvent{}, }
EventsAPIInnerEventMapping maps INNER Event API events to their corresponding struct implementations. The structs should be instances of the unmarshalling target for the matching event type.
Functions ¶
This section is empty.
Types ¶
type AppHomeOpenedEvent ¶ added in v0.9.1
type AppHomeOpenedEvent struct { Type string `json:"type"` User string `json:"user"` Channel string `json:"channel"` EventTimeStamp json.Number `json:"event_ts"` Tab string `json:"tab"` View slack.View `json:"view"` }
AppHomeOpenedEvent Your Slack app home was opened.
type AppMentionEvent ¶
type AppMentionEvent struct { Type string `json:"type"` User string `json:"user"` Text string `json:"text"` TimeStamp string `json:"ts"` ThreadTimeStamp string `json:"thread_ts"` Channel string `json:"channel"` EventTimeStamp json.Number `json:"event_ts"` // When Message comes from a channel that is shared between workspaces UserTeam string `json:"user_team,omitempty"` SourceTeam string `json:"source_team,omitempty"` // BotID is filled out when a bot triggers the app_mention event BotID string `json:"bot_id,omitempty"` }
AppMentionEvent is an (inner) EventsAPI subscribable event.
type AppUninstalledEvent ¶
type AppUninstalledEvent struct {
Type string `json:"type"`
}
AppUninstalledEvent Your Slack app was uninstalled.
type ChallengeResponse ¶
type ChallengeResponse struct {
Challenge string
}
ChallengeResponse is a response to a EventsAPIEvent URLVerification challenge
type ChannelCreatedEvent ¶ added in v0.9.1
type ChannelCreatedEvent struct { Type string `json:"type"` Channel ChannelCreatedInfo `json:"channel"` EventTimestamp string `json:"event_ts"` }
ChannelCreatedEvent represents the Channel created event
type ChannelCreatedInfo ¶ added in v0.9.1
type ChannelCreatedInfo struct { ID string `json:"id"` IsChannel bool `json:"is_channel"` Name string `json:"name"` Created int `json:"created"` Creator string `json:"creator"` }
ChannelCreatedInfo represents the information associated with the Channel created event
type Comment ¶
type Comment struct { ID string `json:"id,omitempty"` Created JSONTime `json:"created,omitempty"` Timestamp JSONTime `json:"timestamp,omitempty"` User string `json:"user,omitempty"` Comment string `json:"comment,omitempty"` }
Comment contains all the information relative to a comment
type EmojiChangedEvent ¶ added in v0.9.1
type EmojiChangedEvent struct { Type string `json:"type"` Subtype string `json:"subtype"` EventTimeStamp json.Number `json:"event_ts"` // filled out when custom emoji added Name string `json:"name,omitempty"` // filled out when custom emoji removed Names []string `json:"names,omitempty"` // filled out when custom emoji renamed OldName string `json:"old_name,omitempty"` NewName string `json:"new_name,omitempty"` // filled out when custom emoji added or renamed Value string `json:"value,omitempty"` }
EmojiChangedEvent is the event of custom emoji has been added or changed
type EventsAPIAppRateLimited ¶
type EventsAPIAppRateLimited struct { Type string `json:"type"` Token string `json:"token"` TeamID string `json:"team_id"` MinuteRateLimited int `json:"minute_rate_limited"` APIAppID string `json:"api_app_id"` }
EventsAPIAppRateLimited indicates your app's event subscriptions are being rate limited
type EventsAPICallbackEvent ¶
type EventsAPICallbackEvent struct { Type string `json:"type"` Token string `json:"token"` TeamID string `json:"team_id"` APIAppID string `json:"api_app_id"` InnerEvent *json.RawMessage `json:"event"` AuthedUsers []string `json:"authed_users"` AuthedTeams []string `json:"authed_teams"` EventID string `json:"event_id"` EventTime int `json:"event_time"` EventContext string `json:"event_context"` }
EventsAPICallbackEvent is the main (outer) EventsAPI event.
type EventsAPIEvent ¶
type EventsAPIEvent struct { Token string `json:"token"` TeamID string `json:"team_id"` Type string `json:"type"` APIAppID string `json:"api_app_id"` Data interface{} InnerEvent EventsAPIInnerEvent }
EventsAPIEvent is the base EventsAPIEvent
func ParseEvent ¶
func ParseEvent(rawEvent json.RawMessage, opts ...Option) (EventsAPIEvent, error)
ParseEvent parses the outter and inner events (if applicable) of an events api event returning a EventsAPIEvent type. If the event is a url_verification event, the inner event is empty.
type EventsAPIInnerEvent ¶
type EventsAPIInnerEvent struct { Type string `json:"type"` Data interface{} }
EventsAPIInnerEvent the inner event of a EventsAPI event_callback Event.
type EventsAPIURLVerificationEvent ¶
type EventsAPIURLVerificationEvent struct { Token string `json:"token"` Challenge string `json:"challenge"` Type string `json:"type"` }
EventsAPIURLVerificationEvent received when configuring a EventsAPI driven app
type File ¶
type File struct { ID string `json:"id"` Created int `json:"created"` Timestamp int `json:"timestamp"` Name string `json:"name"` Title string `json:"title"` Mimetype string `json:"mimetype"` Filetype string `json:"filetype"` PrettyType string `json:"pretty_type"` User string `json:"user"` Editable bool `json:"editable"` Size int `json:"size"` Mode string `json:"mode"` IsExternal bool `json:"is_external"` ExternalType string `json:"external_type"` IsPublic bool `json:"is_public"` DisplayAsBot bool `json:"display_as_bot"` Username string `json:"username"` URLPrivate string `json:"url_private"` URLPrivateDownload string `json:"url_private_download"` Thumb64 string `json:"thumb_64"` Thumb80 string `json:"thumb_80"` Thumb360 string `json:"thumb_360"` Thumb360W int `json:"thumb_360_w"` Thumb360H int `json:"thumb_360_h"` Thumb480 string `json:"thumb_480"` Thumb480W int `json:"thumb_480_w"` Thumb480H int `json:"thumb_480_h"` Thumb160 string `json:"thumb_160"` Thumb720 string `json:"thumb_720"` Thumb720W int `json:"thumb_720_w"` Thumb720H int `json:"thumb_720_h"` Thumb800 string `json:"thumb_800"` Thumb800W int `json:"thumb_800_w"` Thumb800H int `json:"thumb_800_h"` Thumb960 string `json:"thumb_960"` Thumb960W int `json:"thumb_960_w"` Thumb960H int `json:"thumb_960_h"` Thumb1024 string `json:"thumb_1024"` Thumb1024W int `json:"thumb_1024_w"` Thumb1024H int `json:"thumb_1024_h"` ImageExifRotation int `json:"image_exif_rotation"` OriginalW int `json:"original_w"` OriginalH int `json:"original_h"` Permalink string `json:"permalink"` PermalinkPublic string `json:"permalink_public"` }
File is a file upload
type GridMigrationFinishedEvent ¶
type GridMigrationFinishedEvent struct { Type string `json:"type"` EnterpriseID string `json:"enterprise_id"` }
GridMigrationFinishedEvent An enterprise grid migration has finished on this workspace.
type GridMigrationStartedEvent ¶
type GridMigrationStartedEvent struct { Type string `json:"type"` EnterpriseID string `json:"enterprise_id"` }
GridMigrationStartedEvent An enterprise grid migration has started on this workspace.
type Icon ¶
type Icon struct { IconURL string `json:"icon_url,omitempty"` IconEmoji string `json:"icon_emoji,omitempty"` }
Icon is used for bot messages
type Item ¶
type Item struct { Type string `json:"type"` Channel string `json:"channel,omitempty"` Message *ItemMessage `json:"message,omitempty"` File *File `json:"file,omitempty"` Comment *Comment `json:"comment,omitempty"` Timestamp string `json:"ts,omitempty"` }
Item is any type of slack message - message, file, or file comment.
type ItemMessage ¶
type ItemMessage struct { Type string `json:"type"` User string `json:"user"` Text string `json:"text"` Timestamp string `json:"ts"` PinnedTo []string `json:"pinned_to"` ReplaceOriginal bool `json:"replace_original"` DeleteOriginal bool `json:"delete_original"` }
ItemMessage is the event message
type JSONTime ¶
type JSONTime int64
JSONTime exists so that we can have a String method converting the date
type LinkSharedEvent ¶
type LinkSharedEvent struct {}
LinkSharedEvent A message was posted containing one or more links relevant to your application
type MemberJoinedChannelEvent ¶
type MemberJoinedChannelEvent struct { Type string `json:"type"` User string `json:"user"` Channel string `json:"channel"` ChannelType string `json:"channel_type"` Team string `json:"team"` Inviter string `json:"inviter"` }
MemberJoinedChannelEvent A member joined a public or private channel
type MemberLeftChannelEvent ¶ added in v0.9.1
type MemberLeftChannelEvent struct { Type string `json:"type"` User string `json:"user"` Channel string `json:"channel"` ChannelType string `json:"channel_type"` Team string `json:"team"` }
MemberLeftChannelEvent A member left a public or private channel
type MessageAction ¶
type MessageAction struct { Type string `json:"type"` Actions []slack.AttachmentAction `json:"actions"` CallbackID string `json:"callback_id"` Team MessageActionEntity `json:"team"` Channel MessageActionEntity `json:"channel"` User MessageActionEntity `json:"user"` ActionTimestamp json.Number `json:"action_ts"` MessageTimestamp json.Number `json:"message_ts"` AttachmentID json.Number `json:"attachment_id"` Token string `json:"token"` Message slack.Message `json:"message"` OriginalMessage slack.Message `json:"original_message"` ResponseURL string `json:"response_url"` TriggerID string `json:"trigger_id"` }
func ParseActionEvent ¶
func ParseActionEvent(payloadString string, opts ...Option) (MessageAction, error)
type MessageActionEntity ¶
type MessageActionResponse ¶
type MessageEvent ¶
type MessageEvent struct { // Basic Message Event - https://api.slack.com/events/message ClientMsgID string `json:"client_msg_id"` Type string `json:"type"` User string `json:"user"` Text string `json:"text"` ThreadTimeStamp string `json:"thread_ts"` TimeStamp string `json:"ts"` Channel string `json:"channel"` ChannelType string `json:"channel_type"` EventTimeStamp json.Number `json:"event_ts"` // When Message comes from a channel that is shared between workspaces UserTeam string `json:"user_team,omitempty"` SourceTeam string `json:"source_team,omitempty"` // Edited Message Message *MessageEvent `json:"message,omitempty"` PreviousMessage *MessageEvent `json:"previous_message,omitempty"` Edited *Edited `json:"edited,omitempty"` // Message Subtypes SubType string `json:"subtype,omitempty"` // bot_message (https://api.slack.com/events/message/bot_message) BotID string `json:"bot_id,omitempty"` Username string `json:"username,omitempty"` Icons *Icon `json:"icons,omitempty"` Upload bool `json:"upload"` Files []File `json:"files"` Attachments []slack.Attachment `json:"attachments,omitempty"` // Root is the message that was broadcast to the channel when the SubType is // thread_broadcast. If this is not a thread_broadcast message event, this // value is nil. Root *MessageEvent `json:"root"` }
MessageEvent occurs when a variety of types of messages has been posted. Parse ChannelType to see which if ChannelType = "group", this is a private channel message if ChannelType = "channel", this message was sent to a channel if ChannelType = "im", this is a private message if ChannelType = "mim", A message was posted in a multiparty direct message channel TODO: Improve this so that it is not required to manually parse ChannelType
func (MessageEvent) IsEdited ¶
func (e MessageEvent) IsEdited() bool
IsEdited checks if the MessageEvent is caused by an edit
type Option ¶
type Option func(cfg *Config)
func OptionNoVerifyToken ¶
func OptionNoVerifyToken() Option
OptionNoVerifyToken skips the check of the Slack verification token
func OptionVerifyToken ¶
func OptionVerifyToken(v verifier) Option
type PinAddedEvent ¶
type PinAddedEvent pinEvent
PinAddedEvent An item was pinned to a channel - https://api.slack.com/events/pin_added
type PinRemovedEvent ¶
type PinRemovedEvent pinEvent
PinRemovedEvent An item was unpinned from a channel - https://api.slack.com/events/pin_removed
type ReactionAddedEvent ¶ added in v0.9.1
type ReactionAddedEvent reactionEvent
ReactionAddedEvent An reaction was added to a message - https://api.slack.com/events/reaction_added
type ReactionRemovedEvent ¶ added in v0.9.1
type ReactionRemovedEvent reactionEvent
ReactionRemovedEvent An reaction was removed from a message - https://api.slack.com/events/reaction_removed
type TokenComparator ¶
type TokenComparator struct {
VerificationToken string
}
func (TokenComparator) Verify ¶
func (c TokenComparator) Verify(t string) bool
type TokensRevokedEvent ¶ added in v0.9.1
type TokensRevokedEvent struct { Type string `json:"type"` Tokens tokens `json:"tokens"` }
TokensRevokedEvent APP's API tokes are revoked - https://api.slack.com/events/tokens_revoked