-- | module containing all dispatch events module Calamity.Gateway.DispatchEvents where import Calamity.Internal.AesonThings import Calamity.Internal.ConstructorName import Calamity.Internal.Utils () import Calamity.Types.Model.Channel import Calamity.Types.Model.Channel.UpdatedMessage import Calamity.Types.Model.Guild.Ban import Calamity.Types.Model.Guild.Emoji import Calamity.Types.Model.Guild.Guild import Calamity.Types.Model.Guild.Member import Calamity.Types.Model.Guild.Role import Calamity.Types.Model.Guild.UnavailableGuild import Calamity.Types.Model.Presence.Presence import Calamity.Types.Model.User import Calamity.Types.Model.Voice import Calamity.Types.Snowflake import Calamity.Types.UnixTimestamp import Data.Aeson import Data.Dynamic import Data.Text.Lazy (Text) import Data.Time import Data.Typeable import Data.Vector.Unboxing (Vector) import GHC.Generics data CalamityEvent = Dispatch Int -- ^ The shard that pushed this event DispatchData -- ^ The attached data | Custom TypeRep -- ^ The name of the custom event Dynamic -- ^ The data sent to the custom event | ShutDown deriving (Show, Generic) data DispatchData = Ready !ReadyData | Resumed | ChannelCreate !Channel | ChannelUpdate !Channel | ChannelDelete !Channel | ChannelPinsUpdate !ChannelPinsUpdateData | GuildCreate !Guild | GuildUpdate !UpdatedGuild | GuildDelete !UnavailableGuild | GuildBanAdd !BanData | GuildBanRemove !BanData | GuildEmojisUpdate !GuildEmojisUpdateData | GuildIntegrationsUpdate !GuildIntegrationsUpdateData | GuildMemberAdd !Member | GuildMemberRemove !GuildMemberRemoveData | GuildMemberUpdate !GuildMemberUpdateData | GuildMembersChunk !GuildMembersChunkData | GuildRoleCreate !GuildRoleData | GuildRoleUpdate !GuildRoleData | GuildRoleDelete !GuildRoleDeleteData | InviteCreate !InviteCreateData | InviteDelete !InviteDeleteData | MessageCreate !Message !(Maybe User) | MessageUpdate !UpdatedMessage | MessageDelete !MessageDeleteData | MessageDeleteBulk !MessageDeleteBulkData | MessageReactionAdd !ReactionEvtData | MessageReactionRemove !ReactionEvtData | MessageReactionRemoveAll !MessageReactionRemoveAllData | PresenceUpdate !PresenceUpdateData | TypingStart !TypingStartData | UserUpdate !User | VoiceStateUpdate !VoiceState | VoiceServerUpdate !VoiceServerUpdateData | WebhooksUpdate !WebhooksUpdateData deriving (Show, Generic, CtorName) data ReadyData = ReadyData { v :: Integer , user :: User , guilds :: [UnavailableGuild] , sessionID :: Text } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON ReadyData data ChannelPinsUpdateData = ChannelPinsUpdateData { channelID :: Snowflake Channel , lastPinTimestamp :: Maybe UTCTime } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON ChannelPinsUpdateData data GuildEmojisUpdateData = GuildEmojisUpdateData { guildID :: Snowflake Guild , emojis :: [Emoji] } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON GuildEmojisUpdateData newtype GuildIntegrationsUpdateData = GuildIntegrationsUpdateData { guildID :: Snowflake Guild } deriving newtype (Show, Generic) deriving (FromJSON) via CalamityJSON GuildIntegrationsUpdateData data GuildMemberRemoveData = GuildMemberRemoveData { guildID :: Snowflake Guild , user :: User } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON GuildMemberRemoveData data GuildMemberUpdateData = GuildMemberUpdateData { guildID :: Snowflake Guild , roles :: Vector (Snowflake Role) , user :: User , nick :: Maybe Text } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON GuildMemberUpdateData data GuildMembersChunkData = GuildMembersChunkData { guildID :: Snowflake Guild , members :: [Member] } deriving (Show, Generic) instance FromJSON GuildMembersChunkData where parseJSON = withObject "GuildMembersChunkData" $ \v -> do guildID <- v .: "guild_id" members' <- do members' <- v .: "members" traverse (\m -> parseJSON $ Object (m <> "guild_id" .= guildID)) members' pure $ GuildMembersChunkData guildID members' data GuildRoleData = GuildRoleData { guildID :: Snowflake Guild , role :: Role } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON GuildRoleData data GuildRoleDeleteData = GuildRoleDeleteData { guildID :: Snowflake Guild , roleID :: Snowflake Role } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON GuildRoleDeleteData data InviteCreateData = InviteCreateData { channelID :: Snowflake Channel , code :: Text , createdAt :: UTCTime , guildID :: Maybe (Snowflake Guild) , inviter :: Maybe (Snowflake User) , maxAge :: Int , maxUses :: Int , targetUser :: Maybe (Snowflake User) , targetUserType :: Maybe Integer , temporary :: Bool , uses :: Integer } deriving (Show, Generic) deriving (FromJSON) via WithSpecialCases '["inviter" `ExtractFieldFrom` "id", "targetUser" `ExtractFieldFrom` "id"] InviteCreateData data InviteDeleteData = InviteDeleteData { channelID :: Snowflake Channel , guildID :: Maybe (Snowflake Guild) , code :: Text } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON InviteDeleteData data MessageDeleteData = MessageDeleteData { id :: Snowflake Message , channelID :: Snowflake Channel , guildID :: Snowflake Guild } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON MessageDeleteData data MessageDeleteBulkData = MessageDeleteBulkData { guildID :: Snowflake Guild , channelID :: Snowflake Channel , ids :: [Snowflake Message] } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON MessageDeleteBulkData data MessageReactionRemoveAllData = MessageReactionRemoveAllData { channelID :: Snowflake Channel , messageID :: Snowflake Message , guildID :: Maybe (Snowflake Guild) } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON MessageReactionRemoveAllData data PresenceUpdateData = PresenceUpdateData { userID :: Snowflake User , presence :: Presence } deriving (Show, Generic) instance FromJSON PresenceUpdateData where parseJSON = withObject "PresenceUpdate" $ \v -> do user <- (v .: "user") >>= (.: "id") presence <- parseJSON $ Object v pure $ PresenceUpdateData user presence data TypingStartData = TypingStartData { channelID :: Snowflake Channel , guildID :: Maybe (Snowflake Guild) , userID :: Snowflake User , timestamp :: UnixTimestamp } deriving (Show, Generic) deriving (FromJSON) via CalamityJSON TypingStartData newtype VoiceServerUpdateData = VoiceServerUpdateData Value deriving newtype (Show, Generic) deriving newtype (ToJSON, FromJSON) newtype WebhooksUpdateData = WebhooksUpdateData Value deriving newtype (Show, Generic) deriving newtype (ToJSON, FromJSON) data ReactionEvtData = ReactionEvtData { userID :: Snowflake User , channelID :: Snowflake Channel , messageID :: Snowflake Message , guildID :: Maybe (Snowflake Guild) , emoji :: RawEmoji } deriving (Eq, Show, Generic) deriving (ToJSON, FromJSON) via CalamityJSON ReactionEvtData deriving (HasID User) via HasIDField "userID" ReactionEvtData deriving (HasID Channel) via HasIDField "channelID" ReactionEvtData deriving (HasID Message) via HasIDField "messageID" ReactionEvtData