{-# 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.PinpointSmsVoiceV2.DescribeSenderIds
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Describes the specified SenderIds or all SenderIds associated with your
-- Amazon Web Services account.
--
-- If you specify SenderIds, the output includes information for only the
-- specified SenderIds. If you specify filters, the output includes
-- information for only those SenderIds that meet the filter criteria. If
-- you don\'t specify SenderIds or filters, the output includes information
-- for all SenderIds.
--
-- f you specify a sender ID that isn\'t valid, an Error is returned.
--
-- This operation returns paginated results.
module Amazonka.PinpointSmsVoiceV2.DescribeSenderIds
  ( -- * Creating a Request
    DescribeSenderIds (..),
    newDescribeSenderIds,

    -- * Request Lenses
    describeSenderIds_filters,
    describeSenderIds_maxResults,
    describeSenderIds_nextToken,
    describeSenderIds_senderIds,

    -- * Destructuring the Response
    DescribeSenderIdsResponse (..),
    newDescribeSenderIdsResponse,

    -- * Response Lenses
    describeSenderIdsResponse_nextToken,
    describeSenderIdsResponse_senderIds,
    describeSenderIdsResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.PinpointSmsVoiceV2.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newDescribeSenderIds' smart constructor.
data DescribeSenderIds = DescribeSenderIds'
  { -- | An array of SenderIdFilter objects to filter the results.
    DescribeSenderIds -> Maybe [SenderIdFilter]
filters :: Prelude.Maybe [SenderIdFilter],
    -- | The maximum number of results to return per each request.
    DescribeSenderIds -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
    -- | The token to be used for the next set of paginated results. You don\'t
    -- need to supply a value for this field in the initial request.
    DescribeSenderIds -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | An array of SenderIdAndCountry objects to search for.
    DescribeSenderIds -> Maybe [SenderIdAndCountry]
senderIds :: Prelude.Maybe [SenderIdAndCountry]
  }
  deriving (DescribeSenderIds -> DescribeSenderIds -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeSenderIds -> DescribeSenderIds -> Bool
$c/= :: DescribeSenderIds -> DescribeSenderIds -> Bool
== :: DescribeSenderIds -> DescribeSenderIds -> Bool
$c== :: DescribeSenderIds -> DescribeSenderIds -> Bool
Prelude.Eq, ReadPrec [DescribeSenderIds]
ReadPrec DescribeSenderIds
Int -> ReadS DescribeSenderIds
ReadS [DescribeSenderIds]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeSenderIds]
$creadListPrec :: ReadPrec [DescribeSenderIds]
readPrec :: ReadPrec DescribeSenderIds
$creadPrec :: ReadPrec DescribeSenderIds
readList :: ReadS [DescribeSenderIds]
$creadList :: ReadS [DescribeSenderIds]
readsPrec :: Int -> ReadS DescribeSenderIds
$creadsPrec :: Int -> ReadS DescribeSenderIds
Prelude.Read, Int -> DescribeSenderIds -> ShowS
[DescribeSenderIds] -> ShowS
DescribeSenderIds -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeSenderIds] -> ShowS
$cshowList :: [DescribeSenderIds] -> ShowS
show :: DescribeSenderIds -> String
$cshow :: DescribeSenderIds -> String
showsPrec :: Int -> DescribeSenderIds -> ShowS
$cshowsPrec :: Int -> DescribeSenderIds -> ShowS
Prelude.Show, forall x. Rep DescribeSenderIds x -> DescribeSenderIds
forall x. DescribeSenderIds -> Rep DescribeSenderIds x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeSenderIds x -> DescribeSenderIds
$cfrom :: forall x. DescribeSenderIds -> Rep DescribeSenderIds x
Prelude.Generic)

-- |
-- Create a value of 'DescribeSenderIds' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'filters', 'describeSenderIds_filters' - An array of SenderIdFilter objects to filter the results.
--
-- 'maxResults', 'describeSenderIds_maxResults' - The maximum number of results to return per each request.
--
-- 'nextToken', 'describeSenderIds_nextToken' - The token to be used for the next set of paginated results. You don\'t
-- need to supply a value for this field in the initial request.
--
-- 'senderIds', 'describeSenderIds_senderIds' - An array of SenderIdAndCountry objects to search for.
newDescribeSenderIds ::
  DescribeSenderIds
newDescribeSenderIds :: DescribeSenderIds
newDescribeSenderIds =
  DescribeSenderIds'
    { $sel:filters:DescribeSenderIds' :: Maybe [SenderIdFilter]
filters = forall a. Maybe a
Prelude.Nothing,
      $sel:maxResults:DescribeSenderIds' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:DescribeSenderIds' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:senderIds:DescribeSenderIds' :: Maybe [SenderIdAndCountry]
senderIds = forall a. Maybe a
Prelude.Nothing
    }

-- | An array of SenderIdFilter objects to filter the results.
describeSenderIds_filters :: Lens.Lens' DescribeSenderIds (Prelude.Maybe [SenderIdFilter])
describeSenderIds_filters :: Lens' DescribeSenderIds (Maybe [SenderIdFilter])
describeSenderIds_filters = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSenderIds' {Maybe [SenderIdFilter]
filters :: Maybe [SenderIdFilter]
$sel:filters:DescribeSenderIds' :: DescribeSenderIds -> Maybe [SenderIdFilter]
filters} -> Maybe [SenderIdFilter]
filters) (\s :: DescribeSenderIds
s@DescribeSenderIds' {} Maybe [SenderIdFilter]
a -> DescribeSenderIds
s {$sel:filters:DescribeSenderIds' :: Maybe [SenderIdFilter]
filters = Maybe [SenderIdFilter]
a} :: DescribeSenderIds) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | The maximum number of results to return per each request.
describeSenderIds_maxResults :: Lens.Lens' DescribeSenderIds (Prelude.Maybe Prelude.Natural)
describeSenderIds_maxResults :: Lens' DescribeSenderIds (Maybe Natural)
describeSenderIds_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSenderIds' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:DescribeSenderIds' :: DescribeSenderIds -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: DescribeSenderIds
s@DescribeSenderIds' {} Maybe Natural
a -> DescribeSenderIds
s {$sel:maxResults:DescribeSenderIds' :: Maybe Natural
maxResults = Maybe Natural
a} :: DescribeSenderIds)

-- | The token to be used for the next set of paginated results. You don\'t
-- need to supply a value for this field in the initial request.
describeSenderIds_nextToken :: Lens.Lens' DescribeSenderIds (Prelude.Maybe Prelude.Text)
describeSenderIds_nextToken :: Lens' DescribeSenderIds (Maybe Text)
describeSenderIds_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSenderIds' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeSenderIds' :: DescribeSenderIds -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeSenderIds
s@DescribeSenderIds' {} Maybe Text
a -> DescribeSenderIds
s {$sel:nextToken:DescribeSenderIds' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeSenderIds)

-- | An array of SenderIdAndCountry objects to search for.
describeSenderIds_senderIds :: Lens.Lens' DescribeSenderIds (Prelude.Maybe [SenderIdAndCountry])
describeSenderIds_senderIds :: Lens' DescribeSenderIds (Maybe [SenderIdAndCountry])
describeSenderIds_senderIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSenderIds' {Maybe [SenderIdAndCountry]
senderIds :: Maybe [SenderIdAndCountry]
$sel:senderIds:DescribeSenderIds' :: DescribeSenderIds -> Maybe [SenderIdAndCountry]
senderIds} -> Maybe [SenderIdAndCountry]
senderIds) (\s :: DescribeSenderIds
s@DescribeSenderIds' {} Maybe [SenderIdAndCountry]
a -> DescribeSenderIds
s {$sel:senderIds:DescribeSenderIds' :: Maybe [SenderIdAndCountry]
senderIds = Maybe [SenderIdAndCountry]
a} :: DescribeSenderIds) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance Core.AWSPager DescribeSenderIds where
  page :: DescribeSenderIds
-> AWSResponse DescribeSenderIds -> Maybe DescribeSenderIds
page DescribeSenderIds
rq AWSResponse DescribeSenderIds
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribeSenderIds
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeSenderIdsResponse (Maybe Text)
describeSenderIdsResponse_nextToken
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribeSenderIds
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeSenderIdsResponse (Maybe [SenderIdInformation])
describeSenderIdsResponse_senderIds
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | Bool
Prelude.otherwise =
        forall a. a -> Maybe a
Prelude.Just
          forall a b. (a -> b) -> a -> b
Prelude.$ DescribeSenderIds
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' DescribeSenderIds (Maybe Text)
describeSenderIds_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse DescribeSenderIds
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeSenderIdsResponse (Maybe Text)
describeSenderIdsResponse_nextToken
          forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just

instance Core.AWSRequest DescribeSenderIds where
  type
    AWSResponse DescribeSenderIds =
      DescribeSenderIdsResponse
  request :: (Service -> Service)
-> DescribeSenderIds -> Request DescribeSenderIds
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 DescribeSenderIds
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeSenderIds)))
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 ->
          Maybe Text
-> Maybe [SenderIdInformation] -> Int -> DescribeSenderIdsResponse
DescribeSenderIdsResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"NextToken")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"SenderIds" forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty)
            forall (f :: * -> *) a b. Applicative f => 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))
      )

instance Prelude.Hashable DescribeSenderIds where
  hashWithSalt :: Int -> DescribeSenderIds -> Int
hashWithSalt Int
_salt DescribeSenderIds' {Maybe Natural
Maybe [SenderIdAndCountry]
Maybe [SenderIdFilter]
Maybe Text
senderIds :: Maybe [SenderIdAndCountry]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [SenderIdFilter]
$sel:senderIds:DescribeSenderIds' :: DescribeSenderIds -> Maybe [SenderIdAndCountry]
$sel:nextToken:DescribeSenderIds' :: DescribeSenderIds -> Maybe Text
$sel:maxResults:DescribeSenderIds' :: DescribeSenderIds -> Maybe Natural
$sel:filters:DescribeSenderIds' :: DescribeSenderIds -> Maybe [SenderIdFilter]
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [SenderIdFilter]
filters
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
maxResults
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [SenderIdAndCountry]
senderIds

instance Prelude.NFData DescribeSenderIds where
  rnf :: DescribeSenderIds -> ()
rnf DescribeSenderIds' {Maybe Natural
Maybe [SenderIdAndCountry]
Maybe [SenderIdFilter]
Maybe Text
senderIds :: Maybe [SenderIdAndCountry]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [SenderIdFilter]
$sel:senderIds:DescribeSenderIds' :: DescribeSenderIds -> Maybe [SenderIdAndCountry]
$sel:nextToken:DescribeSenderIds' :: DescribeSenderIds -> Maybe Text
$sel:maxResults:DescribeSenderIds' :: DescribeSenderIds -> Maybe Natural
$sel:filters:DescribeSenderIds' :: DescribeSenderIds -> Maybe [SenderIdFilter]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [SenderIdFilter]
filters
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Natural
maxResults
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [SenderIdAndCountry]
senderIds

instance Data.ToHeaders DescribeSenderIds where
  toHeaders :: DescribeSenderIds -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"PinpointSMSVoiceV2.DescribeSenderIds" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.0" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON DescribeSenderIds where
  toJSON :: DescribeSenderIds -> Value
toJSON DescribeSenderIds' {Maybe Natural
Maybe [SenderIdAndCountry]
Maybe [SenderIdFilter]
Maybe Text
senderIds :: Maybe [SenderIdAndCountry]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [SenderIdFilter]
$sel:senderIds:DescribeSenderIds' :: DescribeSenderIds -> Maybe [SenderIdAndCountry]
$sel:nextToken:DescribeSenderIds' :: DescribeSenderIds -> Maybe Text
$sel:maxResults:DescribeSenderIds' :: DescribeSenderIds -> Maybe Natural
$sel:filters:DescribeSenderIds' :: DescribeSenderIds -> Maybe [SenderIdFilter]
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"Filters" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [SenderIdFilter]
filters,
            (Key
"MaxResults" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Natural
maxResults,
            (Key
"NextToken" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
nextToken,
            (Key
"SenderIds" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [SenderIdAndCountry]
senderIds
          ]
      )

instance Data.ToPath DescribeSenderIds where
  toPath :: DescribeSenderIds -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery DescribeSenderIds where
  toQuery :: DescribeSenderIds -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newDescribeSenderIdsResponse' smart constructor.
data DescribeSenderIdsResponse = DescribeSenderIdsResponse'
  { -- | The token to be used for the next set of paginated results. If this
    -- field is empty then there are no more results.
    DescribeSenderIdsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | An array of SernderIdInformation objects that contain the details for
    -- the requested SenderIds.
    DescribeSenderIdsResponse -> Maybe [SenderIdInformation]
senderIds :: Prelude.Maybe [SenderIdInformation],
    -- | The response's http status code.
    DescribeSenderIdsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeSenderIdsResponse -> DescribeSenderIdsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeSenderIdsResponse -> DescribeSenderIdsResponse -> Bool
$c/= :: DescribeSenderIdsResponse -> DescribeSenderIdsResponse -> Bool
== :: DescribeSenderIdsResponse -> DescribeSenderIdsResponse -> Bool
$c== :: DescribeSenderIdsResponse -> DescribeSenderIdsResponse -> Bool
Prelude.Eq, ReadPrec [DescribeSenderIdsResponse]
ReadPrec DescribeSenderIdsResponse
Int -> ReadS DescribeSenderIdsResponse
ReadS [DescribeSenderIdsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeSenderIdsResponse]
$creadListPrec :: ReadPrec [DescribeSenderIdsResponse]
readPrec :: ReadPrec DescribeSenderIdsResponse
$creadPrec :: ReadPrec DescribeSenderIdsResponse
readList :: ReadS [DescribeSenderIdsResponse]
$creadList :: ReadS [DescribeSenderIdsResponse]
readsPrec :: Int -> ReadS DescribeSenderIdsResponse
$creadsPrec :: Int -> ReadS DescribeSenderIdsResponse
Prelude.Read, Int -> DescribeSenderIdsResponse -> ShowS
[DescribeSenderIdsResponse] -> ShowS
DescribeSenderIdsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeSenderIdsResponse] -> ShowS
$cshowList :: [DescribeSenderIdsResponse] -> ShowS
show :: DescribeSenderIdsResponse -> String
$cshow :: DescribeSenderIdsResponse -> String
showsPrec :: Int -> DescribeSenderIdsResponse -> ShowS
$cshowsPrec :: Int -> DescribeSenderIdsResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeSenderIdsResponse x -> DescribeSenderIdsResponse
forall x.
DescribeSenderIdsResponse -> Rep DescribeSenderIdsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeSenderIdsResponse x -> DescribeSenderIdsResponse
$cfrom :: forall x.
DescribeSenderIdsResponse -> Rep DescribeSenderIdsResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeSenderIdsResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'nextToken', 'describeSenderIdsResponse_nextToken' - The token to be used for the next set of paginated results. If this
-- field is empty then there are no more results.
--
-- 'senderIds', 'describeSenderIdsResponse_senderIds' - An array of SernderIdInformation objects that contain the details for
-- the requested SenderIds.
--
-- 'httpStatus', 'describeSenderIdsResponse_httpStatus' - The response's http status code.
newDescribeSenderIdsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeSenderIdsResponse
newDescribeSenderIdsResponse :: Int -> DescribeSenderIdsResponse
newDescribeSenderIdsResponse Int
pHttpStatus_ =
  DescribeSenderIdsResponse'
    { $sel:nextToken:DescribeSenderIdsResponse' :: Maybe Text
nextToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:senderIds:DescribeSenderIdsResponse' :: Maybe [SenderIdInformation]
senderIds = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeSenderIdsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The token to be used for the next set of paginated results. If this
-- field is empty then there are no more results.
describeSenderIdsResponse_nextToken :: Lens.Lens' DescribeSenderIdsResponse (Prelude.Maybe Prelude.Text)
describeSenderIdsResponse_nextToken :: Lens' DescribeSenderIdsResponse (Maybe Text)
describeSenderIdsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSenderIdsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeSenderIdsResponse' :: DescribeSenderIdsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeSenderIdsResponse
s@DescribeSenderIdsResponse' {} Maybe Text
a -> DescribeSenderIdsResponse
s {$sel:nextToken:DescribeSenderIdsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeSenderIdsResponse)

-- | An array of SernderIdInformation objects that contain the details for
-- the requested SenderIds.
describeSenderIdsResponse_senderIds :: Lens.Lens' DescribeSenderIdsResponse (Prelude.Maybe [SenderIdInformation])
describeSenderIdsResponse_senderIds :: Lens' DescribeSenderIdsResponse (Maybe [SenderIdInformation])
describeSenderIdsResponse_senderIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSenderIdsResponse' {Maybe [SenderIdInformation]
senderIds :: Maybe [SenderIdInformation]
$sel:senderIds:DescribeSenderIdsResponse' :: DescribeSenderIdsResponse -> Maybe [SenderIdInformation]
senderIds} -> Maybe [SenderIdInformation]
senderIds) (\s :: DescribeSenderIdsResponse
s@DescribeSenderIdsResponse' {} Maybe [SenderIdInformation]
a -> DescribeSenderIdsResponse
s {$sel:senderIds:DescribeSenderIdsResponse' :: Maybe [SenderIdInformation]
senderIds = Maybe [SenderIdInformation]
a} :: DescribeSenderIdsResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | The response's http status code.
describeSenderIdsResponse_httpStatus :: Lens.Lens' DescribeSenderIdsResponse Prelude.Int
describeSenderIdsResponse_httpStatus :: Lens' DescribeSenderIdsResponse Int
describeSenderIdsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeSenderIdsResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeSenderIdsResponse' :: DescribeSenderIdsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeSenderIdsResponse
s@DescribeSenderIdsResponse' {} Int
a -> DescribeSenderIdsResponse
s {$sel:httpStatus:DescribeSenderIdsResponse' :: Int
httpStatus = Int
a} :: DescribeSenderIdsResponse)

instance Prelude.NFData DescribeSenderIdsResponse where
  rnf :: DescribeSenderIdsResponse -> ()
rnf DescribeSenderIdsResponse' {Int
Maybe [SenderIdInformation]
Maybe Text
httpStatus :: Int
senderIds :: Maybe [SenderIdInformation]
nextToken :: Maybe Text
$sel:httpStatus:DescribeSenderIdsResponse' :: DescribeSenderIdsResponse -> Int
$sel:senderIds:DescribeSenderIdsResponse' :: DescribeSenderIdsResponse -> Maybe [SenderIdInformation]
$sel:nextToken:DescribeSenderIdsResponse' :: DescribeSenderIdsResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [SenderIdInformation]
senderIds
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus