{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.Pinpoint.SendUsersMessages
(
SendUsersMessages (..),
newSendUsersMessages,
sendUsersMessages_applicationId,
sendUsersMessages_sendUsersMessageRequest,
SendUsersMessagesResponse (..),
newSendUsersMessagesResponse,
sendUsersMessagesResponse_httpStatus,
sendUsersMessagesResponse_sendUsersMessageResponse,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.Pinpoint.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data SendUsersMessages = SendUsersMessages'
{
SendUsersMessages -> Text
applicationId :: Prelude.Text,
SendUsersMessages -> SendUsersMessageRequest
sendUsersMessageRequest :: SendUsersMessageRequest
}
deriving (SendUsersMessages -> SendUsersMessages -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: SendUsersMessages -> SendUsersMessages -> Bool
$c/= :: SendUsersMessages -> SendUsersMessages -> Bool
== :: SendUsersMessages -> SendUsersMessages -> Bool
$c== :: SendUsersMessages -> SendUsersMessages -> Bool
Prelude.Eq, ReadPrec [SendUsersMessages]
ReadPrec SendUsersMessages
Int -> ReadS SendUsersMessages
ReadS [SendUsersMessages]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [SendUsersMessages]
$creadListPrec :: ReadPrec [SendUsersMessages]
readPrec :: ReadPrec SendUsersMessages
$creadPrec :: ReadPrec SendUsersMessages
readList :: ReadS [SendUsersMessages]
$creadList :: ReadS [SendUsersMessages]
readsPrec :: Int -> ReadS SendUsersMessages
$creadsPrec :: Int -> ReadS SendUsersMessages
Prelude.Read, Int -> SendUsersMessages -> ShowS
[SendUsersMessages] -> ShowS
SendUsersMessages -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [SendUsersMessages] -> ShowS
$cshowList :: [SendUsersMessages] -> ShowS
show :: SendUsersMessages -> String
$cshow :: SendUsersMessages -> String
showsPrec :: Int -> SendUsersMessages -> ShowS
$cshowsPrec :: Int -> SendUsersMessages -> ShowS
Prelude.Show, forall x. Rep SendUsersMessages x -> SendUsersMessages
forall x. SendUsersMessages -> Rep SendUsersMessages x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep SendUsersMessages x -> SendUsersMessages
$cfrom :: forall x. SendUsersMessages -> Rep SendUsersMessages x
Prelude.Generic)
newSendUsersMessages ::
Prelude.Text ->
SendUsersMessageRequest ->
SendUsersMessages
newSendUsersMessages :: Text -> SendUsersMessageRequest -> SendUsersMessages
newSendUsersMessages
Text
pApplicationId_
SendUsersMessageRequest
pSendUsersMessageRequest_ =
SendUsersMessages'
{ $sel:applicationId:SendUsersMessages' :: Text
applicationId = Text
pApplicationId_,
$sel:sendUsersMessageRequest:SendUsersMessages' :: SendUsersMessageRequest
sendUsersMessageRequest = SendUsersMessageRequest
pSendUsersMessageRequest_
}
sendUsersMessages_applicationId :: Lens.Lens' SendUsersMessages Prelude.Text
sendUsersMessages_applicationId :: Lens' SendUsersMessages Text
sendUsersMessages_applicationId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\SendUsersMessages' {Text
applicationId :: Text
$sel:applicationId:SendUsersMessages' :: SendUsersMessages -> Text
applicationId} -> Text
applicationId) (\s :: SendUsersMessages
s@SendUsersMessages' {} Text
a -> SendUsersMessages
s {$sel:applicationId:SendUsersMessages' :: Text
applicationId = Text
a} :: SendUsersMessages)
sendUsersMessages_sendUsersMessageRequest :: Lens.Lens' SendUsersMessages SendUsersMessageRequest
sendUsersMessages_sendUsersMessageRequest :: Lens' SendUsersMessages SendUsersMessageRequest
sendUsersMessages_sendUsersMessageRequest = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\SendUsersMessages' {SendUsersMessageRequest
sendUsersMessageRequest :: SendUsersMessageRequest
$sel:sendUsersMessageRequest:SendUsersMessages' :: SendUsersMessages -> SendUsersMessageRequest
sendUsersMessageRequest} -> SendUsersMessageRequest
sendUsersMessageRequest) (\s :: SendUsersMessages
s@SendUsersMessages' {} SendUsersMessageRequest
a -> SendUsersMessages
s {$sel:sendUsersMessageRequest:SendUsersMessages' :: SendUsersMessageRequest
sendUsersMessageRequest = SendUsersMessageRequest
a} :: SendUsersMessages)
instance Core.AWSRequest SendUsersMessages where
type
AWSResponse SendUsersMessages =
SendUsersMessagesResponse
request :: (Service -> Service)
-> SendUsersMessages -> Request SendUsersMessages
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy SendUsersMessages
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse SendUsersMessages)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
( \Int
s ResponseHeaders
h Object
x ->
Int -> SendUsersMessageResponse -> SendUsersMessagesResponse
SendUsersMessagesResponse'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall a. FromJSON a => Object -> Either String a
Data.eitherParseJSON Object
x)
)
instance Prelude.Hashable SendUsersMessages where
hashWithSalt :: Int -> SendUsersMessages -> Int
hashWithSalt Int
_salt SendUsersMessages' {Text
SendUsersMessageRequest
sendUsersMessageRequest :: SendUsersMessageRequest
applicationId :: Text
$sel:sendUsersMessageRequest:SendUsersMessages' :: SendUsersMessages -> SendUsersMessageRequest
$sel:applicationId:SendUsersMessages' :: SendUsersMessages -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
applicationId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` SendUsersMessageRequest
sendUsersMessageRequest
instance Prelude.NFData SendUsersMessages where
rnf :: SendUsersMessages -> ()
rnf SendUsersMessages' {Text
SendUsersMessageRequest
sendUsersMessageRequest :: SendUsersMessageRequest
applicationId :: Text
$sel:sendUsersMessageRequest:SendUsersMessages' :: SendUsersMessages -> SendUsersMessageRequest
$sel:applicationId:SendUsersMessages' :: SendUsersMessages -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
applicationId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf SendUsersMessageRequest
sendUsersMessageRequest
instance Data.ToHeaders SendUsersMessages where
toHeaders :: SendUsersMessages -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON SendUsersMessages where
toJSON :: SendUsersMessages -> Value
toJSON SendUsersMessages' {Text
SendUsersMessageRequest
sendUsersMessageRequest :: SendUsersMessageRequest
applicationId :: Text
$sel:sendUsersMessageRequest:SendUsersMessages' :: SendUsersMessages -> SendUsersMessageRequest
$sel:applicationId:SendUsersMessages' :: SendUsersMessages -> Text
..} =
forall a. ToJSON a => a -> Value
Data.toJSON SendUsersMessageRequest
sendUsersMessageRequest
instance Data.ToPath SendUsersMessages where
toPath :: SendUsersMessages -> ByteString
toPath SendUsersMessages' {Text
SendUsersMessageRequest
sendUsersMessageRequest :: SendUsersMessageRequest
applicationId :: Text
$sel:sendUsersMessageRequest:SendUsersMessages' :: SendUsersMessages -> SendUsersMessageRequest
$sel:applicationId:SendUsersMessages' :: SendUsersMessages -> Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/v1/apps/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
applicationId,
ByteString
"/users-messages"
]
instance Data.ToQuery SendUsersMessages where
toQuery :: SendUsersMessages -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data SendUsersMessagesResponse = SendUsersMessagesResponse'
{
SendUsersMessagesResponse -> Int
httpStatus :: Prelude.Int,
SendUsersMessagesResponse -> SendUsersMessageResponse
sendUsersMessageResponse :: SendUsersMessageResponse
}
deriving (SendUsersMessagesResponse -> SendUsersMessagesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: SendUsersMessagesResponse -> SendUsersMessagesResponse -> Bool
$c/= :: SendUsersMessagesResponse -> SendUsersMessagesResponse -> Bool
== :: SendUsersMessagesResponse -> SendUsersMessagesResponse -> Bool
$c== :: SendUsersMessagesResponse -> SendUsersMessagesResponse -> Bool
Prelude.Eq, ReadPrec [SendUsersMessagesResponse]
ReadPrec SendUsersMessagesResponse
Int -> ReadS SendUsersMessagesResponse
ReadS [SendUsersMessagesResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [SendUsersMessagesResponse]
$creadListPrec :: ReadPrec [SendUsersMessagesResponse]
readPrec :: ReadPrec SendUsersMessagesResponse
$creadPrec :: ReadPrec SendUsersMessagesResponse
readList :: ReadS [SendUsersMessagesResponse]
$creadList :: ReadS [SendUsersMessagesResponse]
readsPrec :: Int -> ReadS SendUsersMessagesResponse
$creadsPrec :: Int -> ReadS SendUsersMessagesResponse
Prelude.Read, Int -> SendUsersMessagesResponse -> ShowS
[SendUsersMessagesResponse] -> ShowS
SendUsersMessagesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [SendUsersMessagesResponse] -> ShowS
$cshowList :: [SendUsersMessagesResponse] -> ShowS
show :: SendUsersMessagesResponse -> String
$cshow :: SendUsersMessagesResponse -> String
showsPrec :: Int -> SendUsersMessagesResponse -> ShowS
$cshowsPrec :: Int -> SendUsersMessagesResponse -> ShowS
Prelude.Show, forall x.
Rep SendUsersMessagesResponse x -> SendUsersMessagesResponse
forall x.
SendUsersMessagesResponse -> Rep SendUsersMessagesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep SendUsersMessagesResponse x -> SendUsersMessagesResponse
$cfrom :: forall x.
SendUsersMessagesResponse -> Rep SendUsersMessagesResponse x
Prelude.Generic)
newSendUsersMessagesResponse ::
Prelude.Int ->
SendUsersMessageResponse ->
SendUsersMessagesResponse
newSendUsersMessagesResponse :: Int -> SendUsersMessageResponse -> SendUsersMessagesResponse
newSendUsersMessagesResponse
Int
pHttpStatus_
SendUsersMessageResponse
pSendUsersMessageResponse_ =
SendUsersMessagesResponse'
{ $sel:httpStatus:SendUsersMessagesResponse' :: Int
httpStatus =
Int
pHttpStatus_,
$sel:sendUsersMessageResponse:SendUsersMessagesResponse' :: SendUsersMessageResponse
sendUsersMessageResponse =
SendUsersMessageResponse
pSendUsersMessageResponse_
}
sendUsersMessagesResponse_httpStatus :: Lens.Lens' SendUsersMessagesResponse Prelude.Int
sendUsersMessagesResponse_httpStatus :: Lens' SendUsersMessagesResponse Int
sendUsersMessagesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\SendUsersMessagesResponse' {Int
httpStatus :: Int
$sel:httpStatus:SendUsersMessagesResponse' :: SendUsersMessagesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: SendUsersMessagesResponse
s@SendUsersMessagesResponse' {} Int
a -> SendUsersMessagesResponse
s {$sel:httpStatus:SendUsersMessagesResponse' :: Int
httpStatus = Int
a} :: SendUsersMessagesResponse)
sendUsersMessagesResponse_sendUsersMessageResponse :: Lens.Lens' SendUsersMessagesResponse SendUsersMessageResponse
sendUsersMessagesResponse_sendUsersMessageResponse :: Lens' SendUsersMessagesResponse SendUsersMessageResponse
sendUsersMessagesResponse_sendUsersMessageResponse = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\SendUsersMessagesResponse' {SendUsersMessageResponse
sendUsersMessageResponse :: SendUsersMessageResponse
$sel:sendUsersMessageResponse:SendUsersMessagesResponse' :: SendUsersMessagesResponse -> SendUsersMessageResponse
sendUsersMessageResponse} -> SendUsersMessageResponse
sendUsersMessageResponse) (\s :: SendUsersMessagesResponse
s@SendUsersMessagesResponse' {} SendUsersMessageResponse
a -> SendUsersMessagesResponse
s {$sel:sendUsersMessageResponse:SendUsersMessagesResponse' :: SendUsersMessageResponse
sendUsersMessageResponse = SendUsersMessageResponse
a} :: SendUsersMessagesResponse)
instance Prelude.NFData SendUsersMessagesResponse where
rnf :: SendUsersMessagesResponse -> ()
rnf SendUsersMessagesResponse' {Int
SendUsersMessageResponse
sendUsersMessageResponse :: SendUsersMessageResponse
httpStatus :: Int
$sel:sendUsersMessageResponse:SendUsersMessagesResponse' :: SendUsersMessagesResponse -> SendUsersMessageResponse
$sel:httpStatus:SendUsersMessagesResponse' :: SendUsersMessagesResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf SendUsersMessageResponse
sendUsersMessageResponse