{-# 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.Route53Resolver.PutResolverRulePolicy
(
PutResolverRulePolicy (..),
newPutResolverRulePolicy,
putResolverRulePolicy_arn,
putResolverRulePolicy_resolverRulePolicy,
PutResolverRulePolicyResponse (..),
newPutResolverRulePolicyResponse,
putResolverRulePolicyResponse_returnValue,
putResolverRulePolicyResponse_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.Route53Resolver.Types
data PutResolverRulePolicy = PutResolverRulePolicy'
{
PutResolverRulePolicy -> Text
arn :: Prelude.Text,
PutResolverRulePolicy -> Text
resolverRulePolicy :: Prelude.Text
}
deriving (PutResolverRulePolicy -> PutResolverRulePolicy -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PutResolverRulePolicy -> PutResolverRulePolicy -> Bool
$c/= :: PutResolverRulePolicy -> PutResolverRulePolicy -> Bool
== :: PutResolverRulePolicy -> PutResolverRulePolicy -> Bool
$c== :: PutResolverRulePolicy -> PutResolverRulePolicy -> Bool
Prelude.Eq, ReadPrec [PutResolverRulePolicy]
ReadPrec PutResolverRulePolicy
Int -> ReadS PutResolverRulePolicy
ReadS [PutResolverRulePolicy]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [PutResolverRulePolicy]
$creadListPrec :: ReadPrec [PutResolverRulePolicy]
readPrec :: ReadPrec PutResolverRulePolicy
$creadPrec :: ReadPrec PutResolverRulePolicy
readList :: ReadS [PutResolverRulePolicy]
$creadList :: ReadS [PutResolverRulePolicy]
readsPrec :: Int -> ReadS PutResolverRulePolicy
$creadsPrec :: Int -> ReadS PutResolverRulePolicy
Prelude.Read, Int -> PutResolverRulePolicy -> ShowS
[PutResolverRulePolicy] -> ShowS
PutResolverRulePolicy -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PutResolverRulePolicy] -> ShowS
$cshowList :: [PutResolverRulePolicy] -> ShowS
show :: PutResolverRulePolicy -> String
$cshow :: PutResolverRulePolicy -> String
showsPrec :: Int -> PutResolverRulePolicy -> ShowS
$cshowsPrec :: Int -> PutResolverRulePolicy -> ShowS
Prelude.Show, forall x. Rep PutResolverRulePolicy x -> PutResolverRulePolicy
forall x. PutResolverRulePolicy -> Rep PutResolverRulePolicy x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep PutResolverRulePolicy x -> PutResolverRulePolicy
$cfrom :: forall x. PutResolverRulePolicy -> Rep PutResolverRulePolicy x
Prelude.Generic)
newPutResolverRulePolicy ::
Prelude.Text ->
Prelude.Text ->
PutResolverRulePolicy
newPutResolverRulePolicy :: Text -> Text -> PutResolverRulePolicy
newPutResolverRulePolicy Text
pArn_ Text
pResolverRulePolicy_ =
PutResolverRulePolicy'
{ $sel:arn:PutResolverRulePolicy' :: Text
arn = Text
pArn_,
$sel:resolverRulePolicy:PutResolverRulePolicy' :: Text
resolverRulePolicy = Text
pResolverRulePolicy_
}
putResolverRulePolicy_arn :: Lens.Lens' PutResolverRulePolicy Prelude.Text
putResolverRulePolicy_arn :: Lens' PutResolverRulePolicy Text
putResolverRulePolicy_arn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PutResolverRulePolicy' {Text
arn :: Text
$sel:arn:PutResolverRulePolicy' :: PutResolverRulePolicy -> Text
arn} -> Text
arn) (\s :: PutResolverRulePolicy
s@PutResolverRulePolicy' {} Text
a -> PutResolverRulePolicy
s {$sel:arn:PutResolverRulePolicy' :: Text
arn = Text
a} :: PutResolverRulePolicy)
putResolverRulePolicy_resolverRulePolicy :: Lens.Lens' PutResolverRulePolicy Prelude.Text
putResolverRulePolicy_resolverRulePolicy :: Lens' PutResolverRulePolicy Text
putResolverRulePolicy_resolverRulePolicy = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PutResolverRulePolicy' {Text
resolverRulePolicy :: Text
$sel:resolverRulePolicy:PutResolverRulePolicy' :: PutResolverRulePolicy -> Text
resolverRulePolicy} -> Text
resolverRulePolicy) (\s :: PutResolverRulePolicy
s@PutResolverRulePolicy' {} Text
a -> PutResolverRulePolicy
s {$sel:resolverRulePolicy:PutResolverRulePolicy' :: Text
resolverRulePolicy = Text
a} :: PutResolverRulePolicy)
instance Core.AWSRequest PutResolverRulePolicy where
type
AWSResponse PutResolverRulePolicy =
PutResolverRulePolicyResponse
request :: (Service -> Service)
-> PutResolverRulePolicy -> Request PutResolverRulePolicy
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 PutResolverRulePolicy
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse PutResolverRulePolicy)))
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 Bool -> Int -> PutResolverRulePolicyResponse
PutResolverRulePolicyResponse'
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
"ReturnValue")
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 PutResolverRulePolicy where
hashWithSalt :: Int -> PutResolverRulePolicy -> Int
hashWithSalt Int
_salt PutResolverRulePolicy' {Text
resolverRulePolicy :: Text
arn :: Text
$sel:resolverRulePolicy:PutResolverRulePolicy' :: PutResolverRulePolicy -> Text
$sel:arn:PutResolverRulePolicy' :: PutResolverRulePolicy -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
arn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
resolverRulePolicy
instance Prelude.NFData PutResolverRulePolicy where
rnf :: PutResolverRulePolicy -> ()
rnf PutResolverRulePolicy' {Text
resolverRulePolicy :: Text
arn :: Text
$sel:resolverRulePolicy:PutResolverRulePolicy' :: PutResolverRulePolicy -> Text
$sel:arn:PutResolverRulePolicy' :: PutResolverRulePolicy -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
arn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
resolverRulePolicy
instance Data.ToHeaders PutResolverRulePolicy where
toHeaders :: PutResolverRulePolicy -> 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
"Route53Resolver.PutResolverRulePolicy" ::
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 PutResolverRulePolicy where
toJSON :: PutResolverRulePolicy -> Value
toJSON PutResolverRulePolicy' {Text
resolverRulePolicy :: Text
arn :: Text
$sel:resolverRulePolicy:PutResolverRulePolicy' :: PutResolverRulePolicy -> Text
$sel:arn:PutResolverRulePolicy' :: PutResolverRulePolicy -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just (Key
"Arn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
arn),
forall a. a -> Maybe a
Prelude.Just
(Key
"ResolverRulePolicy" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
resolverRulePolicy)
]
)
instance Data.ToPath PutResolverRulePolicy where
toPath :: PutResolverRulePolicy -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery PutResolverRulePolicy where
toQuery :: PutResolverRulePolicy -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data PutResolverRulePolicyResponse = PutResolverRulePolicyResponse'
{
PutResolverRulePolicyResponse -> Maybe Bool
returnValue :: Prelude.Maybe Prelude.Bool,
PutResolverRulePolicyResponse -> Int
httpStatus :: Prelude.Int
}
deriving (PutResolverRulePolicyResponse
-> PutResolverRulePolicyResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PutResolverRulePolicyResponse
-> PutResolverRulePolicyResponse -> Bool
$c/= :: PutResolverRulePolicyResponse
-> PutResolverRulePolicyResponse -> Bool
== :: PutResolverRulePolicyResponse
-> PutResolverRulePolicyResponse -> Bool
$c== :: PutResolverRulePolicyResponse
-> PutResolverRulePolicyResponse -> Bool
Prelude.Eq, ReadPrec [PutResolverRulePolicyResponse]
ReadPrec PutResolverRulePolicyResponse
Int -> ReadS PutResolverRulePolicyResponse
ReadS [PutResolverRulePolicyResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [PutResolverRulePolicyResponse]
$creadListPrec :: ReadPrec [PutResolverRulePolicyResponse]
readPrec :: ReadPrec PutResolverRulePolicyResponse
$creadPrec :: ReadPrec PutResolverRulePolicyResponse
readList :: ReadS [PutResolverRulePolicyResponse]
$creadList :: ReadS [PutResolverRulePolicyResponse]
readsPrec :: Int -> ReadS PutResolverRulePolicyResponse
$creadsPrec :: Int -> ReadS PutResolverRulePolicyResponse
Prelude.Read, Int -> PutResolverRulePolicyResponse -> ShowS
[PutResolverRulePolicyResponse] -> ShowS
PutResolverRulePolicyResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PutResolverRulePolicyResponse] -> ShowS
$cshowList :: [PutResolverRulePolicyResponse] -> ShowS
show :: PutResolverRulePolicyResponse -> String
$cshow :: PutResolverRulePolicyResponse -> String
showsPrec :: Int -> PutResolverRulePolicyResponse -> ShowS
$cshowsPrec :: Int -> PutResolverRulePolicyResponse -> ShowS
Prelude.Show, forall x.
Rep PutResolverRulePolicyResponse x
-> PutResolverRulePolicyResponse
forall x.
PutResolverRulePolicyResponse
-> Rep PutResolverRulePolicyResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep PutResolverRulePolicyResponse x
-> PutResolverRulePolicyResponse
$cfrom :: forall x.
PutResolverRulePolicyResponse
-> Rep PutResolverRulePolicyResponse x
Prelude.Generic)
newPutResolverRulePolicyResponse ::
Prelude.Int ->
PutResolverRulePolicyResponse
newPutResolverRulePolicyResponse :: Int -> PutResolverRulePolicyResponse
newPutResolverRulePolicyResponse Int
pHttpStatus_ =
PutResolverRulePolicyResponse'
{ $sel:returnValue:PutResolverRulePolicyResponse' :: Maybe Bool
returnValue =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:PutResolverRulePolicyResponse' :: Int
httpStatus = Int
pHttpStatus_
}
putResolverRulePolicyResponse_returnValue :: Lens.Lens' PutResolverRulePolicyResponse (Prelude.Maybe Prelude.Bool)
putResolverRulePolicyResponse_returnValue :: Lens' PutResolverRulePolicyResponse (Maybe Bool)
putResolverRulePolicyResponse_returnValue = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PutResolverRulePolicyResponse' {Maybe Bool
returnValue :: Maybe Bool
$sel:returnValue:PutResolverRulePolicyResponse' :: PutResolverRulePolicyResponse -> Maybe Bool
returnValue} -> Maybe Bool
returnValue) (\s :: PutResolverRulePolicyResponse
s@PutResolverRulePolicyResponse' {} Maybe Bool
a -> PutResolverRulePolicyResponse
s {$sel:returnValue:PutResolverRulePolicyResponse' :: Maybe Bool
returnValue = Maybe Bool
a} :: PutResolverRulePolicyResponse)
putResolverRulePolicyResponse_httpStatus :: Lens.Lens' PutResolverRulePolicyResponse Prelude.Int
putResolverRulePolicyResponse_httpStatus :: Lens' PutResolverRulePolicyResponse Int
putResolverRulePolicyResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PutResolverRulePolicyResponse' {Int
httpStatus :: Int
$sel:httpStatus:PutResolverRulePolicyResponse' :: PutResolverRulePolicyResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: PutResolverRulePolicyResponse
s@PutResolverRulePolicyResponse' {} Int
a -> PutResolverRulePolicyResponse
s {$sel:httpStatus:PutResolverRulePolicyResponse' :: Int
httpStatus = Int
a} :: PutResolverRulePolicyResponse)
instance Prelude.NFData PutResolverRulePolicyResponse where
rnf :: PutResolverRulePolicyResponse -> ()
rnf PutResolverRulePolicyResponse' {Int
Maybe Bool
httpStatus :: Int
returnValue :: Maybe Bool
$sel:httpStatus:PutResolverRulePolicyResponse' :: PutResolverRulePolicyResponse -> Int
$sel:returnValue:PutResolverRulePolicyResponse' :: PutResolverRulePolicyResponse -> Maybe Bool
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
returnValue
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus