{-# 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.SNS.ListSMSSandboxPhoneNumbers
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Lists the calling Amazon Web Services account\'s current verified and
-- pending destination phone numbers in the SMS sandbox.
--
-- When you start using Amazon SNS to send SMS messages, your Amazon Web
-- Services account is in the /SMS sandbox/. The SMS sandbox provides a
-- safe environment for you to try Amazon SNS features without risking your
-- reputation as an SMS sender. While your Amazon Web Services account is
-- in the SMS sandbox, you can use all of the features of Amazon SNS.
-- However, you can send SMS messages only to verified destination phone
-- numbers. For more information, including how to move out of the sandbox
-- to send messages without restrictions, see
-- <https://docs.aws.amazon.com/sns/latest/dg/sns-sms-sandbox.html SMS sandbox>
-- in the /Amazon SNS Developer Guide/.
--
-- This operation returns paginated results.
module Amazonka.SNS.ListSMSSandboxPhoneNumbers
  ( -- * Creating a Request
    ListSMSSandboxPhoneNumbers (..),
    newListSMSSandboxPhoneNumbers,

    -- * Request Lenses
    listSMSSandboxPhoneNumbers_maxResults,
    listSMSSandboxPhoneNumbers_nextToken,

    -- * Destructuring the Response
    ListSMSSandboxPhoneNumbersResponse (..),
    newListSMSSandboxPhoneNumbersResponse,

    -- * Response Lenses
    listSMSSandboxPhoneNumbersResponse_nextToken,
    listSMSSandboxPhoneNumbersResponse_httpStatus,
    listSMSSandboxPhoneNumbersResponse_phoneNumbers,
  )
where

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

-- | /See:/ 'newListSMSSandboxPhoneNumbers' smart constructor.
data ListSMSSandboxPhoneNumbers = ListSMSSandboxPhoneNumbers'
  { -- | The maximum number of phone numbers to return.
    ListSMSSandboxPhoneNumbers -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
    -- | Token that the previous @ListSMSSandboxPhoneNumbersInput@ request
    -- returns.
    ListSMSSandboxPhoneNumbers -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text
  }
  deriving (ListSMSSandboxPhoneNumbers -> ListSMSSandboxPhoneNumbers -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListSMSSandboxPhoneNumbers -> ListSMSSandboxPhoneNumbers -> Bool
$c/= :: ListSMSSandboxPhoneNumbers -> ListSMSSandboxPhoneNumbers -> Bool
== :: ListSMSSandboxPhoneNumbers -> ListSMSSandboxPhoneNumbers -> Bool
$c== :: ListSMSSandboxPhoneNumbers -> ListSMSSandboxPhoneNumbers -> Bool
Prelude.Eq, ReadPrec [ListSMSSandboxPhoneNumbers]
ReadPrec ListSMSSandboxPhoneNumbers
Int -> ReadS ListSMSSandboxPhoneNumbers
ReadS [ListSMSSandboxPhoneNumbers]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListSMSSandboxPhoneNumbers]
$creadListPrec :: ReadPrec [ListSMSSandboxPhoneNumbers]
readPrec :: ReadPrec ListSMSSandboxPhoneNumbers
$creadPrec :: ReadPrec ListSMSSandboxPhoneNumbers
readList :: ReadS [ListSMSSandboxPhoneNumbers]
$creadList :: ReadS [ListSMSSandboxPhoneNumbers]
readsPrec :: Int -> ReadS ListSMSSandboxPhoneNumbers
$creadsPrec :: Int -> ReadS ListSMSSandboxPhoneNumbers
Prelude.Read, Int -> ListSMSSandboxPhoneNumbers -> ShowS
[ListSMSSandboxPhoneNumbers] -> ShowS
ListSMSSandboxPhoneNumbers -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListSMSSandboxPhoneNumbers] -> ShowS
$cshowList :: [ListSMSSandboxPhoneNumbers] -> ShowS
show :: ListSMSSandboxPhoneNumbers -> String
$cshow :: ListSMSSandboxPhoneNumbers -> String
showsPrec :: Int -> ListSMSSandboxPhoneNumbers -> ShowS
$cshowsPrec :: Int -> ListSMSSandboxPhoneNumbers -> ShowS
Prelude.Show, forall x.
Rep ListSMSSandboxPhoneNumbers x -> ListSMSSandboxPhoneNumbers
forall x.
ListSMSSandboxPhoneNumbers -> Rep ListSMSSandboxPhoneNumbers x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListSMSSandboxPhoneNumbers x -> ListSMSSandboxPhoneNumbers
$cfrom :: forall x.
ListSMSSandboxPhoneNumbers -> Rep ListSMSSandboxPhoneNumbers x
Prelude.Generic)

-- |
-- Create a value of 'ListSMSSandboxPhoneNumbers' 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:
--
-- 'maxResults', 'listSMSSandboxPhoneNumbers_maxResults' - The maximum number of phone numbers to return.
--
-- 'nextToken', 'listSMSSandboxPhoneNumbers_nextToken' - Token that the previous @ListSMSSandboxPhoneNumbersInput@ request
-- returns.
newListSMSSandboxPhoneNumbers ::
  ListSMSSandboxPhoneNumbers
newListSMSSandboxPhoneNumbers :: ListSMSSandboxPhoneNumbers
newListSMSSandboxPhoneNumbers =
  ListSMSSandboxPhoneNumbers'
    { $sel:maxResults:ListSMSSandboxPhoneNumbers' :: Maybe Natural
maxResults =
        forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListSMSSandboxPhoneNumbers' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing
    }

-- | The maximum number of phone numbers to return.
listSMSSandboxPhoneNumbers_maxResults :: Lens.Lens' ListSMSSandboxPhoneNumbers (Prelude.Maybe Prelude.Natural)
listSMSSandboxPhoneNumbers_maxResults :: Lens' ListSMSSandboxPhoneNumbers (Maybe Natural)
listSMSSandboxPhoneNumbers_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSMSSandboxPhoneNumbers' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:ListSMSSandboxPhoneNumbers' :: ListSMSSandboxPhoneNumbers -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: ListSMSSandboxPhoneNumbers
s@ListSMSSandboxPhoneNumbers' {} Maybe Natural
a -> ListSMSSandboxPhoneNumbers
s {$sel:maxResults:ListSMSSandboxPhoneNumbers' :: Maybe Natural
maxResults = Maybe Natural
a} :: ListSMSSandboxPhoneNumbers)

-- | Token that the previous @ListSMSSandboxPhoneNumbersInput@ request
-- returns.
listSMSSandboxPhoneNumbers_nextToken :: Lens.Lens' ListSMSSandboxPhoneNumbers (Prelude.Maybe Prelude.Text)
listSMSSandboxPhoneNumbers_nextToken :: Lens' ListSMSSandboxPhoneNumbers (Maybe Text)
listSMSSandboxPhoneNumbers_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSMSSandboxPhoneNumbers' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListSMSSandboxPhoneNumbers' :: ListSMSSandboxPhoneNumbers -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListSMSSandboxPhoneNumbers
s@ListSMSSandboxPhoneNumbers' {} Maybe Text
a -> ListSMSSandboxPhoneNumbers
s {$sel:nextToken:ListSMSSandboxPhoneNumbers' :: Maybe Text
nextToken = Maybe Text
a} :: ListSMSSandboxPhoneNumbers)

instance Core.AWSPager ListSMSSandboxPhoneNumbers where
  page :: ListSMSSandboxPhoneNumbers
-> AWSResponse ListSMSSandboxPhoneNumbers
-> Maybe ListSMSSandboxPhoneNumbers
page ListSMSSandboxPhoneNumbers
rq AWSResponse ListSMSSandboxPhoneNumbers
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse ListSMSSandboxPhoneNumbers
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListSMSSandboxPhoneNumbersResponse (Maybe Text)
listSMSSandboxPhoneNumbersResponse_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 ListSMSSandboxPhoneNumbers
rs
            forall s a. s -> Getting a s a -> a
Lens.^. Lens' ListSMSSandboxPhoneNumbersResponse [SMSSandboxPhoneNumber]
listSMSSandboxPhoneNumbersResponse_phoneNumbers
        ) =
        forall a. Maybe a
Prelude.Nothing
    | Bool
Prelude.otherwise =
        forall a. a -> Maybe a
Prelude.Just
          forall a b. (a -> b) -> a -> b
Prelude.$ ListSMSSandboxPhoneNumbers
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' ListSMSSandboxPhoneNumbers (Maybe Text)
listSMSSandboxPhoneNumbers_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse ListSMSSandboxPhoneNumbers
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListSMSSandboxPhoneNumbersResponse (Maybe Text)
listSMSSandboxPhoneNumbersResponse_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 ListSMSSandboxPhoneNumbers where
  type
    AWSResponse ListSMSSandboxPhoneNumbers =
      ListSMSSandboxPhoneNumbersResponse
  request :: (Service -> Service)
-> ListSMSSandboxPhoneNumbers -> Request ListSMSSandboxPhoneNumbers
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy ListSMSSandboxPhoneNumbers
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse ListSMSSandboxPhoneNumbers)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
Text
-> (Int
    -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXMLWrapper
      Text
"ListSMSSandboxPhoneNumbersResult"
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe Text
-> Int
-> [SMSSandboxPhoneNumber]
-> ListSMSSandboxPhoneNumbersResponse
ListSMSSandboxPhoneNumbersResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"NextToken")
            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))
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ( [Node]
x
                            forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"PhoneNumbers"
                            forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
                            forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"member"
                        )
      )

instance Prelude.Hashable ListSMSSandboxPhoneNumbers where
  hashWithSalt :: Int -> ListSMSSandboxPhoneNumbers -> Int
hashWithSalt Int
_salt ListSMSSandboxPhoneNumbers' {Maybe Natural
Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:nextToken:ListSMSSandboxPhoneNumbers' :: ListSMSSandboxPhoneNumbers -> Maybe Text
$sel:maxResults:ListSMSSandboxPhoneNumbers' :: ListSMSSandboxPhoneNumbers -> Maybe Natural
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
maxResults
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken

instance Prelude.NFData ListSMSSandboxPhoneNumbers where
  rnf :: ListSMSSandboxPhoneNumbers -> ()
rnf ListSMSSandboxPhoneNumbers' {Maybe Natural
Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:nextToken:ListSMSSandboxPhoneNumbers' :: ListSMSSandboxPhoneNumbers -> Maybe Text
$sel:maxResults:ListSMSSandboxPhoneNumbers' :: ListSMSSandboxPhoneNumbers -> Maybe Natural
..} =
    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

instance Data.ToHeaders ListSMSSandboxPhoneNumbers where
  toHeaders :: ListSMSSandboxPhoneNumbers -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

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

instance Data.ToQuery ListSMSSandboxPhoneNumbers where
  toQuery :: ListSMSSandboxPhoneNumbers -> QueryString
toQuery ListSMSSandboxPhoneNumbers' {Maybe Natural
Maybe Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:nextToken:ListSMSSandboxPhoneNumbers' :: ListSMSSandboxPhoneNumbers -> Maybe Text
$sel:maxResults:ListSMSSandboxPhoneNumbers' :: ListSMSSandboxPhoneNumbers -> Maybe Natural
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"ListSMSSandboxPhoneNumbers" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2010-03-31" :: Prelude.ByteString),
        ByteString
"MaxResults" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Natural
maxResults,
        ByteString
"NextToken" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
nextToken
      ]

-- | /See:/ 'newListSMSSandboxPhoneNumbersResponse' smart constructor.
data ListSMSSandboxPhoneNumbersResponse = ListSMSSandboxPhoneNumbersResponse'
  { -- | A @NextToken@ string is returned when you call the
    -- @ListSMSSandboxPhoneNumbersInput@ operation if additional pages of
    -- records are available.
    ListSMSSandboxPhoneNumbersResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    ListSMSSandboxPhoneNumbersResponse -> Int
httpStatus :: Prelude.Int,
    -- | A list of the calling account\'s pending and verified phone numbers.
    ListSMSSandboxPhoneNumbersResponse -> [SMSSandboxPhoneNumber]
phoneNumbers :: [SMSSandboxPhoneNumber]
  }
  deriving (ListSMSSandboxPhoneNumbersResponse
-> ListSMSSandboxPhoneNumbersResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListSMSSandboxPhoneNumbersResponse
-> ListSMSSandboxPhoneNumbersResponse -> Bool
$c/= :: ListSMSSandboxPhoneNumbersResponse
-> ListSMSSandboxPhoneNumbersResponse -> Bool
== :: ListSMSSandboxPhoneNumbersResponse
-> ListSMSSandboxPhoneNumbersResponse -> Bool
$c== :: ListSMSSandboxPhoneNumbersResponse
-> ListSMSSandboxPhoneNumbersResponse -> Bool
Prelude.Eq, ReadPrec [ListSMSSandboxPhoneNumbersResponse]
ReadPrec ListSMSSandboxPhoneNumbersResponse
Int -> ReadS ListSMSSandboxPhoneNumbersResponse
ReadS [ListSMSSandboxPhoneNumbersResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListSMSSandboxPhoneNumbersResponse]
$creadListPrec :: ReadPrec [ListSMSSandboxPhoneNumbersResponse]
readPrec :: ReadPrec ListSMSSandboxPhoneNumbersResponse
$creadPrec :: ReadPrec ListSMSSandboxPhoneNumbersResponse
readList :: ReadS [ListSMSSandboxPhoneNumbersResponse]
$creadList :: ReadS [ListSMSSandboxPhoneNumbersResponse]
readsPrec :: Int -> ReadS ListSMSSandboxPhoneNumbersResponse
$creadsPrec :: Int -> ReadS ListSMSSandboxPhoneNumbersResponse
Prelude.Read, Int -> ListSMSSandboxPhoneNumbersResponse -> ShowS
[ListSMSSandboxPhoneNumbersResponse] -> ShowS
ListSMSSandboxPhoneNumbersResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListSMSSandboxPhoneNumbersResponse] -> ShowS
$cshowList :: [ListSMSSandboxPhoneNumbersResponse] -> ShowS
show :: ListSMSSandboxPhoneNumbersResponse -> String
$cshow :: ListSMSSandboxPhoneNumbersResponse -> String
showsPrec :: Int -> ListSMSSandboxPhoneNumbersResponse -> ShowS
$cshowsPrec :: Int -> ListSMSSandboxPhoneNumbersResponse -> ShowS
Prelude.Show, forall x.
Rep ListSMSSandboxPhoneNumbersResponse x
-> ListSMSSandboxPhoneNumbersResponse
forall x.
ListSMSSandboxPhoneNumbersResponse
-> Rep ListSMSSandboxPhoneNumbersResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListSMSSandboxPhoneNumbersResponse x
-> ListSMSSandboxPhoneNumbersResponse
$cfrom :: forall x.
ListSMSSandboxPhoneNumbersResponse
-> Rep ListSMSSandboxPhoneNumbersResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListSMSSandboxPhoneNumbersResponse' 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', 'listSMSSandboxPhoneNumbersResponse_nextToken' - A @NextToken@ string is returned when you call the
-- @ListSMSSandboxPhoneNumbersInput@ operation if additional pages of
-- records are available.
--
-- 'httpStatus', 'listSMSSandboxPhoneNumbersResponse_httpStatus' - The response's http status code.
--
-- 'phoneNumbers', 'listSMSSandboxPhoneNumbersResponse_phoneNumbers' - A list of the calling account\'s pending and verified phone numbers.
newListSMSSandboxPhoneNumbersResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  ListSMSSandboxPhoneNumbersResponse
newListSMSSandboxPhoneNumbersResponse :: Int -> ListSMSSandboxPhoneNumbersResponse
newListSMSSandboxPhoneNumbersResponse Int
pHttpStatus_ =
  ListSMSSandboxPhoneNumbersResponse'
    { $sel:nextToken:ListSMSSandboxPhoneNumbersResponse' :: Maybe Text
nextToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:ListSMSSandboxPhoneNumbersResponse' :: Int
httpStatus = Int
pHttpStatus_,
      $sel:phoneNumbers:ListSMSSandboxPhoneNumbersResponse' :: [SMSSandboxPhoneNumber]
phoneNumbers = forall a. Monoid a => a
Prelude.mempty
    }

-- | A @NextToken@ string is returned when you call the
-- @ListSMSSandboxPhoneNumbersInput@ operation if additional pages of
-- records are available.
listSMSSandboxPhoneNumbersResponse_nextToken :: Lens.Lens' ListSMSSandboxPhoneNumbersResponse (Prelude.Maybe Prelude.Text)
listSMSSandboxPhoneNumbersResponse_nextToken :: Lens' ListSMSSandboxPhoneNumbersResponse (Maybe Text)
listSMSSandboxPhoneNumbersResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSMSSandboxPhoneNumbersResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListSMSSandboxPhoneNumbersResponse' :: ListSMSSandboxPhoneNumbersResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListSMSSandboxPhoneNumbersResponse
s@ListSMSSandboxPhoneNumbersResponse' {} Maybe Text
a -> ListSMSSandboxPhoneNumbersResponse
s {$sel:nextToken:ListSMSSandboxPhoneNumbersResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListSMSSandboxPhoneNumbersResponse)

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

-- | A list of the calling account\'s pending and verified phone numbers.
listSMSSandboxPhoneNumbersResponse_phoneNumbers :: Lens.Lens' ListSMSSandboxPhoneNumbersResponse [SMSSandboxPhoneNumber]
listSMSSandboxPhoneNumbersResponse_phoneNumbers :: Lens' ListSMSSandboxPhoneNumbersResponse [SMSSandboxPhoneNumber]
listSMSSandboxPhoneNumbersResponse_phoneNumbers = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListSMSSandboxPhoneNumbersResponse' {[SMSSandboxPhoneNumber]
phoneNumbers :: [SMSSandboxPhoneNumber]
$sel:phoneNumbers:ListSMSSandboxPhoneNumbersResponse' :: ListSMSSandboxPhoneNumbersResponse -> [SMSSandboxPhoneNumber]
phoneNumbers} -> [SMSSandboxPhoneNumber]
phoneNumbers) (\s :: ListSMSSandboxPhoneNumbersResponse
s@ListSMSSandboxPhoneNumbersResponse' {} [SMSSandboxPhoneNumber]
a -> ListSMSSandboxPhoneNumbersResponse
s {$sel:phoneNumbers:ListSMSSandboxPhoneNumbersResponse' :: [SMSSandboxPhoneNumber]
phoneNumbers = [SMSSandboxPhoneNumber]
a} :: ListSMSSandboxPhoneNumbersResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

instance
  Prelude.NFData
    ListSMSSandboxPhoneNumbersResponse
  where
  rnf :: ListSMSSandboxPhoneNumbersResponse -> ()
rnf ListSMSSandboxPhoneNumbersResponse' {Int
[SMSSandboxPhoneNumber]
Maybe Text
phoneNumbers :: [SMSSandboxPhoneNumber]
httpStatus :: Int
nextToken :: Maybe Text
$sel:phoneNumbers:ListSMSSandboxPhoneNumbersResponse' :: ListSMSSandboxPhoneNumbersResponse -> [SMSSandboxPhoneNumber]
$sel:httpStatus:ListSMSSandboxPhoneNumbersResponse' :: ListSMSSandboxPhoneNumbersResponse -> Int
$sel:nextToken:ListSMSSandboxPhoneNumbersResponse' :: ListSMSSandboxPhoneNumbersResponse -> 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 Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [SMSSandboxPhoneNumber]
phoneNumbers