{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}

-- | Data structures pertaining to Discord User
module Discord.Internal.Types.User where

import Data.Aeson
import Data.Text (Text)
import qualified Data.Text as T
import Discord.Internal.Types.Prelude
import Data.Time (UTCTime)

-- | Represents information about a user.
data User = User
  { User -> UserId
userId          :: UserId             -- ^ The user's id.
  , User -> Text
userName        :: T.Text             -- ^ The user's username (not unique)
  , User -> Maybe Text
userDiscrim     :: Maybe T.Text       -- ^ The user's 4-digit discord-tag.
  , User -> Maybe Text
userAvatar      :: Maybe T.Text       -- ^ The user's avatar hash.
  , User -> Bool
userIsBot       :: Bool               -- ^ User is an OAuth2 application.
  , User -> Bool
userIsWebhook   :: Bool               -- ^ User is a webhook.
  , User -> Maybe Bool
userIsSystem    :: Maybe Bool         -- ^ User is an official discord system user.
  , User -> Maybe Bool
userMfa         :: Maybe Bool         -- ^ User has two factor authentication enabled on the account.
  , User -> Maybe Text
userBanner      :: Maybe T.Text       -- ^ User's banner hash
  , User -> Maybe Int
userAccentColor :: Maybe Int          -- ^ User's banner color
  , User -> Maybe Text
userLocale      :: Maybe T.Text       -- ^ User's chosen language
  , User -> Maybe Bool
userVerified    :: Maybe Bool         -- ^ Whether the email has been verified.
  , User -> Maybe Text
userEmail       :: Maybe T.Text       -- ^ The user's email.
  , User -> Maybe Integer
userFlags       :: Maybe Integer      -- ^ The user's flags.
  , User -> Maybe Integer
userPremiumType :: Maybe Integer      -- ^ The user's premium type.
  , User -> Maybe Integer
userPublicFlags :: Maybe Integer      -- ^ The user's public flags.
  , User -> Maybe GuildMember
userMember      :: Maybe GuildMember  -- ^ Some guild member info (message create/update)
  } deriving (Int -> User -> ShowS
[User] -> ShowS
User -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [User] -> ShowS
$cshowList :: [User] -> ShowS
show :: User -> String
$cshow :: User -> String
showsPrec :: Int -> User -> ShowS
$cshowsPrec :: Int -> User -> ShowS
Show, ReadPrec [User]
ReadPrec User
Int -> ReadS User
ReadS [User]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [User]
$creadListPrec :: ReadPrec [User]
readPrec :: ReadPrec User
$creadPrec :: ReadPrec User
readList :: ReadS [User]
$creadList :: ReadS [User]
readsPrec :: Int -> ReadS User
$creadsPrec :: Int -> ReadS User
Read, User -> User -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: User -> User -> Bool
$c/= :: User -> User -> Bool
== :: User -> User -> Bool
$c== :: User -> User -> Bool
Eq, Eq User
User -> User -> Bool
User -> User -> Ordering
User -> User -> User
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: User -> User -> User
$cmin :: User -> User -> User
max :: User -> User -> User
$cmax :: User -> User -> User
>= :: User -> User -> Bool
$c>= :: User -> User -> Bool
> :: User -> User -> Bool
$c> :: User -> User -> Bool
<= :: User -> User -> Bool
$c<= :: User -> User -> Bool
< :: User -> User -> Bool
$c< :: User -> User -> Bool
compare :: User -> User -> Ordering
$ccompare :: User -> User -> Ordering
Ord)

instance FromJSON User where
  parseJSON :: Value -> Parser User
parseJSON = forall a. String -> (Object -> Parser a) -> Value -> Parser a
withObject String
"User" forall a b. (a -> b) -> a -> b
$ \Object
o ->
    UserId
-> Text
-> Maybe Text
-> Maybe Text
-> Bool
-> Bool
-> Maybe Bool
-> Maybe Bool
-> Maybe Text
-> Maybe Int
-> Maybe Text
-> Maybe Bool
-> Maybe Text
-> Maybe Integer
-> Maybe Integer
-> Maybe Integer
-> Maybe GuildMember
-> User
User forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.:  Key
"id"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.:  Key
"username"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"discriminator" -- possibly not there in the case of webhooks
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"avatar"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"bot" forall a. Parser (Maybe a) -> a -> Parser a
.!= Bool
False
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall (f :: * -> *) a. Applicative f => a -> f a
pure Bool
False -- webhook
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"system"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"mfa_enabled"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"banner"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"accent_color"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"locale"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"verified"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"email"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"flags"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"premium_type"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"public_flags"
         forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"member"

instance ToJSON User where
  toJSON :: User -> Value
toJSON User{Bool
Maybe Bool
Maybe Int
Maybe Integer
Maybe Text
Maybe GuildMember
Text
UserId
userMember :: Maybe GuildMember
userPublicFlags :: Maybe Integer
userPremiumType :: Maybe Integer
userFlags :: Maybe Integer
userEmail :: Maybe Text
userVerified :: Maybe Bool
userLocale :: Maybe Text
userAccentColor :: Maybe Int
userBanner :: Maybe Text
userMfa :: Maybe Bool
userIsSystem :: Maybe Bool
userIsWebhook :: Bool
userIsBot :: Bool
userAvatar :: Maybe Text
userDiscrim :: Maybe Text
userName :: Text
userId :: UserId
userMember :: User -> Maybe GuildMember
userPublicFlags :: User -> Maybe Integer
userPremiumType :: User -> Maybe Integer
userFlags :: User -> Maybe Integer
userEmail :: User -> Maybe Text
userVerified :: User -> Maybe Bool
userLocale :: User -> Maybe Text
userAccentColor :: User -> Maybe Int
userBanner :: User -> Maybe Text
userMfa :: User -> Maybe Bool
userIsSystem :: User -> Maybe Bool
userIsWebhook :: User -> Bool
userIsBot :: User -> Bool
userAvatar :: User -> Maybe Text
userDiscrim :: User -> Maybe Text
userName :: User -> Text
userId :: User -> UserId
..} = [Maybe Pair] -> Value
objectFromMaybes
              [ Key
"id" forall a. ToJSON a => Key -> a -> Maybe Pair
.== UserId
userId
              , Key
"username" forall a. ToJSON a => Key -> a -> Maybe Pair
.== Text
userName
              , Key
"discriminator" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Text
userDiscrim
              , Key
"avatar" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Text
userAvatar
              , Key
"bot" forall a. ToJSON a => Key -> a -> Maybe Pair
.== Bool
userIsBot
              , Key
"system" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Bool
userIsSystem
              , Key
"mfa_enabled" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Bool
userMfa
              , Key
"banner" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Text
userBanner
              , Key
"accent_color" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Int
userAccentColor
              , Key
"verified" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Bool
userVerified
              , Key
"email" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Text
userEmail
              , Key
"flags" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Integer
userFlags
              , Key
"premium_type" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Integer
userPremiumType
              , Key
"public_flags" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Integer
userPublicFlags
              , Key
"member" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Integer
userPublicFlags
              ]

-- TODO: fully update webhook structure
data Webhook = Webhook
  { Webhook -> WebhookId
webhookId :: WebhookId
  , Webhook -> Maybe WebhookToken
webhookToken :: Maybe WebhookToken
  , Webhook -> ChannelId
webhookChannelId :: ChannelId
  } deriving (Int -> Webhook -> ShowS
[Webhook] -> ShowS
Webhook -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [Webhook] -> ShowS
$cshowList :: [Webhook] -> ShowS
show :: Webhook -> String
$cshow :: Webhook -> String
showsPrec :: Int -> Webhook -> ShowS
$cshowsPrec :: Int -> Webhook -> ShowS
Show, ReadPrec [Webhook]
ReadPrec Webhook
Int -> ReadS Webhook
ReadS [Webhook]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [Webhook]
$creadListPrec :: ReadPrec [Webhook]
readPrec :: ReadPrec Webhook
$creadPrec :: ReadPrec Webhook
readList :: ReadS [Webhook]
$creadList :: ReadS [Webhook]
readsPrec :: Int -> ReadS Webhook
$creadsPrec :: Int -> ReadS Webhook
Read, Webhook -> Webhook -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Webhook -> Webhook -> Bool
$c/= :: Webhook -> Webhook -> Bool
== :: Webhook -> Webhook -> Bool
$c== :: Webhook -> Webhook -> Bool
Eq, Eq Webhook
Webhook -> Webhook -> Bool
Webhook -> Webhook -> Ordering
Webhook -> Webhook -> Webhook
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: Webhook -> Webhook -> Webhook
$cmin :: Webhook -> Webhook -> Webhook
max :: Webhook -> Webhook -> Webhook
$cmax :: Webhook -> Webhook -> Webhook
>= :: Webhook -> Webhook -> Bool
$c>= :: Webhook -> Webhook -> Bool
> :: Webhook -> Webhook -> Bool
$c> :: Webhook -> Webhook -> Bool
<= :: Webhook -> Webhook -> Bool
$c<= :: Webhook -> Webhook -> Bool
< :: Webhook -> Webhook -> Bool
$c< :: Webhook -> Webhook -> Bool
compare :: Webhook -> Webhook -> Ordering
$ccompare :: Webhook -> Webhook -> Ordering
Ord)

instance FromJSON Webhook where
  parseJSON :: Value -> Parser Webhook
parseJSON = forall a. String -> (Object -> Parser a) -> Value -> Parser a
withObject String
"Webhook" forall a b. (a -> b) -> a -> b
$ \Object
o ->
    WebhookId -> Maybe WebhookToken -> ChannelId -> Webhook
Webhook forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.:  Key
"id"
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"token"
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.:  Key
"channel_id"

-- | The connection object that the user has attached.
data ConnectionObject = ConnectionObject
  { ConnectionObject -> Text
connectionObjectId :: Text -- ^ id of the connection account
  , ConnectionObject -> Text
connectionObjectName :: Text -- ^ the username of the connection account
  , ConnectionObject -> Text
connectionObjectType :: Text -- ^ the service of the connection (twitch, youtube)
  , ConnectionObject -> Bool
connectionObjectRevoked :: Bool -- ^ whether the connection is revoked
  , ConnectionObject -> [IntegrationId]
connectionObjectIntegrations :: [IntegrationId] -- ^ List of server `IntegrationId`
  , ConnectionObject -> Bool
connectionObjectVerified :: Bool -- ^ whether the connection is verified
  , ConnectionObject -> Bool
connectionObjectFriendSyncOn :: Bool -- ^ whether friend sync is enabled for this connection
  , ConnectionObject -> Bool
connectionObjectShownInPresenceUpdates :: Bool -- ^ whether activities related to this connection will be shown in presence updates
  , ConnectionObject -> Bool
connectionObjectVisibleToOthers :: Bool -- ^ visibility of this connection
  } deriving (Int -> ConnectionObject -> ShowS
[ConnectionObject] -> ShowS
ConnectionObject -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ConnectionObject] -> ShowS
$cshowList :: [ConnectionObject] -> ShowS
show :: ConnectionObject -> String
$cshow :: ConnectionObject -> String
showsPrec :: Int -> ConnectionObject -> ShowS
$cshowsPrec :: Int -> ConnectionObject -> ShowS
Show, ReadPrec [ConnectionObject]
ReadPrec ConnectionObject
Int -> ReadS ConnectionObject
ReadS [ConnectionObject]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ConnectionObject]
$creadListPrec :: ReadPrec [ConnectionObject]
readPrec :: ReadPrec ConnectionObject
$creadPrec :: ReadPrec ConnectionObject
readList :: ReadS [ConnectionObject]
$creadList :: ReadS [ConnectionObject]
readsPrec :: Int -> ReadS ConnectionObject
$creadsPrec :: Int -> ReadS ConnectionObject
Read, ConnectionObject -> ConnectionObject -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ConnectionObject -> ConnectionObject -> Bool
$c/= :: ConnectionObject -> ConnectionObject -> Bool
== :: ConnectionObject -> ConnectionObject -> Bool
$c== :: ConnectionObject -> ConnectionObject -> Bool
Eq, Eq ConnectionObject
ConnectionObject -> ConnectionObject -> Bool
ConnectionObject -> ConnectionObject -> Ordering
ConnectionObject -> ConnectionObject -> ConnectionObject
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: ConnectionObject -> ConnectionObject -> ConnectionObject
$cmin :: ConnectionObject -> ConnectionObject -> ConnectionObject
max :: ConnectionObject -> ConnectionObject -> ConnectionObject
$cmax :: ConnectionObject -> ConnectionObject -> ConnectionObject
>= :: ConnectionObject -> ConnectionObject -> Bool
$c>= :: ConnectionObject -> ConnectionObject -> Bool
> :: ConnectionObject -> ConnectionObject -> Bool
$c> :: ConnectionObject -> ConnectionObject -> Bool
<= :: ConnectionObject -> ConnectionObject -> Bool
$c<= :: ConnectionObject -> ConnectionObject -> Bool
< :: ConnectionObject -> ConnectionObject -> Bool
$c< :: ConnectionObject -> ConnectionObject -> Bool
compare :: ConnectionObject -> ConnectionObject -> Ordering
$ccompare :: ConnectionObject -> ConnectionObject -> Ordering
Ord)

instance FromJSON ConnectionObject where
  parseJSON :: Value -> Parser ConnectionObject
parseJSON = forall a. String -> (Object -> Parser a) -> Value -> Parser a
withObject String
"ConnectionObject" forall a b. (a -> b) -> a -> b
$ \Object
o -> do
    [Object]
integrations <- Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"integrations"
    Text
-> Text
-> Text
-> Bool
-> [IntegrationId]
-> Bool
-> Bool
-> Bool
-> Bool
-> ConnectionObject
ConnectionObject forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"id"
               forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"name"
               forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"type"
               forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"revoked"
               forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
mapM (forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"id") [Object]
integrations
               forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"verified"
               forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"friend_sync"
               forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"show_activity"
               forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> ( forall a. Eq a => a -> a -> Bool
(==) (Int
1::Int) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"visibility")


-- | Representation of a guild member.
data GuildMember = GuildMember
      { GuildMember -> Maybe User
memberUser     :: Maybe User -- ^ User object - not included in message_create or update
      , GuildMember -> Maybe Text
memberNick     :: Maybe T.Text -- ^ User's guild nickname
      , GuildMember -> Maybe Text
memberAvatar   :: Maybe T.Text -- ^ User's guild avatar hash
      , GuildMember -> [RoleId]
memberRoles    :: [RoleId] -- ^ Array of role ids
      , GuildMember -> UTCTime
memberJoinedAt :: UTCTime -- ^ When the user joined the guild
      , GuildMember -> Maybe UTCTime
memberPremiumSince :: Maybe UTCTime -- ^ When the user started boosting the guild
      , GuildMember -> Bool
memberDeaf     :: Bool -- ^ Whether the user is deafened
      , GuildMember -> Bool
memberMute     :: Bool -- ^ Whether the user is muted
      , GuildMember -> Bool
memberPending     :: Bool -- ^ Whether the user has passed the guild's membership screening
      , GuildMember -> Maybe Text
memberPermissions     :: Maybe T.Text -- ^ total permissions of the member
      , GuildMember -> Maybe UTCTime
memberTimeoutEnd :: Maybe UTCTime -- ^ when the user's timeout will expire and they can communicate again
      } deriving (Int -> GuildMember -> ShowS
[GuildMember] -> ShowS
GuildMember -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GuildMember] -> ShowS
$cshowList :: [GuildMember] -> ShowS
show :: GuildMember -> String
$cshow :: GuildMember -> String
showsPrec :: Int -> GuildMember -> ShowS
$cshowsPrec :: Int -> GuildMember -> ShowS
Show, ReadPrec [GuildMember]
ReadPrec GuildMember
Int -> ReadS GuildMember
ReadS [GuildMember]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GuildMember]
$creadListPrec :: ReadPrec [GuildMember]
readPrec :: ReadPrec GuildMember
$creadPrec :: ReadPrec GuildMember
readList :: ReadS [GuildMember]
$creadList :: ReadS [GuildMember]
readsPrec :: Int -> ReadS GuildMember
$creadsPrec :: Int -> ReadS GuildMember
Read, GuildMember -> GuildMember -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GuildMember -> GuildMember -> Bool
$c/= :: GuildMember -> GuildMember -> Bool
== :: GuildMember -> GuildMember -> Bool
$c== :: GuildMember -> GuildMember -> Bool
Eq, Eq GuildMember
GuildMember -> GuildMember -> Bool
GuildMember -> GuildMember -> Ordering
GuildMember -> GuildMember -> GuildMember
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: GuildMember -> GuildMember -> GuildMember
$cmin :: GuildMember -> GuildMember -> GuildMember
max :: GuildMember -> GuildMember -> GuildMember
$cmax :: GuildMember -> GuildMember -> GuildMember
>= :: GuildMember -> GuildMember -> Bool
$c>= :: GuildMember -> GuildMember -> Bool
> :: GuildMember -> GuildMember -> Bool
$c> :: GuildMember -> GuildMember -> Bool
<= :: GuildMember -> GuildMember -> Bool
$c<= :: GuildMember -> GuildMember -> Bool
< :: GuildMember -> GuildMember -> Bool
$c< :: GuildMember -> GuildMember -> Bool
compare :: GuildMember -> GuildMember -> Ordering
$ccompare :: GuildMember -> GuildMember -> Ordering
Ord)

instance FromJSON GuildMember where
  parseJSON :: Value -> Parser GuildMember
parseJSON = forall a. String -> (Object -> Parser a) -> Value -> Parser a
withObject String
"GuildMember" forall a b. (a -> b) -> a -> b
$ \Object
o ->
    Maybe User
-> Maybe Text
-> Maybe Text
-> [RoleId]
-> UTCTime
-> Maybe UTCTime
-> Bool
-> Bool
-> Bool
-> Maybe Text
-> Maybe UTCTime
-> GuildMember
GuildMember forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"user"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"nick"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"avatar"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.:  Key
"roles"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.:  Key
"joined_at"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"premium_since"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.:  Key
"deaf"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser a
.:  Key
"mute"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"pending" forall a. Parser (Maybe a) -> a -> Parser a
.!= Bool
False
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"permissions"
                forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"communication_disabled_until"

instance ToJSON GuildMember where
  toJSON :: GuildMember -> Value
toJSON GuildMember {Bool
[RoleId]
Maybe UTCTime
Maybe Text
Maybe User
UTCTime
memberTimeoutEnd :: Maybe UTCTime
memberPermissions :: Maybe Text
memberPending :: Bool
memberMute :: Bool
memberDeaf :: Bool
memberPremiumSince :: Maybe UTCTime
memberJoinedAt :: UTCTime
memberRoles :: [RoleId]
memberAvatar :: Maybe Text
memberNick :: Maybe Text
memberUser :: Maybe User
memberTimeoutEnd :: GuildMember -> Maybe UTCTime
memberPermissions :: GuildMember -> Maybe Text
memberPending :: GuildMember -> Bool
memberMute :: GuildMember -> Bool
memberDeaf :: GuildMember -> Bool
memberPremiumSince :: GuildMember -> Maybe UTCTime
memberJoinedAt :: GuildMember -> UTCTime
memberRoles :: GuildMember -> [RoleId]
memberAvatar :: GuildMember -> Maybe Text
memberNick :: GuildMember -> Maybe Text
memberUser :: GuildMember -> Maybe User
..} = [Maybe Pair] -> Value
objectFromMaybes
      [ Key
"user" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe User
memberUser
      , Key
"nick" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Text
memberNick
      , Key
"avatar" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Text
memberAvatar
      , Key
"roles" forall a. ToJSON a => Key -> a -> Maybe Pair
.== [RoleId]
memberRoles
      , Key
"joined_at" forall a. ToJSON a => Key -> a -> Maybe Pair
.== UTCTime
memberJoinedAt
      , Key
"premium_since" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe UTCTime
memberPremiumSince
      , Key
"deaf" forall a. ToJSON a => Key -> a -> Maybe Pair
.== Bool
memberDeaf
      , Key
"mute" forall a. ToJSON a => Key -> a -> Maybe Pair
.== Bool
memberMute
      , Key
"pending" forall a. ToJSON a => Key -> a -> Maybe Pair
.== Bool
memberPending
      , Key
"permissions" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe Text
memberPermissions
      , Key
"communication_disabled_until" forall a. ToJSON a => Key -> Maybe a -> Maybe Pair
.=? Maybe UTCTime
memberTimeoutEnd
      ]