{-# 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.ElasticBeanstalk.CheckDNSAvailability
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Checks if the specified CNAME is available.
module Amazonka.ElasticBeanstalk.CheckDNSAvailability
  ( -- * Creating a Request
    CheckDNSAvailability (..),
    newCheckDNSAvailability,

    -- * Request Lenses
    checkDNSAvailability_cNAMEPrefix,

    -- * Destructuring the Response
    CheckDNSAvailabilityResponse (..),
    newCheckDNSAvailabilityResponse,

    -- * Response Lenses
    checkDNSAvailabilityResponse_available,
    checkDNSAvailabilityResponse_fullyQualifiedCNAME,
    checkDNSAvailabilityResponse_httpStatus,
  )
where

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

-- | Results message indicating whether a CNAME is available.
--
-- /See:/ 'newCheckDNSAvailability' smart constructor.
data CheckDNSAvailability = CheckDNSAvailability'
  { -- | The prefix used when this CNAME is reserved.
    CheckDNSAvailability -> Text
cNAMEPrefix :: Prelude.Text
  }
  deriving (CheckDNSAvailability -> CheckDNSAvailability -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CheckDNSAvailability -> CheckDNSAvailability -> Bool
$c/= :: CheckDNSAvailability -> CheckDNSAvailability -> Bool
== :: CheckDNSAvailability -> CheckDNSAvailability -> Bool
$c== :: CheckDNSAvailability -> CheckDNSAvailability -> Bool
Prelude.Eq, ReadPrec [CheckDNSAvailability]
ReadPrec CheckDNSAvailability
Int -> ReadS CheckDNSAvailability
ReadS [CheckDNSAvailability]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CheckDNSAvailability]
$creadListPrec :: ReadPrec [CheckDNSAvailability]
readPrec :: ReadPrec CheckDNSAvailability
$creadPrec :: ReadPrec CheckDNSAvailability
readList :: ReadS [CheckDNSAvailability]
$creadList :: ReadS [CheckDNSAvailability]
readsPrec :: Int -> ReadS CheckDNSAvailability
$creadsPrec :: Int -> ReadS CheckDNSAvailability
Prelude.Read, Int -> CheckDNSAvailability -> ShowS
[CheckDNSAvailability] -> ShowS
CheckDNSAvailability -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CheckDNSAvailability] -> ShowS
$cshowList :: [CheckDNSAvailability] -> ShowS
show :: CheckDNSAvailability -> String
$cshow :: CheckDNSAvailability -> String
showsPrec :: Int -> CheckDNSAvailability -> ShowS
$cshowsPrec :: Int -> CheckDNSAvailability -> ShowS
Prelude.Show, forall x. Rep CheckDNSAvailability x -> CheckDNSAvailability
forall x. CheckDNSAvailability -> Rep CheckDNSAvailability x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CheckDNSAvailability x -> CheckDNSAvailability
$cfrom :: forall x. CheckDNSAvailability -> Rep CheckDNSAvailability x
Prelude.Generic)

-- |
-- Create a value of 'CheckDNSAvailability' 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:
--
-- 'cNAMEPrefix', 'checkDNSAvailability_cNAMEPrefix' - The prefix used when this CNAME is reserved.
newCheckDNSAvailability ::
  -- | 'cNAMEPrefix'
  Prelude.Text ->
  CheckDNSAvailability
newCheckDNSAvailability :: Text -> CheckDNSAvailability
newCheckDNSAvailability Text
pCNAMEPrefix_ =
  CheckDNSAvailability' {$sel:cNAMEPrefix:CheckDNSAvailability' :: Text
cNAMEPrefix = Text
pCNAMEPrefix_}

-- | The prefix used when this CNAME is reserved.
checkDNSAvailability_cNAMEPrefix :: Lens.Lens' CheckDNSAvailability Prelude.Text
checkDNSAvailability_cNAMEPrefix :: Lens' CheckDNSAvailability Text
checkDNSAvailability_cNAMEPrefix = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CheckDNSAvailability' {Text
cNAMEPrefix :: Text
$sel:cNAMEPrefix:CheckDNSAvailability' :: CheckDNSAvailability -> Text
cNAMEPrefix} -> Text
cNAMEPrefix) (\s :: CheckDNSAvailability
s@CheckDNSAvailability' {} Text
a -> CheckDNSAvailability
s {$sel:cNAMEPrefix:CheckDNSAvailability' :: Text
cNAMEPrefix = Text
a} :: CheckDNSAvailability)

