{-# 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.GetResolverRuleAssociation
(
GetResolverRuleAssociation (..),
newGetResolverRuleAssociation,
getResolverRuleAssociation_resolverRuleAssociationId,
GetResolverRuleAssociationResponse (..),
newGetResolverRuleAssociationResponse,
getResolverRuleAssociationResponse_resolverRuleAssociation,
getResolverRuleAssociationResponse_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 GetResolverRuleAssociation = GetResolverRuleAssociation'
{
GetResolverRuleAssociation -> Text
resolverRuleAssociationId :: Prelude.Text
}
deriving (GetResolverRuleAssociation -> GetResolverRuleAssociation -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetResolverRuleAssociation -> GetResolverRuleAssociation -> Bool
$c/= :: GetResolverRuleAssociation -> GetResolverRuleAssociation -> Bool
== :: GetResolverRuleAssociation -> GetResolverRuleAssociation -> Bool
$c== :: GetResolverRuleAssociation -> GetResolverRuleAssociation -> Bool
Prelude.Eq, ReadPrec [GetResolverRuleAssociation]
ReadPrec GetResolverRuleAssociation
Int -> ReadS GetResolverRuleAssociation
ReadS [GetResolverRuleAssociation]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetResolverRuleAssociation]
$creadListPrec :: ReadPrec [GetResolverRuleAssociation]
readPrec :: ReadPrec GetResolverRuleAssociation
$creadPrec :: ReadPrec GetResolverRuleAssociation
readList :: ReadS [GetResolverRuleAssociation]
$creadList :: ReadS [GetResolverRuleAssociation]
readsPrec :: Int -> ReadS GetResolverRuleAssociation
$creadsPrec :: Int -> ReadS GetResolverRuleAssociation
Prelude.Read, Int -> GetResolverRuleAssociation -> ShowS
[GetResolverRuleAssociation] -> ShowS
GetResolverRuleAssociation -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetResolverRuleAssociation] -> ShowS
$cshowList :: [GetResolverRuleAssociation] -> ShowS
show :: GetResolverRuleAssociation -> String
$cshow :: GetResolverRuleAssociation -> String
showsPrec :: Int -> GetResolverRuleAssociation -> ShowS
$cshowsPrec :: Int -> GetResolverRuleAssociation -> ShowS
Prelude.Show, forall x.
Rep GetResolverRuleAssociation x -> GetResolverRuleAssociation
forall x.
GetResolverRuleAssociation -> Rep GetResolverRuleAssociation x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetResolverRuleAssociation x -> GetResolverRuleAssociation
$cfrom :: forall x.
GetResolverRuleAssociation -> Rep GetResolverRuleAssociation x
Prelude.Generic)
newGetResolverRuleAssociation ::
Prelude.Text ->
GetResolverRuleAssociation
newGetResolverRuleAssociation :: Text -> GetResolverRuleAssociation
newGetResolverRuleAssociation
Text
pResolverRuleAssociationId_ =
GetResolverRuleAssociation'
{ $sel:resolverRuleAssociationId:GetResolverRuleAssociation' :: Text
resolverRuleAssociationId =
Text
pResolverRuleAssociationId_
}
getResolverRuleAssociation_resolverRuleAssociationId :: Lens.Lens' GetResolverRuleAssociation Prelude.Text
getResolverRuleAssociation_resolverRuleAssociationId :: Lens' GetResolverRuleAssociation Text
getResolverRuleAssociation_resolverRuleAssociationId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetResolverRuleAssociation' {Text
resolverRuleAssociationId :: Text
$sel:resolverRuleAssociationId:GetResolverRuleAssociation' :: GetResolverRuleAssociation -> Text
resolverRuleAssociationId} -> Text
resolverRuleAssociationId) (\s :: GetResolverRuleAssociation
s@GetResolverRuleAssociation' {} Text
a -> GetResolverRuleAssociation
s {$sel:resolverRuleAssociationId:GetResolverRuleAssociation' :: Text
resolverRuleAssociationId = Text
a} :: GetResolverRuleAssociation)
instance Core.AWSRequest GetResolverRuleAssociation where
type
AWSResponse GetResolverRuleAssociation =
GetResolverRuleAssociationResponse
request :: (Service -> Service)
-> GetResolverRuleAssociation -> Request GetResolverRuleAssociation
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 GetResolverRuleAssociation
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse GetResolverRuleAssociation)))
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 ResolverRuleAssociation
-> Int -> GetResolverRuleAssociationResponse
GetResolverRuleAssociationResponse'
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
"ResolverRuleAssociation")
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 GetResolverRuleAssociation where
hashWithSalt :: Int -> GetResolverRuleAssociation -> Int
hashWithSalt Int
_salt GetResolverRuleAssociation' {Text
resolverRuleAssociationId :: Text
$sel:resolverRuleAssociationId:GetResolverRuleAssociation' :: GetResolverRuleAssociation -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
resolverRuleAssociationId
instance Prelude.NFData GetResolverRuleAssociation where
rnf :: GetResolverRuleAssociation -> ()
rnf GetResolverRuleAssociation' {Text
resolverRuleAssociationId :: Text
$sel:resolverRuleAssociationId:GetResolverRuleAssociation' :: GetResolverRuleAssociation -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
resolverRuleAssociationId
instance Data.ToHeaders GetResolverRuleAssociation where
toHeaders :: GetResolverRuleAssociation -> 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.GetResolverRuleAssociation" ::
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 GetResolverRuleAssociation where
toJSON :: GetResolverRuleAssociation -> Value
toJSON GetResolverRuleAssociation' {Text
resolverRuleAssociationId :: Text
$sel:resolverRuleAssociationId:GetResolverRuleAssociation' :: GetResolverRuleAssociation -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just
( Key
"ResolverRuleAssociationId"
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
resolverRuleAssociationId
)
]
)
instance Data.ToPath GetResolverRuleAssociation where
toPath :: GetResolverRuleAssociation -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery GetResolverRuleAssociation where
toQuery :: GetResolverRuleAssociation -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data GetResolverRuleAssociationResponse = GetResolverRuleAssociationResponse'
{
GetResolverRuleAssociationResponse -> Maybe ResolverRuleAssociation
resolverRuleAssociation :: Prelude.Maybe ResolverRuleAssociation,
GetResolverRuleAssociationResponse -> Int
httpStatus :: Prelude.Int
}
deriving (GetResolverRuleAssociationResponse
-> GetResolverRuleAssociationResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetResolverRuleAssociationResponse
-> GetResolverRuleAssociationResponse -> Bool
$c/= :: GetResolverRuleAssociationResponse
-> GetResolverRuleAssociationResponse -> Bool
== :: GetResolverRuleAssociationResponse
-> GetResolverRuleAssociationResponse -> Bool
$c== :: GetResolverRuleAssociationResponse
-> GetResolverRuleAssociationResponse -> Bool
Prelude.Eq, ReadPrec [GetResolverRuleAssociationResponse]
ReadPrec GetResolverRuleAssociationResponse
Int -> ReadS GetResolverRuleAssociationResponse
ReadS [GetResolverRuleAssociationResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetResolverRuleAssociationResponse]
$creadListPrec :: ReadPrec [GetResolverRuleAssociationResponse]
readPrec :: ReadPrec GetResolverRuleAssociationResponse
$creadPrec :: ReadPrec GetResolverRuleAssociationResponse
readList :: ReadS [GetResolverRuleAssociationResponse]
$creadList :: ReadS [GetResolverRuleAssociationResponse]
readsPrec :: Int -> ReadS GetResolverRuleAssociationResponse
$creadsPrec :: Int -> ReadS GetResolverRuleAssociationResponse
Prelude.Read, Int -> GetResolverRuleAssociationResponse -> ShowS
[GetResolverRuleAssociationResponse] -> ShowS
GetResolverRuleAssociationResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetResolverRuleAssociationResponse] -> ShowS
$cshowList :: [GetResolverRuleAssociationResponse] -> ShowS
show :: GetResolverRuleAssociationResponse -> String
$cshow :: GetResolverRuleAssociationResponse -> String
showsPrec :: Int -> GetResolverRuleAssociationResponse -> ShowS
$cshowsPrec :: Int -> GetResolverRuleAssociationResponse -> ShowS
Prelude.Show, forall x.
Rep GetResolverRuleAssociationResponse x
-> GetResolverRuleAssociationResponse
forall x.
GetResolverRuleAssociationResponse
-> Rep GetResolverRuleAssociationResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetResolverRuleAssociationResponse x
-> GetResolverRuleAssociationResponse
$cfrom :: forall x.
GetResolverRuleAssociationResponse
-> Rep GetResolverRuleAssociationResponse x
Prelude.Generic)
newGetResolverRuleAssociationResponse ::
Prelude.Int ->
GetResolverRuleAssociationResponse
newGetResolverRuleAssociationResponse :: Int -> GetResolverRuleAssociationResponse
newGetResolverRuleAssociationResponse Int
pHttpStatus_ =
GetResolverRuleAssociationResponse'
{ $sel:resolverRuleAssociation:GetResolverRuleAssociationResponse' :: Maybe ResolverRuleAssociation
resolverRuleAssociation =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:GetResolverRuleAssociationResponse' :: Int
httpStatus = Int
pHttpStatus_
}
getResolverRuleAssociationResponse_resolverRuleAssociation :: Lens.Lens' GetResolverRuleAssociationResponse (Prelude.Maybe ResolverRuleAssociation)
getResolverRuleAssociationResponse_resolverRuleAssociation :: Lens'
GetResolverRuleAssociationResponse (Maybe ResolverRuleAssociation)
getResolverRuleAssociationResponse_resolverRuleAssociation = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetResolverRuleAssociationResponse' {Maybe ResolverRuleAssociation
resolverRuleAssociation :: Maybe ResolverRuleAssociation
$sel:resolverRuleAssociation:GetResolverRuleAssociationResponse' :: GetResolverRuleAssociationResponse -> Maybe ResolverRuleAssociation
resolverRuleAssociation} -> Maybe ResolverRuleAssociation
resolverRuleAssociation) (\s :: GetResolverRuleAssociationResponse
s@GetResolverRuleAssociationResponse' {} Maybe ResolverRuleAssociation
a -> GetResolverRuleAssociationResponse
s {$sel:resolverRuleAssociation:GetResolverRuleAssociationResponse' :: Maybe ResolverRuleAssociation
resolverRuleAssociation = Maybe ResolverRuleAssociation
a} :: GetResolverRuleAssociationResponse)
getResolverRuleAssociationResponse_httpStatus :: Lens.Lens' GetResolverRuleAssociationResponse Prelude.Int
getResolverRuleAssociationResponse_httpStatus :: Lens' GetResolverRuleAssociationResponse Int
getResolverRuleAssociationResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetResolverRuleAssociationResponse' {Int
httpStatus :: Int
$sel:httpStatus:GetResolverRuleAssociationResponse' :: GetResolverRuleAssociationResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: GetResolverRuleAssociationResponse
s@GetResolverRuleAssociationResponse' {} Int
a -> GetResolverRuleAssociationResponse
s {$sel:httpStatus:GetResolverRuleAssociationResponse' :: Int
httpStatus = Int
a} :: GetResolverRuleAssociationResponse)
instance
Prelude.NFData
GetResolverRuleAssociationResponse
where
rnf :: GetResolverRuleAssociationResponse -> ()
rnf GetResolverRuleAssociationResponse' {Int
Maybe ResolverRuleAssociation
httpStatus :: Int
resolverRuleAssociation :: Maybe ResolverRuleAssociation
$sel:httpStatus:GetResolverRuleAssociationResponse' :: GetResolverRuleAssociationResponse -> Int
$sel:resolverRuleAssociation:GetResolverRuleAssociationResponse' :: GetResolverRuleAssociationResponse -> Maybe ResolverRuleAssociation
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe ResolverRuleAssociation
resolverRuleAssociation
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus