{-# 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.DescribePhoneNumbers
-- 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 origination phone number, or all the phone
-- numbers in your account.
--
-- If you specify phone number IDs, the output includes information for
-- only the specified phone numbers. If you specify filters, the output
-- includes information for only those phone numbers that meet the filter
-- criteria. If you don\'t specify phone number IDs or filters, the output
-- includes information for all phone numbers.
--
-- If you specify a phone number ID that isn\'t valid, an Error is
-- returned.
--
-- This operation returns paginated results.
module Amazonka.PinpointSmsVoiceV2.DescribePhoneNumbers
  ( -- * Creating a Request
    DescribePhoneNumbers (..),
    newDescribePhoneNumbers,

    -- * Request Lenses
    describePhoneNumbers_filters,
    describePhoneNumbers_maxResults,
    describePhoneNumbers_nextToken,
    describePhoneNumbers_phoneNumberIds,

    -- * Destructuring the Response
    DescribePhoneNumbersResponse (..),
    newDescribePhoneNumbersResponse,

    -- * Response Lenses
    describePhoneNumbersResponse_nextToken,
    describePhoneNumbersResponse_phoneNumbers,
    describePhoneNumbersResponse_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:/ 'newDescribePhoneNumbers' smart constructor.
data DescribePhoneNumbers = DescribePhoneNumbers'
  { -- | An array of PhoneNumberFilter objects to filter the results.
    DescribePhoneNumbers -> Maybe [PhoneNumberFilter]
filters :: Prelude.Maybe [PhoneNumberFilter],
    -- | The maximum number of results to return per each request.
    DescribePhoneNumbers -> 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.
    DescribePhoneNumbers -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The unique identifier of phone numbers to find information about. This
    -- is an array of strings that can be either the PhoneNumberId or
    -- PhoneNumberArn.
    DescribePhoneNumbers -> Maybe [Text]
phoneNumberIds :: Prelude.Maybe [Prelude.Text]
  }
  deriving (DescribePhoneNumbers -> DescribePhoneNumbers -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribePhoneNumbers -> DescribePhoneNumbers -> Bool
$c/= :: DescribePhoneNumbers -> DescribePhoneNumbers -> Bool
== :: DescribePhoneNumbers -> DescribePhoneNumbers -> Bool
$c== :: DescribePhoneNumbers -> DescribePhoneNumbers -> Bool
Prelude.Eq, ReadPrec [DescribePhoneNumbers]
ReadPrec DescribePhoneNumbers
Int -> ReadS DescribePhoneNumbers
ReadS [DescribePhoneNumbers]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribePhoneNumbers]
$creadListPrec :: ReadPrec [DescribePhoneNumbers]
readPrec :: ReadPrec DescribePhoneNumbers
$creadPrec :: ReadPrec DescribePhoneNumbers
readList :: ReadS [DescribePhoneNumbers]
$creadList :: ReadS [DescribePhoneNumbers]
readsPrec :: Int -> ReadS DescribePhoneNumbers
$creadsPrec :: Int -> ReadS DescribePhoneNumbers
Prelude.Read, Int -> DescribePhoneNumbers -> ShowS
[DescribePhoneNumbers] -> ShowS
DescribePhoneNumbers -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribePhoneNumbers] -> ShowS
$cshowList :: [DescribePhoneNumbers] -> ShowS
show :: DescribePhoneNumbers -> String
$cshow :: DescribePhoneNumbers -> String
showsPrec :: Int -> DescribePhoneNumbers -> ShowS
$cshowsPrec :: Int -> DescribePhoneNumbers -> ShowS
Prelude.Show, forall x. Rep DescribePhoneNumbers x -> DescribePhoneNumbers
forall x. DescribePhoneNumbers -> Rep DescribePhoneNumbers x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribePhoneNumbers x -> DescribePhoneNumbers
$cfrom :: forall x. DescribePhoneNumbers -> Rep DescribePhoneNumbers x
Prelude.Generic)

-- |
-- Create a value of 'DescribePhoneNumbers' 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', 'describePhoneNumbers_filters' - An array of PhoneNumberFilter objects to filter the results.
--
-- 'maxResults', 'describePhoneNumbers_maxResults' - The maximum number of results to return per each request.
--
-- 'nextToken', 'describePhoneNumbers_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.
--
-- 'phoneNumberIds', 'describePhoneNumbers_phoneNumberIds' - The unique identifier of phone numbers to find information about. This
-- is an array of strings that can be either the PhoneNumberId or
-- PhoneNumberArn.
newDescribePhoneNumbers ::
  DescribePhoneNumbers
newDescribePhoneNumbers :: DescribePhoneNumbers
newDescribePhoneNumbers =
  DescribePhoneNumbers'
    { $sel:filters:DescribePhoneNumbers' :: Maybe [PhoneNumberFilter]
filters = forall a. Maybe a
Prelude.Nothing,
      $sel:maxResults:DescribePhoneNumbers' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:DescribePhoneNumbers' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:phoneNumberIds:DescribePhoneNumbers' :: Maybe [Text]
phoneNumberIds = forall a. Maybe a
Prelude.Nothing
    }

-- | An array of PhoneNumberFilter objects to filter the results.
describePhoneNumbers_filters :: Lens.Lens' DescribePhoneNumbers (Prelude.Maybe [PhoneNumberFilter])
describePhoneNumbers_filters :: Lens' DescribePhoneNumbers (Maybe [PhoneNumberFilter])
describePhoneNumbers_filters = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribePhoneNumbers' {Maybe [PhoneNumberFilter]
filters :: Maybe [PhoneNumberFilter]
$sel:filters:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe [PhoneNumberFilter]
filters} -> Maybe [PhoneNumberFilter]
filters) (\s :: DescribePhoneNumbers
s@DescribePhoneNumbers' {} Maybe [PhoneNumberFilter]
a -> DescribePhoneNumbers
s {$sel:filters:DescribePhoneNumbers' :: Maybe [PhoneNumberFilter]
filters = Maybe [PhoneNumberFilter]
a} :: DescribePhoneNumbers) 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.
describePhoneNumbers_maxResults :: Lens.Lens' DescribePhoneNumbers (Prelude.Maybe Prelude.Natural)
describePhoneNumbers_maxResults :: Lens' DescribePhoneNumbers (Maybe Natural)
describePhoneNumbers_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribePhoneNumbers' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: DescribePhoneNumbers
s@DescribePhoneNumbers' {} Maybe Natural
a -> DescribePhoneNumbers
s {$sel:maxResults:DescribePhoneNumbers' :: Maybe Natural
maxResults = Maybe Natural
a} :: DescribePhoneNumbers)

-- | 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.
describePhoneNumbers_nextToken :: Lens.Lens' DescribePhoneNumbers (Prelude.Maybe Prelude.Text)
describePhoneNumbers_nextToken :: Lens' DescribePhoneNumbers (Maybe Text)
describePhoneNumbers_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribePhoneNumbers' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribePhoneNumbers
s@DescribePhoneNumbers' {} Maybe Text
a -> DescribePhoneNumbers
s {$sel:nextToken:DescribePhoneNumbers' :: Maybe Text
nextToken = Maybe Text
a} :: DescribePhoneNumbers)

-- | The unique identifier of phone numbers to find information about. This
-- is an array of strings that can be either the PhoneNumberId or
-- PhoneNumberArn.
describePhoneNumbers_phoneNumberIds :: Lens.Lens' DescribePhoneNumbers (Prelude.Maybe [Prelude.Text])
describePhoneNumbers_phoneNumberIds :: Lens' DescribePhoneNumbers (Maybe [Text])
describePhoneNumbers_phoneNumberIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribePhoneNumbers' {Maybe [Text]
phoneNumberIds :: Maybe [Text]
$sel:phoneNumberIds:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe [Text]
phoneNumberIds} -> Maybe [Text]
phoneNumberIds) (\s :: DescribePhoneNumbers
s@DescribePhoneNumbers' {} Maybe [Text]
a -> DescribePhoneNumbers
s {$sel:phoneNumberIds:DescribePhoneNumbers' :: Maybe [Text]
phoneNumberIds = Maybe [Text]
a} :: DescribePhoneNumbers) 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 DescribePhoneNumbers where
  page :: DescribePhoneNumbers
-> AWSResponse DescribePhoneNumbers -> Maybe DescribePhoneNumbers
page DescribePhoneNumbers
rq AWSResponse DescribePhoneNumbers
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribePhoneNumbers
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribePhoneNumbersResponse (Maybe Text)
describePhoneNumbersResponse_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 DescribePhoneNumbers
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribePhoneNumbersResponse (Maybe [PhoneNumberInformation])
describePhoneNumbersResponse_phoneNumbers
            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.$ DescribePhoneNumbers
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' DescribePhoneNumbers (Maybe Text)
describePhoneNumbers_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse DescribePhoneNumbers
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribePhoneNumbersResponse (Maybe Text)
describePhoneNumbersResponse_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 DescribePhoneNumbers where
  type
    AWSResponse DescribePhoneNumbers =
      DescribePhoneNumbersResponse
  request :: (Service -> Service)
-> DescribePhoneNumbers -> Request DescribePhoneNumbers
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 DescribePhoneNumbers
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribePhoneNumbers)))
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 [PhoneNumberInformation]
-> Int
-> DescribePhoneNumbersResponse
DescribePhoneNumbersResponse'
            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
"PhoneNumbers" 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 DescribePhoneNumbers where
  hashWithSalt :: Int -> DescribePhoneNumbers -> Int
hashWithSalt Int
_salt DescribePhoneNumbers' {Maybe Natural
Maybe [Text]
Maybe [PhoneNumberFilter]
Maybe Text
phoneNumberIds :: Maybe [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [PhoneNumberFilter]
$sel:phoneNumberIds:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe [Text]
$sel:nextToken:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe Text
$sel:maxResults:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe Natural
$sel:filters:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe [PhoneNumberFilter]
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [PhoneNumberFilter]
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 [Text]
phoneNumberIds

instance Prelude.NFData DescribePhoneNumbers where
  rnf :: DescribePhoneNumbers -> ()
rnf DescribePhoneNumbers' {Maybe Natural
Maybe [Text]
Maybe [PhoneNumberFilter]
Maybe Text
phoneNumberIds :: Maybe [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [PhoneNumberFilter]
$sel:phoneNumberIds:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe [Text]
$sel:nextToken:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe Text
$sel:maxResults:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe Natural
$sel:filters:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe [PhoneNumberFilter]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [PhoneNumberFilter]
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 [Text]
phoneNumberIds

instance Data.ToHeaders DescribePhoneNumbers where
  toHeaders :: DescribePhoneNumbers -> 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.DescribePhoneNumbers" ::
                          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 DescribePhoneNumbers where
  toJSON :: DescribePhoneNumbers -> Value
toJSON DescribePhoneNumbers' {Maybe Natural
Maybe [Text]
Maybe [PhoneNumberFilter]
Maybe Text
phoneNumberIds :: Maybe [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [PhoneNumberFilter]
$sel:phoneNumberIds:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe [Text]
$sel:nextToken:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe Text
$sel:maxResults:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe Natural
$sel:filters:DescribePhoneNumbers' :: DescribePhoneNumbers -> Maybe [PhoneNumberFilter]
..} =
    [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 [PhoneNumberFilter]
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
"PhoneNumberIds" 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]
phoneNumberIds
          ]
      )

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

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

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

-- |
-- Create a value of 'DescribePhoneNumbersResponse' 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', 'describePhoneNumbersResponse_nextToken' - The token to be used for the next set of paginated results. If this
-- field is empty then there are no more results.
--
-- 'phoneNumbers', 'describePhoneNumbersResponse_phoneNumbers' - An array of PhoneNumberInformation objects that contain the details for
-- the requested phone numbers.
--
-- 'httpStatus', 'describePhoneNumbersResponse_httpStatus' - The response's http status code.
newDescribePhoneNumbersResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribePhoneNumbersResponse
newDescribePhoneNumbersResponse :: Int -> DescribePhoneNumbersResponse
newDescribePhoneNumbersResponse Int
pHttpStatus_ =
  DescribePhoneNumbersResponse'
    { $sel:nextToken:DescribePhoneNumbersResponse' :: Maybe Text
nextToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:phoneNumbers:DescribePhoneNumbersResponse' :: Maybe [PhoneNumberInformation]
phoneNumbers = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribePhoneNumbersResponse' :: 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.
describePhoneNumbersResponse_nextToken :: Lens.Lens' DescribePhoneNumbersResponse (Prelude.Maybe Prelude.Text)
describePhoneNumbersResponse_nextToken :: Lens' DescribePhoneNumbersResponse (Maybe Text)
describePhoneNumbersResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribePhoneNumbersResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribePhoneNumbersResponse' :: DescribePhoneNumbersResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribePhoneNumbersResponse
s@DescribePhoneNumbersResponse' {} Maybe Text
a -> DescribePhoneNumbersResponse
s {$sel:nextToken:DescribePhoneNumbersResponse' :: Maybe Text
nextToken = Maybe Text
a} :: DescribePhoneNumbersResponse)

-- | An array of PhoneNumberInformation objects that contain the details for
-- the requested phone numbers.
describePhoneNumbersResponse_phoneNumbers :: Lens.Lens' DescribePhoneNumbersResponse (Prelude.Maybe [PhoneNumberInformation])
describePhoneNumbersResponse_phoneNumbers :: Lens' DescribePhoneNumbersResponse (Maybe [PhoneNumberInformation])
describePhoneNumbersResponse_phoneNumbers = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribePhoneNumbersResponse' {Maybe [PhoneNumberInformation]
phoneNumbers :: Maybe [PhoneNumberInformation]
$sel:phoneNumbers:DescribePhoneNumbersResponse' :: DescribePhoneNumbersResponse -> Maybe [PhoneNumberInformation]
phoneNumbers} -> Maybe [PhoneNumberInformation]
phoneNumbers) (\s :: DescribePhoneNumbersResponse
s@DescribePhoneNumbersResponse' {} Maybe [PhoneNumberInformation]
a -> DescribePhoneNumbersResponse
s {$sel:phoneNumbers:DescribePhoneNumbersResponse' :: Maybe [PhoneNumberInformation]
phoneNumbers = Maybe [PhoneNumberInformation]
a} :: DescribePhoneNumbersResponse) 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.
describePhoneNumbersResponse_httpStatus :: Lens.Lens' DescribePhoneNumbersResponse Prelude.Int
describePhoneNumbersResponse_httpStatus :: Lens' DescribePhoneNumbersResponse Int
describePhoneNumbersResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribePhoneNumbersResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribePhoneNumbersResponse' :: DescribePhoneNumbersResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribePhoneNumbersResponse
s@DescribePhoneNumbersResponse' {} Int
a -> DescribePhoneNumbersResponse
s {$sel:httpStatus:DescribePhoneNumbersResponse' :: Int
httpStatus = Int
a} :: DescribePhoneNumbersResponse)

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