instance Core.AWSRequest CheckDNSAvailability where
  type
    AWSResponse CheckDNSAvailability =
      CheckDNSAvailabilityResponse
  request :: (Service -> Service)
-> CheckDNSAvailability -> Request CheckDNSAvailability
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 CheckDNSAvailability
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse CheckDNSAvailability)))
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
"CheckDNSAvailabilityResult"
      ( \Int
s ResponseHeaders
h [Node]
x ->
          Maybe Bool -> Maybe Text -> Int -> CheckDNSAvailabilityResponse
CheckDNSAvailabilityResponse'
            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
"Available")
            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
"FullyQualifiedCNAME")
            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 CheckDNSAvailability where
  hashWithSalt :: Int -> CheckDNSAvailability -> Int
hashWithSalt Int
_salt CheckDNSAvailability' {Text
cNAMEPrefix :: Text
$sel:cNAMEPrefix:CheckDNSAvailability' :: CheckDNSAvailability -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
cNAMEPrefix

instance Prelude.NFData CheckDNSAvailability where
  rnf :: CheckDNSAvailability -> ()
rnf CheckDNSAvailability' {Text
cNAMEPrefix :: Text
$sel:cNAMEPrefix:CheckDNSAvailability' :: CheckDNSAvailability -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
cNAMEPrefix

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

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

instance Data.ToQuery CheckDNSAvailability where
  toQuery :: CheckDNSAvailability -> QueryString
toQuery CheckDNSAvailability' {Text
cNAMEPrefix :: Text
$sel:cNAMEPrefix:CheckDNSAvailability' :: CheckDNSAvailability -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"CheckDNSAvailability" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2010-12-01" :: Prelude.ByteString),
        ByteString
"CNAMEPrefix" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
cNAMEPrefix
      ]

-- | Indicates if the specified CNAME is available.
--
-- /See:/ 'newCheckDNSAvailabilityResponse' smart constructor.
data CheckDNSAvailabilityResponse = CheckDNSAvailabilityResponse'
  { -- | Indicates if the specified CNAME is available:
    --
    -- -   @true@ : The CNAME is available.
    --
    -- -   @false@ : The CNAME is not available.
    CheckDNSAvailabilityResponse -> Maybe Bool
available :: Prelude.Maybe Prelude.Bool,
    -- | The fully qualified CNAME to reserve when CreateEnvironment is called
    -- with the provided prefix.
    CheckDNSAvailabilityResponse -> Maybe Text
fullyQualifiedCNAME :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    CheckDNSAvailabilityResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (CheckDNSAvailabilityResponse
-> CheckDNSAvailabilityResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CheckDNSAvailabilityResponse
-> CheckDNSAvailabilityResponse -> Bool
$c/= :: CheckDNSAvailabilityResponse
-> CheckDNSAvailabilityResponse -> Bool
== :: CheckDNSAvailabilityResponse
-> CheckDNSAvailabilityResponse -> Bool
$c== :: CheckDNSAvailabilityResponse
-> CheckDNSAvailabilityResponse -> Bool
Prelude.Eq, ReadPrec [CheckDNSAvailabilityResponse]
ReadPrec CheckDNSAvailabilityResponse
Int -> ReadS CheckDNSAvailabilityResponse
ReadS [CheckDNSAvailabilityResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CheckDNSAvailabilityResponse]
$creadListPrec :: ReadPrec [CheckDNSAvailabilityResponse]
readPrec :: ReadPrec CheckDNSAvailabilityResponse
$creadPrec :: ReadPrec CheckDNSAvailabilityResponse
readList :: ReadS [CheckDNSAvailabilityResponse]
$creadList :: ReadS [CheckDNSAvailabilityResponse]
readsPrec :: Int -> ReadS CheckDNSAvailabilityResponse
$creadsPrec :: Int -> ReadS CheckDNSAvailabilityResponse
Prelude.Read, Int -> CheckDNSAvailabilityResponse -> ShowS
[CheckDNSAvailabilityResponse] -> ShowS
CheckDNSAvailabilityResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CheckDNSAvailabilityResponse] -> ShowS
$cshowList :: [CheckDNSAvailabilityResponse] -> ShowS
show :: CheckDNSAvailabilityResponse -> String
$cshow :: CheckDNSAvailabilityResponse -> String
showsPrec :: Int -> CheckDNSAvailabilityResponse -> ShowS
$cshowsPrec :: Int -> CheckDNSAvailabilityResponse -> ShowS
Prelude.Show, forall x.
Rep CheckDNSAvailabilityResponse x -> CheckDNSAvailabilityResponse
forall x.
CheckDNSAvailabilityResponse -> Rep CheckDNSAvailabilityResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CheckDNSAvailabilityResponse x -> CheckDNSAvailabilityResponse
$cfrom :: forall x.
CheckDNSAvailabilityResponse -> Rep CheckDNSAvailabilityResponse x
Prelude.Generic)

-- |
-- Create a value of 'CheckDNSAvailabilityResponse' 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:
--
-- 'available', 'checkDNSAvailabilityResponse_available' - Indicates if the specified CNAME is available:
--
-- -   @true@ : The CNAME is available.
--
-- -   @false@ : The CNAME is not available.
--
-- 'fullyQualifiedCNAME', 'checkDNSAvailabilityResponse_fullyQualifiedCNAME' - The fully qualified CNAME to reserve when CreateEnvironment is called
-- with the provided prefix.
--
-- 'httpStatus', 'checkDNSAvailabilityResponse_httpStatus' - The response's http status code.
newCheckDNSAvailabilityResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  CheckDNSAvailabilityResponse
newCheckDNSAvailabilityResponse :: Int -> CheckDNSAvailabilityResponse
newCheckDNSAvailabilityResponse Int
pHttpStatus_ =
  CheckDNSAvailabilityResponse'
    { $sel:available:CheckDNSAvailabilityResponse' :: Maybe Bool
available =
        forall a. Maybe a
Prelude.Nothing,
      $sel:fullyQualifiedCNAME:CheckDNSAvailabilityResponse' :: Maybe Text
fullyQualifiedCNAME = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:CheckDNSAvailabilityResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Indicates if the specified CNAME is available:
--
-- -   @true@ : The CNAME is available.
--
-- -   @false@ : The CNAME is not available.
checkDNSAvailabilityResponse_available :: Lens.Lens' CheckDNSAvailabilityResponse (Prelude.Maybe Prelude.Bool)
checkDNSAvailabilityResponse_available :: Lens' CheckDNSAvailabilityResponse (Maybe Bool)
checkDNSAvailabilityResponse_available = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CheckDNSAvailabilityResponse' {Maybe Bool
available :: Maybe Bool
$sel:available:CheckDNSAvailabilityResponse' :: CheckDNSAvailabilityResponse -> Maybe Bool
available} -> Maybe Bool
available) (\s :: CheckDNSAvailabilityResponse
s@CheckDNSAvailabilityResponse' {} Maybe Bool
a -> CheckDNSAvailabilityResponse
s {$sel:available:CheckDNSAvailabilityResponse' :: Maybe Bool
available = Maybe Bool
a} :: CheckDNSAvailabilityResponse)

-- | The fully qualified CNAME to reserve when CreateEnvironment is called
-- with the provided prefix.
checkDNSAvailabilityResponse_fullyQualifiedCNAME :: Lens.Lens' CheckDNSAvailabilityResponse (Prelude.Maybe Prelude.Text)
checkDNSAvailabilityResponse_fullyQualifiedCNAME :: Lens' CheckDNSAvailabilityResponse (Maybe Text)
checkDNSAvailabilityResponse_fullyQualifiedCNAME = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CheckDNSAvailabilityResponse' {Maybe Text
fullyQualifiedCNAME :: Maybe Text
$sel:fullyQualifiedCNAME:CheckDNSAvailabilityResponse' :: CheckDNSAvailabilityResponse -> Maybe Text
fullyQualifiedCNAME} -> Maybe Text
fullyQualifiedCNAME) (\s :: CheckDNSAvailabilityResponse
s@CheckDNSAvailabilityResponse' {} Maybe Text
a -> CheckDNSAvailabilityResponse
s {$sel:fullyQualifiedCNAME:CheckDNSAvailabilityResponse' :: Maybe Text
fullyQualifiedCNAME = Maybe Text
a} :: CheckDNSAvailabilityResponse)

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

instance Prelude.NFData CheckDNSAvailabilityResponse where
  rnf :: CheckDNSAvailabilityResponse -> ()
rnf CheckDNSAvailabilityResponse' {Int
Maybe Bool
Maybe Text
httpStatus :: Int
fullyQualifiedCNAME :: Maybe Text
available :: Maybe Bool
$sel:httpStatus:CheckDNSAvailabilityResponse' :: CheckDNSAvailabilityResponse -> Int
$sel:fullyQualifiedCNAME:CheckDNSAvailabilityResponse' :: CheckDNSAvailabilityResponse -> Maybe Text
$sel:available:CheckDNSAvailabilityResponse' :: CheckDNSAvailabilityResponse -> Maybe Bool
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
available
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
fullyQualifiedCNAME
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus