{-# 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 #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.Pinpoint.SendUsersMessages -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Creates and sends a message to a list of users. module Amazonka.Pinpoint.SendUsersMessages ( -- * Creating a Request SendUsersMessages (..), newSendUsersMessages, -- * Request Lenses sendUsersMessages_applicationId, sendUsersMessages_sendUsersMessageRequest, -- * Destructuring the Response SendUsersMessagesResponse (..), newSendUsersMessagesResponse, -- * Response Lenses 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 -- | /See:/ 'newSendUsersMessages' smart constructor. data SendUsersMessages = SendUsersMessages' { -- | The unique identifier for the application. This identifier is displayed -- as the __Project ID__ on the Amazon Pinpoint console. applicationId :: Prelude.Text, sendUsersMessageRequest :: SendUsersMessageRequest } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SendUsersMessages' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'applicationId', 'sendUsersMessages_applicationId' - The unique identifier for the application. This identifier is displayed -- as the __Project ID__ on the Amazon Pinpoint console. -- -- 'sendUsersMessageRequest', 'sendUsersMessages_sendUsersMessageRequest' - Undocumented member. newSendUsersMessages :: -- | 'applicationId' Prelude.Text -> -- | 'sendUsersMessageRequest' SendUsersMessageRequest -> SendUsersMessages newSendUsersMessages pApplicationId_ pSendUsersMessageRequest_ = SendUsersMessages' { applicationId = pApplicationId_, sendUsersMessageRequest = pSendUsersMessageRequest_ } -- | The unique identifier for the application. This identifier is displayed -- as the __Project ID__ on the Amazon Pinpoint console. sendUsersMessages_applicationId :: Lens.Lens' SendUsersMessages Prelude.Text sendUsersMessages_applicationId = Lens.lens (\SendUsersMessages' {applicationId} -> applicationId) (\s@SendUsersMessages' {} a -> s {applicationId = a} :: SendUsersMessages) -- | Undocumented member. sendUsersMessages_sendUsersMessageRequest :: Lens.Lens' SendUsersMessages SendUsersMessageRequest sendUsersMessages_sendUsersMessageRequest = Lens.lens (\SendUsersMessages' {sendUsersMessageRequest} -> sendUsersMessageRequest) (\s@SendUsersMessages' {} a -> s {sendUsersMessageRequest = a} :: SendUsersMessages) instance Core.AWSRequest SendUsersMessages where type AWSResponse SendUsersMessages = SendUsersMessagesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> SendUsersMessagesResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (Data.eitherParseJSON x) ) instance Prelude.Hashable SendUsersMessages where hashWithSalt _salt SendUsersMessages' {..} = _salt `Prelude.hashWithSalt` applicationId `Prelude.hashWithSalt` sendUsersMessageRequest instance Prelude.NFData SendUsersMessages where rnf SendUsersMessages' {..} = Prelude.rnf applicationId `Prelude.seq` Prelude.rnf sendUsersMessageRequest instance Data.ToHeaders SendUsersMessages where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON SendUsersMessages where toJSON SendUsersMessages' {..} = Data.toJSON sendUsersMessageRequest instance Data.ToPath SendUsersMessages where toPath SendUsersMessages' {..} = Prelude.mconcat [ "/v1/apps/", Data.toBS applicationId, "/users-messages" ] instance Data.ToQuery SendUsersMessages where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newSendUsersMessagesResponse' smart constructor. data SendUsersMessagesResponse = SendUsersMessagesResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, sendUsersMessageResponse :: SendUsersMessageResponse } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SendUsersMessagesResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'httpStatus', 'sendUsersMessagesResponse_httpStatus' - The response's http status code. -- -- 'sendUsersMessageResponse', 'sendUsersMessagesResponse_sendUsersMessageResponse' - Undocumented member. newSendUsersMessagesResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'sendUsersMessageResponse' SendUsersMessageResponse -> SendUsersMessagesResponse newSendUsersMessagesResponse pHttpStatus_ pSendUsersMessageResponse_ = SendUsersMessagesResponse' { httpStatus = pHttpStatus_, sendUsersMessageResponse = pSendUsersMessageResponse_ } -- | The response's http status code. sendUsersMessagesResponse_httpStatus :: Lens.Lens' SendUsersMessagesResponse Prelude.Int sendUsersMessagesResponse_httpStatus = Lens.lens (\SendUsersMessagesResponse' {httpStatus} -> httpStatus) (\s@SendUsersMessagesResponse' {} a -> s {httpStatus = a} :: SendUsersMessagesResponse) -- | Undocumented member. sendUsersMessagesResponse_sendUsersMessageResponse :: Lens.Lens' SendUsersMessagesResponse SendUsersMessageResponse sendUsersMessagesResponse_sendUsersMessageResponse = Lens.lens (\SendUsersMessagesResponse' {sendUsersMessageResponse} -> sendUsersMessageResponse) (\s@SendUsersMessagesResponse' {} a -> s {sendUsersMessageResponse = a} :: SendUsersMessagesResponse) instance Prelude.NFData SendUsersMessagesResponse where rnf SendUsersMessagesResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf sendUsersMessageResponse