{-# 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.Route53Domains.EnableDomainTransferLock
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- This operation sets the transfer lock on the domain (specifically the
-- @clientTransferProhibited@ status) to prevent domain transfers.
-- Successful submission returns an operation ID that you can use to track
-- the progress and completion of the action. If the request is not
-- completed successfully, the domain registrant will be notified by email.
module Amazonka.Route53Domains.EnableDomainTransferLock
  ( -- * Creating a Request
    EnableDomainTransferLock (..),
    newEnableDomainTransferLock,

    -- * Request Lenses
    enableDomainTransferLock_domainName,

    -- * Destructuring the Response
    EnableDomainTransferLockResponse (..),
    newEnableDomainTransferLockResponse,

    -- * Response Lenses
    enableDomainTransferLockResponse_operationId,
    enableDomainTransferLockResponse_httpStatus,
  )
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.Route53Domains.Types

-- | A request to set the transfer lock for the specified domain.
--
-- /See:/ 'newEnableDomainTransferLock' smart constructor.
data EnableDomainTransferLock = EnableDomainTransferLock'
  { -- | The name of the domain that you want to set the transfer lock for.
    EnableDomainTransferLock -> Text
domainName :: Prelude.Text
  }
  deriving (EnableDomainTransferLock -> EnableDomainTransferLock -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: EnableDomainTransferLock -> EnableDomainTransferLock -> Bool
$c/= :: EnableDomainTransferLock -> EnableDomainTransferLock -> Bool
== :: EnableDomainTransferLock -> EnableDomainTransferLock -> Bool
$c== :: EnableDomainTransferLock -> EnableDomainTransferLock -> Bool
Prelude.Eq, ReadPrec [EnableDomainTransferLock]
ReadPrec EnableDomainTransferLock
Int -> ReadS EnableDomainTransferLock
ReadS [EnableDomainTransferLock]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [EnableDomainTransferLock]
$creadListPrec :: ReadPrec [EnableDomainTransferLock]
readPrec :: ReadPrec EnableDomainTransferLock
$creadPrec :: ReadPrec EnableDomainTransferLock
readList :: ReadS [EnableDomainTransferLock]
$creadList :: ReadS [EnableDomainTransferLock]
readsPrec :: Int -> ReadS EnableDomainTransferLock
$creadsPrec :: Int -> ReadS EnableDomainTransferLock
Prelude.Read, Int -> EnableDomainTransferLock -> ShowS
[EnableDomainTransferLock] -> ShowS
EnableDomainTransferLock -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [EnableDomainTransferLock] -> ShowS
$cshowList :: [EnableDomainTransferLock] -> ShowS
show :: EnableDomainTransferLock -> String
$cshow :: EnableDomainTransferLock -> String
showsPrec :: Int -> EnableDomainTransferLock -> ShowS
$cshowsPrec :: Int -> EnableDomainTransferLock -> ShowS
Prelude.Show, forall x.
Rep EnableDomainTransferLock x -> EnableDomainTransferLock
forall x.
EnableDomainTransferLock -> Rep EnableDomainTransferLock x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep EnableDomainTransferLock x -> EnableDomainTransferLock
$cfrom :: forall x.
EnableDomainTransferLock -> Rep EnableDomainTransferLock x
Prelude.Generic)

-- |
-- Create a value of 'EnableDomainTransferLock' 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:
--
-- 'domainName', 'enableDomainTransferLock_domainName' - The name of the domain that you want to set the transfer lock for.
newEnableDomainTransferLock ::
  -- | 'domainName'
  Prelude.Text ->
  EnableDomainTransferLock
newEnableDomainTransferLock :: Text -> EnableDomainTransferLock
newEnableDomainTransferLock Text
pDomainName_ =
  EnableDomainTransferLock'
    { $sel:domainName:EnableDomainTransferLock' :: Text
domainName =
        Text
pDomainName_
    }

-- | The name of the domain that you want to set the transfer lock for.
enableDomainTransferLock_domainName :: Lens.Lens' EnableDomainTransferLock Prelude.Text
enableDomainTransferLock_domainName :: Lens' EnableDomainTransferLock Text
enableDomainTransferLock_domainName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EnableDomainTransferLock' {Text
domainName :: Text
$sel:domainName:EnableDomainTransferLock' :: EnableDomainTransferLock -> Text
domainName} -> Text
domainName) (\s :: EnableDomainTransferLock
s@EnableDomainTransferLock' {} Text
a -> EnableDomainTransferLock
s {$sel:domainName:EnableDomainTransferLock' :: Text
domainName = Text
a} :: EnableDomainTransferLock)

instance Core.AWSRequest EnableDomainTransferLock where
  type
    AWSResponse EnableDomainTransferLock =
      EnableDomainTransferLockResponse
  request :: (Service -> Service)
-> EnableDomainTransferLock -> Request EnableDomainTransferLock
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 EnableDomainTransferLock
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse EnableDomainTransferLock)))
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 -> Int -> EnableDomainTransferLockResponse
EnableDomainTransferLockResponse'
            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
"OperationId")
            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 EnableDomainTransferLock where
  hashWithSalt :: Int -> EnableDomainTransferLock -> Int
hashWithSalt Int
_salt EnableDomainTransferLock' {Text
domainName :: Text
$sel:domainName:EnableDomainTransferLock' :: EnableDomainTransferLock -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
domainName

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

instance Data.ToHeaders EnableDomainTransferLock where
  toHeaders :: EnableDomainTransferLock -> 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
"Route53Domains_v20140515.EnableDomainTransferLock" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON EnableDomainTransferLock where
  toJSON :: EnableDomainTransferLock -> Value
toJSON EnableDomainTransferLock' {Text
domainName :: Text
$sel:domainName:EnableDomainTransferLock' :: EnableDomainTransferLock -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [forall a. a -> Maybe a
Prelude.Just (Key
"DomainName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
domainName)]
      )

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

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

-- | The EnableDomainTransferLock response includes the following elements.
--
-- /See:/ 'newEnableDomainTransferLockResponse' smart constructor.
data EnableDomainTransferLockResponse = EnableDomainTransferLockResponse'
  { -- | Identifier for tracking the progress of the request. To use this ID to
    -- query the operation status, use GetOperationDetail.
    EnableDomainTransferLockResponse -> Maybe Text
operationId :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    EnableDomainTransferLockResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (EnableDomainTransferLockResponse
-> EnableDomainTransferLockResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: EnableDomainTransferLockResponse
-> EnableDomainTransferLockResponse -> Bool
$c/= :: EnableDomainTransferLockResponse
-> EnableDomainTransferLockResponse -> Bool
== :: EnableDomainTransferLockResponse
-> EnableDomainTransferLockResponse -> Bool
$c== :: EnableDomainTransferLockResponse
-> EnableDomainTransferLockResponse -> Bool
Prelude.Eq, ReadPrec [EnableDomainTransferLockResponse]
ReadPrec EnableDomainTransferLockResponse
Int -> ReadS EnableDomainTransferLockResponse
ReadS [EnableDomainTransferLockResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [EnableDomainTransferLockResponse]
$creadListPrec :: ReadPrec [EnableDomainTransferLockResponse]
readPrec :: ReadPrec EnableDomainTransferLockResponse
$creadPrec :: ReadPrec EnableDomainTransferLockResponse
readList :: ReadS [EnableDomainTransferLockResponse]
$creadList :: ReadS [EnableDomainTransferLockResponse]
readsPrec :: Int -> ReadS EnableDomainTransferLockResponse
$creadsPrec :: Int -> ReadS EnableDomainTransferLockResponse
Prelude.Read, Int -> EnableDomainTransferLockResponse -> ShowS
[EnableDomainTransferLockResponse] -> ShowS
EnableDomainTransferLockResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [EnableDomainTransferLockResponse] -> ShowS
$cshowList :: [EnableDomainTransferLockResponse] -> ShowS
show :: EnableDomainTransferLockResponse -> String
$cshow :: EnableDomainTransferLockResponse -> String
showsPrec :: Int -> EnableDomainTransferLockResponse -> ShowS
$cshowsPrec :: Int -> EnableDomainTransferLockResponse -> ShowS
Prelude.Show, forall x.
Rep EnableDomainTransferLockResponse x
-> EnableDomainTransferLockResponse
forall x.
EnableDomainTransferLockResponse
-> Rep EnableDomainTransferLockResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep EnableDomainTransferLockResponse x
-> EnableDomainTransferLockResponse
$cfrom :: forall x.
EnableDomainTransferLockResponse
-> Rep EnableDomainTransferLockResponse x
Prelude.Generic)

-- |
-- Create a value of 'EnableDomainTransferLockResponse' 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:
--
-- 'operationId', 'enableDomainTransferLockResponse_operationId' - Identifier for tracking the progress of the request. To use this ID to
-- query the operation status, use GetOperationDetail.
--
-- 'httpStatus', 'enableDomainTransferLockResponse_httpStatus' - The response's http status code.
newEnableDomainTransferLockResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  EnableDomainTransferLockResponse
newEnableDomainTransferLockResponse :: Int -> EnableDomainTransferLockResponse
newEnableDomainTransferLockResponse Int
pHttpStatus_ =
  EnableDomainTransferLockResponse'
    { $sel:operationId:EnableDomainTransferLockResponse' :: Maybe Text
operationId =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:EnableDomainTransferLockResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Identifier for tracking the progress of the request. To use this ID to
-- query the operation status, use GetOperationDetail.
enableDomainTransferLockResponse_operationId :: Lens.Lens' EnableDomainTransferLockResponse (Prelude.Maybe Prelude.Text)
enableDomainTransferLockResponse_operationId :: Lens' EnableDomainTransferLockResponse (Maybe Text)
enableDomainTransferLockResponse_operationId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EnableDomainTransferLockResponse' {Maybe Text
operationId :: Maybe Text
$sel:operationId:EnableDomainTransferLockResponse' :: EnableDomainTransferLockResponse -> Maybe Text
operationId} -> Maybe Text
operationId) (\s :: EnableDomainTransferLockResponse
s@EnableDomainTransferLockResponse' {} Maybe Text
a -> EnableDomainTransferLockResponse
s {$sel:operationId:EnableDomainTransferLockResponse' :: Maybe Text
operationId = Maybe Text
a} :: EnableDomainTransferLockResponse)

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

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