{-# 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.EC2.DescribeAvailabilityZones
-- 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 Availability Zones, Local Zones, and Wavelength Zones that
-- are available to you. If there is an event impacting a zone, you can use
-- this request to view the state and any provided messages for that zone.
--
-- For more information about Availability Zones, Local Zones, and
-- Wavelength Zones, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html Regions and zones>
-- in the /Amazon Elastic Compute Cloud User Guide/.
module Amazonka.EC2.DescribeAvailabilityZones
  ( -- * Creating a Request
    DescribeAvailabilityZones (..),
    newDescribeAvailabilityZones,

    -- * Request Lenses
    describeAvailabilityZones_allAvailabilityZones,
    describeAvailabilityZones_dryRun,
    describeAvailabilityZones_filters,
    describeAvailabilityZones_zoneIds,
    describeAvailabilityZones_zoneNames,

    -- * Destructuring the Response
    DescribeAvailabilityZonesResponse (..),
    newDescribeAvailabilityZonesResponse,

    -- * Response Lenses
    describeAvailabilityZonesResponse_availabilityZones,
    describeAvailabilityZonesResponse_httpStatus,
  )
where

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

-- | /See:/ 'newDescribeAvailabilityZones' smart constructor.
data DescribeAvailabilityZones = DescribeAvailabilityZones'
  { -- | Include all Availability Zones, Local Zones, and Wavelength Zones
    -- regardless of your opt-in status.
    --
    -- If you do not use this parameter, the results include only the zones for
    -- the Regions where you have chosen the option to opt in.
    DescribeAvailabilityZones -> Maybe Bool
allAvailabilityZones :: Prelude.Maybe Prelude.Bool,
    -- | Checks whether you have the required permissions for the action, without
    -- actually making the request, and provides an error response. If you have
    -- the required permissions, the error response is @DryRunOperation@.
    -- Otherwise, it is @UnauthorizedOperation@.
    DescribeAvailabilityZones -> Maybe Bool
dryRun :: Prelude.Maybe Prelude.Bool,
    -- | The filters.
    --
    -- -   @group-name@ - For Availability Zones, use the Region name. For
    --     Local Zones, use the name of the group associated with the Local
    --     Zone (for example, @us-west-2-lax-1@) For Wavelength Zones, use the
    --     name of the group associated with the Wavelength Zone (for example,
    --     @us-east-1-wl1-bos-wlz-1@).
    --
    -- -   @message@ - The Zone message.
    --
    -- -   @opt-in-status@ - The opt-in status (@opted-in@, and @not-opted-in@
    --     | @opt-in-not-required@).
    --
    -- -   @parent-zoneID@ - The ID of the zone that handles some of the Local
    --     Zone and Wavelength Zone control plane operations, such as API
    --     calls.
    --
    -- -   @parent-zoneName@ - The ID of the zone that handles some of the
    --     Local Zone and Wavelength Zone control plane operations, such as API
    --     calls.
    --
    -- -   @region-name@ - The name of the Region for the Zone (for example,
    --     @us-east-1@).
    --
    -- -   @state@ - The state of the Availability Zone, the Local Zone, or the
    --     Wavelength Zone (@available@).
    --
    -- -   @zone-id@ - The ID of the Availability Zone (for example,
    --     @use1-az1@), the Local Zone (for example, @usw2-lax1-az1@), or the
    --     Wavelength Zone (for example, @us-east-1-wl1-bos-wlz-1@).
    --
    -- -   @zone-type@ - The type of zone, for example, @local-zone@.
    --
    -- -   @zone-name@ - The name of the Availability Zone (for example,
    --     @us-east-1a@), the Local Zone (for example, @us-west-2-lax-1a@), or
    --     the Wavelength Zone (for example, @us-east-1-wl1-bos-wlz-1@).
    --
    -- -   @zone-type@ - The type of zone, for example, @local-zone@.
    DescribeAvailabilityZones -> Maybe [Filter]
filters :: Prelude.Maybe [Filter],
    -- | The IDs of the Availability Zones, Local Zones, and Wavelength Zones.
    DescribeAvailabilityZones -> Maybe [Text]
zoneIds :: Prelude.Maybe [Prelude.Text],
    -- | The names of the Availability Zones, Local Zones, and Wavelength Zones.
    DescribeAvailabilityZones -> Maybe [Text]
zoneNames :: Prelude.Maybe [Prelude.Text]
  }
  deriving (DescribeAvailabilityZones -> DescribeAvailabilityZones -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeAvailabilityZones -> DescribeAvailabilityZones -> Bool
$c/= :: DescribeAvailabilityZones -> DescribeAvailabilityZones -> Bool
== :: DescribeAvailabilityZones -> DescribeAvailabilityZones -> Bool
$c== :: DescribeAvailabilityZones -> DescribeAvailabilityZones -> Bool
Prelude.Eq, ReadPrec [DescribeAvailabilityZones]
ReadPrec DescribeAvailabilityZones
Int -> ReadS DescribeAvailabilityZones
ReadS [DescribeAvailabilityZones]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeAvailabilityZones]
$creadListPrec :: ReadPrec [DescribeAvailabilityZones]
readPrec :: ReadPrec DescribeAvailabilityZones
$creadPrec :: ReadPrec DescribeAvailabilityZones
readList :: ReadS [DescribeAvailabilityZones]
$creadList :: ReadS [DescribeAvailabilityZones]
readsPrec :: Int -> ReadS DescribeAvailabilityZones
$creadsPrec :: Int -> ReadS DescribeAvailabilityZones
Prelude.Read, Int -> DescribeAvailabilityZones -> ShowS
[DescribeAvailabilityZones] -> ShowS
DescribeAvailabilityZones -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeAvailabilityZones] -> ShowS
$cshowList :: [DescribeAvailabilityZones] -> ShowS
show :: DescribeAvailabilityZones -> String
$cshow :: DescribeAvailabilityZones -> String
showsPrec :: Int -> DescribeAvailabilityZones -> ShowS
$cshowsPrec :: Int -> DescribeAvailabilityZones -> ShowS
Prelude.Show, forall x.
Rep DescribeAvailabilityZones x -> DescribeAvailabilityZones
forall x.
DescribeAvailabilityZones -> Rep DescribeAvailabilityZones x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeAvailabilityZones x -> DescribeAvailabilityZones
$cfrom :: forall x.
DescribeAvailabilityZones -> Rep DescribeAvailabilityZones x
Prelude.Generic)

-- |
-- Create a value of 'DescribeAvailabilityZones' 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:
--
-- 'allAvailabilityZones', 'describeAvailabilityZones_allAvailabilityZones' - Include all Availability Zones, Local Zones, and Wavelength Zones
-- regardless of your opt-in status.
--
-- If you do not use this parameter, the results include only the zones for
-- the Regions where you have chosen the option to opt in.
--
-- 'dryRun', 'describeAvailabilityZones_dryRun' - Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
--
-- 'filters', 'describeAvailabilityZones_filters' - The filters.
--
-- -   @group-name@ - For Availability Zones, use the Region name. For
--     Local Zones, use the name of the group associated with the Local
--     Zone (for example, @us-west-2-lax-1@) For Wavelength Zones, use the
--     name of the group associated with the Wavelength Zone (for example,
--     @us-east-1-wl1-bos-wlz-1@).
--
-- -   @message@ - The Zone message.
--
-- -   @opt-in-status@ - The opt-in status (@opted-in@, and @not-opted-in@
--     | @opt-in-not-required@).
--
-- -   @parent-zoneID@ - The ID of the zone that handles some of the Local
--     Zone and Wavelength Zone control plane operations, such as API
--     calls.
--
-- -   @parent-zoneName@ - The ID of the zone that handles some of the
--     Local Zone and Wavelength Zone control plane operations, such as API
--     calls.
--
-- -   @region-name@ - The name of the Region for the Zone (for example,
--     @us-east-1@).
--
-- -   @state@ - The state of the Availability Zone, the Local Zone, or the
--     Wavelength Zone (@available@).
--
-- -   @zone-id@ - The ID of the Availability Zone (for example,
--     @use1-az1@), the Local Zone (for example, @usw2-lax1-az1@), or the
--     Wavelength Zone (for example, @us-east-1-wl1-bos-wlz-1@).
--
-- -   @zone-type@ - The type of zone, for example, @local-zone@.
--
-- -   @zone-name@ - The name of the Availability Zone (for example,
--     @us-east-1a@), the Local Zone (for example, @us-west-2-lax-1a@), or
--     the Wavelength Zone (for example, @us-east-1-wl1-bos-wlz-1@).
--
-- -   @zone-type@ - The type of zone, for example, @local-zone@.
--
-- 'zoneIds', 'describeAvailabilityZones_zoneIds' - The IDs of the Availability Zones, Local Zones, and Wavelength Zones.
--
-- 'zoneNames', 'describeAvailabilityZones_zoneNames' - The names of the Availability Zones, Local Zones, and Wavelength Zones.
newDescribeAvailabilityZones ::
  DescribeAvailabilityZones
