{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
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)
data User = User
{ User -> UserId
userId :: UserId
, User -> Text
userName :: T.Text
, User -> Maybe Text
userDiscrim :: Maybe T.Text
, User -> Maybe Text
userAvatar :: Maybe T.Text
, User -> Bool
userIsBot :: Bool
, User -> Bool
userIsWebhook :: Bool
, User -> Maybe Bool
userIsSystem :: Maybe Bool
, User -> Maybe Bool
userMfa :: Maybe Bool
, User -> Maybe Text
userBanner :: Maybe T.Text
, User -> Maybe Int
userAccentColor :: Maybe Int
, User -> Maybe Text
userLocale :: Maybe T.Text
, User -> Maybe Bool
userVerified :: Maybe Bool
, User -> Maybe Text
userEmail :: Maybe T.Text
, User -> Maybe Integer
userFlags :: Maybe Integer
, User -> Maybe Integer
userPremiumType :: Maybe Integer
, User -> Maybe Integer
userPublicFlags :: Maybe Integer
, User -> Maybe GuildMember
userMember :: Maybe GuildMember
} 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"
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
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
]
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"
data ConnectionObject = ConnectionObject
{ ConnectionObject -> Text
connectionObjectId :: Text
, ConnectionObject -> Text
connectionObjectName :: Text
, ConnectionObject -> Text
connectionObjectType :: Text
, ConnectionObject -> Bool
connectionObjectRevoked :: Bool
, ConnectionObject -> [IntegrationId]
connectionObjectIntegrations :: [IntegrationId]
, ConnectionObject -> Bool
connectionObjectVerified :: Bool
, ConnectionObject -> Bool
connectionObjectFriendSyncOn :: Bool
, ConnectionObject -> Bool
connectionObjectShownInPresenceUpdates :: Bool
, ConnectionObject -> Bool
connectionObjectVisibleToOthers :: Bool
} 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")
data GuildMember = GuildMember
{ GuildMember -> Maybe User
memberUser :: Maybe User
, GuildMember -> Maybe Text
memberNick :: Maybe T.Text
, GuildMember -> Maybe Text
memberAvatar :: Maybe T.Text
, GuildMember -> [RoleId]
memberRoles :: [RoleId]
, GuildMember -> UTCTime
memberJoinedAt :: UTCTime
, GuildMember -> Maybe UTCTime
memberPremiumSince :: Maybe UTCTime
, GuildMember -> Bool
memberDeaf :: Bool
, GuildMember -> Bool
memberMute :: Bool
, GuildMember -> Bool
memberPending :: Bool
, GuildMember -> Maybe Text
memberPermissions :: Maybe T.Text
, GuildMember -> Maybe UTCTime
memberTimeoutEnd :: Maybe UTCTime
} 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
]