{-# 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 #-}
module Amazonka.Route53Domains.EnableDomainTransferLock
(
EnableDomainTransferLock (..),
newEnableDomainTransferLock,
enableDomainTransferLock_domainName,
EnableDomainTransferLockResponse (..),
newEnableDomainTransferLockResponse,
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
data EnableDomainTransferLock = EnableDomainTransferLock'
{
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)
newEnableDomainTransferLock ::
Prelude.Text ->
EnableDomainTransferLock
newEnableDomainTransferLock :: Text -> EnableDomainTransferLock
newEnableDomainTransferLock Text
pDomainName_ =
EnableDomainTransferLock'
{ $sel:domainName:EnableDomainTransferLock' :: Text
domainName =
Text
pDomainName_
}
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
data EnableDomainTransferLockResponse = EnableDomainTransferLockResponse'
{
EnableDomainTransferLockResponse -> Maybe Text
operationId :: Prelude.Maybe Prelude.Text,
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)
newEnableDomainTransferLockResponse ::
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_
}
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)
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