newDescribeAvailabilityZones :: DescribeAvailabilityZones
newDescribeAvailabilityZones =
  DescribeAvailabilityZones'
    { $sel:allAvailabilityZones:DescribeAvailabilityZones' :: Maybe Bool
allAvailabilityZones =
        forall a. Maybe a
Prelude.Nothing,
      $sel:dryRun:DescribeAvailabilityZones' :: Maybe Bool
dryRun = forall a. Maybe a
Prelude.Nothing,
      $sel:filters:DescribeAvailabilityZones' :: Maybe [Filter]
filters = forall a. Maybe a
Prelude.Nothing,
      $sel:zoneIds:DescribeAvailabilityZones' :: Maybe [Text]
zoneIds = forall a. Maybe a
Prelude.Nothing,
      $sel:zoneNames:DescribeAvailabilityZones' :: Maybe [Text]
zoneNames = forall a. Maybe a
Prelude.Nothing
    }

-- | Include all Availability Zones, Local Zones, and Wavelength Zones
-- regardless of your opt-in status.
--
-- If you do not use this parameter, the results include only the zones for
-- the Regions where you have chosen the option to opt in.
describeAvailabilityZones_allAvailabilityZones :: Lens.Lens' DescribeAvailabilityZones (Prelude.Maybe Prelude.Bool)
describeAvailabilityZones_allAvailabilityZones :: Lens' DescribeAvailabilityZones (Maybe Bool)
describeAvailabilityZones_allAvailabilityZones = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAvailabilityZones' {Maybe Bool
allAvailabilityZones :: Maybe Bool
$sel:allAvailabilityZones:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe Bool
allAvailabilityZones} -> Maybe Bool
allAvailabilityZones) (\s :: DescribeAvailabilityZones
s@DescribeAvailabilityZones' {} Maybe Bool
a -> DescribeAvailabilityZones
s {$sel:allAvailabilityZones:DescribeAvailabilityZones' :: Maybe Bool
allAvailabilityZones = Maybe Bool
a} :: DescribeAvailabilityZones)

-- | Checks whether you have the required permissions for the action, without
-- actually making the request, and provides an error response. If you have
-- the required permissions, the error response is @DryRunOperation@.
-- Otherwise, it is @UnauthorizedOperation@.
describeAvailabilityZones_dryRun :: Lens.Lens' DescribeAvailabilityZones (Prelude.Maybe Prelude.Bool)
describeAvailabilityZones_dryRun :: Lens' DescribeAvailabilityZones (Maybe Bool)
describeAvailabilityZones_dryRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAvailabilityZones' {Maybe Bool
dryRun :: Maybe Bool
$sel:dryRun:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe Bool
dryRun} -> Maybe Bool
dryRun) (\s :: DescribeAvailabilityZones
s@DescribeAvailabilityZones' {} Maybe Bool
a -> DescribeAvailabilityZones
s {$sel:dryRun:DescribeAvailabilityZones' :: Maybe Bool
dryRun = Maybe Bool
a} :: DescribeAvailabilityZones)

-- | The filters.
--
-- -   @group-name@ - For Availability Zones, use the Region name. For
--     Local Zones, use the name of the group associated with the Local
--     Zone (for example, @us-west-2-lax-1@) For Wavelength Zones, use the
--     name of the group associated with the Wavelength Zone (for example,
--     @us-east-1-wl1-bos-wlz-1@).
--
-- -   @message@ - The Zone message.
--
-- -   @opt-in-status@ - The opt-in status (@opted-in@, and @not-opted-in@
--     | @opt-in-not-required@).
--
-- -   @parent-zoneID@ - The ID of the zone that handles some of the Local
--     Zone and Wavelength Zone control plane operations, such as API
--     calls.
--
-- -   @parent-zoneName@ - The ID of the zone that handles some of the
--     Local Zone and Wavelength Zone control plane operations, such as API
--     calls.
--
-- -   @region-name@ - The name of the Region for the Zone (for example,
--     @us-east-1@).
--
-- -   @state@ - The state of the Availability Zone, the Local Zone, or the
--     Wavelength Zone (@available@).
--
-- -   @zone-id@ - The ID of the Availability Zone (for example,
--     @use1-az1@), the Local Zone (for example, @usw2-lax1-az1@), or the
--     Wavelength Zone (for example, @us-east-1-wl1-bos-wlz-1@).
--
-- -   @zone-type@ - The type of zone, for example, @local-zone@.
--
-- -   @zone-name@ - The name of the Availability Zone (for example,
--     @us-east-1a@), the Local Zone (for example, @us-west-2-lax-1a@), or
--     the Wavelength Zone (for example, @us-east-1-wl1-bos-wlz-1@).
--
-- -   @zone-type@ - The type of zone, for example, @local-zone@.
describeAvailabilityZones_filters :: Lens.Lens' DescribeAvailabilityZones (Prelude.Maybe [Filter])
describeAvailabilityZones_filters :: Lens' DescribeAvailabilityZones (Maybe [Filter])
describeAvailabilityZones_filters = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAvailabilityZones' {Maybe [Filter]
filters :: Maybe [Filter]
$sel:filters:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Filter]
filters} -> Maybe [Filter]
filters) (\s :: DescribeAvailabilityZones
s@DescribeAvailabilityZones' {} Maybe [Filter]
a -> DescribeAvailabilityZones
s {$sel:filters:DescribeAvailabilityZones' :: Maybe [Filter]
filters = Maybe [Filter]
a} :: DescribeAvailabilityZones) 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 IDs of the Availability Zones, Local Zones, and Wavelength Zones.
describeAvailabilityZones_zoneIds :: Lens.Lens' DescribeAvailabilityZones (Prelude.Maybe [Prelude.Text])
describeAvailabilityZones_zoneIds :: Lens' DescribeAvailabilityZones (Maybe [Text])
describeAvailabilityZones_zoneIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAvailabilityZones' {Maybe [Text]
zoneIds :: Maybe [Text]
$sel:zoneIds:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Text]
zoneIds} -> Maybe [Text]
zoneIds) (\s :: DescribeAvailabilityZones
s@DescribeAvailabilityZones' {} Maybe [Text]
a -> DescribeAvailabilityZones
s {$sel:zoneIds:DescribeAvailabilityZones' :: Maybe [Text]
zoneIds = Maybe [Text]
a} :: DescribeAvailabilityZones) 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 names of the Availability Zones, Local Zones, and Wavelength Zones.
describeAvailabilityZones_zoneNames :: Lens.Lens' DescribeAvailabilityZones (Prelude.Maybe [Prelude.Text])
describeAvailabilityZones_zoneNames :: Lens' DescribeAvailabilityZones (Maybe [Text])
describeAvailabilityZones_zoneNames = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAvailabilityZones' {Maybe [Text]
zoneNames :: Maybe [Text]
$sel:zoneNames:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Text]
zoneNames} -> Maybe [Text]
zoneNames) (\s :: DescribeAvailabilityZones
s@DescribeAvailabilityZones' {} Maybe [Text]
a -> DescribeAvailabilityZones
s {$sel:zoneNames:DescribeAvailabilityZones' :: Maybe [Text]
zoneNames = Maybe [Text]
a} :: DescribeAvailabilityZones) 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.AWSRequest DescribeAvailabilityZones where
  type
    AWSResponse DescribeAvailabilityZones =
      DescribeAvailabilityZonesResponse
  request :: (Service -> Service)
-> DescribeAvailabilityZones -> Request DescribeAvailabilityZones
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 DescribeAvailabilityZones
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DescribeAvailabilityZones)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe [AvailabilityZone]
-> Int -> DescribeAvailabilityZonesResponse
DescribeAvailabilityZonesResponse'
            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
"availabilityZoneInfo"
                            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 (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"item")
                        )
            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 DescribeAvailabilityZones where
  hashWithSalt :: Int -> DescribeAvailabilityZones -> Int
hashWithSalt Int
_salt DescribeAvailabilityZones' {Maybe Bool
Maybe [Text]
Maybe [Filter]
zoneNames :: Maybe [Text]
zoneIds :: Maybe [Text]
filters :: Maybe [Filter]
dryRun :: Maybe Bool
allAvailabilityZones :: Maybe Bool
$sel:zoneNames:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Text]
$sel:zoneIds:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Text]
$sel:filters:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Filter]
$sel:dryRun:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe Bool
$sel:allAvailabilityZones:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe Bool
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
allAvailabilityZones
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
dryRun
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Filter]
filters
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
zoneIds
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
zoneNames

instance Prelude.NFData DescribeAvailabilityZones where
  rnf :: DescribeAvailabilityZones -> ()
rnf DescribeAvailabilityZones' {Maybe Bool
Maybe [Text]
Maybe [Filter]
zoneNames :: Maybe [Text]
zoneIds :: Maybe [Text]
filters :: Maybe [Filter]
dryRun :: Maybe Bool
allAvailabilityZones :: Maybe Bool
$sel:zoneNames:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Text]
$sel:zoneIds:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Text]
$sel:filters:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Filter]
$sel:dryRun:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe Bool
$sel:allAvailabilityZones:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe Bool
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
allAvailabilityZones
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
dryRun
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Filter]
filters
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
zoneIds
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
zoneNames

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

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

instance Data.ToQuery DescribeAvailabilityZones where
  toQuery :: DescribeAvailabilityZones -> QueryString
toQuery DescribeAvailabilityZones' {Maybe Bool
Maybe [Text]
Maybe [Filter]
zoneNames :: Maybe [Text]
zoneIds :: Maybe [Text]
filters :: Maybe [Filter]
dryRun :: Maybe Bool
allAvailabilityZones :: Maybe Bool
$sel:zoneNames:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Text]
$sel:zoneIds:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Text]
$sel:filters:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe [Filter]
$sel:dryRun:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe Bool
$sel:allAvailabilityZones:DescribeAvailabilityZones' :: DescribeAvailabilityZones -> Maybe Bool
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"DescribeAvailabilityZones" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2016-11-15" :: Prelude.ByteString),
        ByteString
"AllAvailabilityZones" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
allAvailabilityZones,
        ByteString
"DryRun" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
dryRun,
        forall a. ToQuery a => a -> QueryString
Data.toQuery
          (forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"Filter" forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Filter]
filters),
        forall a. ToQuery a => a -> QueryString
Data.toQuery
          (forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"ZoneId" forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
zoneIds),
        forall a. ToQuery a => a -> QueryString
Data.toQuery
          (forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"ZoneName" forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
zoneNames)
      ]

-- | /See:/ 'newDescribeAvailabilityZonesResponse' smart constructor.
data DescribeAvailabilityZonesResponse = DescribeAvailabilityZonesResponse'
  { -- | Information about the Availability Zones, Local Zones, and Wavelength
    -- Zones.
    DescribeAvailabilityZonesResponse -> Maybe [AvailabilityZone]
availabilityZones :: Prelude.Maybe [AvailabilityZone],
    -- | The response's http status code.
    DescribeAvailabilityZonesResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeAvailabilityZonesResponse
-> DescribeAvailabilityZonesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeAvailabilityZonesResponse
-> DescribeAvailabilityZonesResponse -> Bool
$c/= :: DescribeAvailabilityZonesResponse
-> DescribeAvailabilityZonesResponse -> Bool
== :: DescribeAvailabilityZonesResponse
-> DescribeAvailabilityZonesResponse -> Bool
$c== :: DescribeAvailabilityZonesResponse
-> DescribeAvailabilityZonesResponse -> Bool
Prelude.Eq, ReadPrec [DescribeAvailabilityZonesResponse]
ReadPrec DescribeAvailabilityZonesResponse
Int -> ReadS DescribeAvailabilityZonesResponse
ReadS [DescribeAvailabilityZonesResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeAvailabilityZonesResponse]
$creadListPrec :: ReadPrec [DescribeAvailabilityZonesResponse]
readPrec :: ReadPrec DescribeAvailabilityZonesResponse
$creadPrec :: ReadPrec DescribeAvailabilityZonesResponse
readList :: ReadS [DescribeAvailabilityZonesResponse]
$creadList :: ReadS [DescribeAvailabilityZonesResponse]
readsPrec :: Int -> ReadS DescribeAvailabilityZonesResponse
$creadsPrec :: Int -> ReadS DescribeAvailabilityZonesResponse
Prelude.Read, Int -> DescribeAvailabilityZonesResponse -> ShowS
[DescribeAvailabilityZonesResponse] -> ShowS
DescribeAvailabilityZonesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeAvailabilityZonesResponse] -> ShowS
$cshowList :: [DescribeAvailabilityZonesResponse] -> ShowS
show :: DescribeAvailabilityZonesResponse -> String
$cshow :: DescribeAvailabilityZonesResponse -> String
showsPrec :: Int -> DescribeAvailabilityZonesResponse -> ShowS
$cshowsPrec :: Int -> DescribeAvailabilityZonesResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeAvailabilityZonesResponse x
-> DescribeAvailabilityZonesResponse
forall x.
DescribeAvailabilityZonesResponse
-> Rep DescribeAvailabilityZonesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeAvailabilityZonesResponse x
-> DescribeAvailabilityZonesResponse
$cfrom :: forall x.
DescribeAvailabilityZonesResponse
-> Rep DescribeAvailabilityZonesResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeAvailabilityZonesResponse' 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:
--
-- 'availabilityZones', 'describeAvailabilityZonesResponse_availabilityZones' - Information about the Availability Zones, Local Zones, and Wavelength
-- Zones.
--
-- 'httpStatus', 'describeAvailabilityZonesResponse_httpStatus' - The response's http status code.
newDescribeAvailabilityZonesResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeAvailabilityZonesResponse
newDescribeAvailabilityZonesResponse :: Int -> DescribeAvailabilityZonesResponse
newDescribeAvailabilityZonesResponse Int
pHttpStatus_ =
  DescribeAvailabilityZonesResponse'
    { $sel:availabilityZones:DescribeAvailabilityZonesResponse' :: Maybe [AvailabilityZone]
availabilityZones =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeAvailabilityZonesResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Information about the Availability Zones, Local Zones, and Wavelength
-- Zones.
describeAvailabilityZonesResponse_availabilityZones :: Lens.Lens' DescribeAvailabilityZonesResponse (Prelude.Maybe [AvailabilityZone])
describeAvailabilityZonesResponse_availabilityZones :: Lens' DescribeAvailabilityZonesResponse (Maybe [AvailabilityZone])
describeAvailabilityZonesResponse_availabilityZones = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAvailabilityZonesResponse' {Maybe [AvailabilityZone]
availabilityZones :: Maybe [AvailabilityZone]
$sel:availabilityZones:DescribeAvailabilityZonesResponse' :: DescribeAvailabilityZonesResponse -> Maybe [AvailabilityZone]
availabilityZones} -> Maybe [AvailabilityZone]
availabilityZones) (\s :: DescribeAvailabilityZonesResponse
s@DescribeAvailabilityZonesResponse' {} Maybe [AvailabilityZone]
a -> DescribeAvailabilityZonesResponse
s {$sel:availabilityZones:DescribeAvailabilityZonesResponse' :: Maybe [AvailabilityZone]
availabilityZones = Maybe [AvailabilityZone]
a} :: DescribeAvailabilityZonesResponse) 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.
describeAvailabilityZonesResponse_httpStatus :: Lens.Lens' DescribeAvailabilityZonesResponse Prelude.Int
describeAvailabilityZonesResponse_httpStatus :: Lens' DescribeAvailabilityZonesResponse Int
describeAvailabilityZonesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeAvailabilityZonesResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeAvailabilityZonesResponse' :: DescribeAvailabilityZonesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeAvailabilityZonesResponse
s@DescribeAvailabilityZonesResponse' {} Int
a -> DescribeAvailabilityZonesResponse
s {$sel:httpStatus:DescribeAvailabilityZonesResponse' :: Int
httpStatus = Int
a} :: DescribeAvailabilityZonesResponse)

instance
  Prelude.NFData
    DescribeAvailabilityZonesResponse
  where
  rnf :: DescribeAvailabilityZonesResponse -> ()
rnf DescribeAvailabilityZonesResponse' {Int
Maybe [AvailabilityZone]
httpStatus :: Int
availabilityZones :: Maybe [AvailabilityZone]
$sel:httpStatus:DescribeAvailabilityZonesResponse' :: DescribeAvailabilityZonesResponse -> Int
$sel:availabilityZones:DescribeAvailabilityZonesResponse' :: DescribeAvailabilityZonesResponse -> Maybe [AvailabilityZone]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [AvailabilityZone]
availabilityZones
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus