{-# 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.AppMesh.DescribeRoute
(
DescribeRoute (..),
newDescribeRoute,
describeRoute_meshOwner,
describeRoute_meshName,
describeRoute_routeName,
describeRoute_virtualRouterName,
DescribeRouteResponse (..),
newDescribeRouteResponse,
describeRouteResponse_httpStatus,
describeRouteResponse_route,
)
where
import Amazonka.AppMesh.Types
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
data DescribeRoute = DescribeRoute'
{
DescribeRoute -> Maybe Text
meshOwner :: Prelude.Maybe Prelude.Text,
DescribeRoute -> Text
meshName :: Prelude.Text,
DescribeRoute -> Text
routeName :: Prelude.Text,
DescribeRoute -> Text
virtualRouterName :: Prelude.Text
}
deriving (DescribeRoute -> DescribeRoute -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeRoute -> DescribeRoute -> Bool
$c/= :: DescribeRoute -> DescribeRoute -> Bool
== :: DescribeRoute -> DescribeRoute -> Bool
$c== :: DescribeRoute -> DescribeRoute -> Bool
Prelude.Eq, ReadPrec [DescribeRoute]
ReadPrec DescribeRoute
Int -> ReadS DescribeRoute
ReadS [DescribeRoute]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeRoute]
$creadListPrec :: ReadPrec [DescribeRoute]
readPrec :: ReadPrec DescribeRoute
$creadPrec :: ReadPrec DescribeRoute
readList :: ReadS [DescribeRoute]
$creadList :: ReadS [DescribeRoute]
readsPrec :: Int -> ReadS DescribeRoute
$creadsPrec :: Int -> ReadS DescribeRoute
Prelude.Read, Int -> DescribeRoute -> ShowS
[DescribeRoute] -> ShowS
DescribeRoute -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeRoute] -> ShowS
$cshowList :: [DescribeRoute] -> ShowS
show :: DescribeRoute -> String
$cshow :: DescribeRoute -> String
showsPrec :: Int -> DescribeRoute -> ShowS
$cshowsPrec :: Int -> DescribeRoute -> ShowS
Prelude.Show, forall x. Rep DescribeRoute x -> DescribeRoute
forall x. DescribeRoute -> Rep DescribeRoute x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeRoute x -> DescribeRoute
$cfrom :: forall x. DescribeRoute -> Rep DescribeRoute x
Prelude.Generic)
newDescribeRoute ::
Prelude.Text ->
Prelude.Text ->
Prelude.Text ->
DescribeRoute
newDescribeRoute :: Text -> Text -> Text -> DescribeRoute
newDescribeRoute
Text
pMeshName_
Text
pRouteName_
Text
pVirtualRouterName_ =
DescribeRoute'
{ $sel:meshOwner:DescribeRoute' :: Maybe Text
meshOwner = forall a. Maybe a
Prelude.Nothing,
$sel:meshName:DescribeRoute' :: Text
meshName = Text
pMeshName_,
$sel:routeName:DescribeRoute' :: Text
routeName = Text
pRouteName_,
$sel:virtualRouterName:DescribeRoute' :: Text
virtualRouterName = Text
pVirtualRouterName_
}
describeRoute_meshOwner :: Lens.Lens' DescribeRoute (Prelude.Maybe Prelude.Text)
describeRoute_meshOwner :: Lens' DescribeRoute (Maybe Text)
describeRoute_meshOwner = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeRoute' {Maybe Text
meshOwner :: Maybe Text
$sel:meshOwner:DescribeRoute' :: DescribeRoute -> Maybe Text
meshOwner} -> Maybe Text
meshOwner) (\s :: DescribeRoute
s@DescribeRoute' {} Maybe Text
a -> DescribeRoute
s {$sel:meshOwner:DescribeRoute' :: Maybe Text
meshOwner = Maybe Text
a} :: DescribeRoute)
describeRoute_meshName :: Lens.Lens' DescribeRoute Prelude.Text
describeRoute_meshName :: Lens' DescribeRoute Text
describeRoute_meshName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeRoute' {Text
meshName :: Text
$sel:meshName:DescribeRoute' :: DescribeRoute -> Text
meshName} -> Text
meshName) (\s :: DescribeRoute
s@DescribeRoute' {} Text
a -> DescribeRoute
s {$sel:meshName:DescribeRoute' :: Text
meshName = Text
a} :: DescribeRoute)
describeRoute_routeName :: Lens.Lens' DescribeRoute Prelude.Text
describeRoute_routeName :: Lens' DescribeRoute Text
describeRoute_routeName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeRoute' {Text
routeName :: Text
$sel:routeName:DescribeRoute' :: DescribeRoute -> Text
routeName} -> Text
routeName) (\s :: DescribeRoute
s@DescribeRoute' {} Text
a -> DescribeRoute
s {$sel:routeName:DescribeRoute' :: Text
routeName = Text
a} :: DescribeRoute)
describeRoute_virtualRouterName :: Lens.Lens' DescribeRoute Prelude.Text
describeRoute_virtualRouterName :: Lens' DescribeRoute Text
describeRoute_virtualRouterName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeRoute' {Text
virtualRouterName :: Text
$sel:virtualRouterName:DescribeRoute' :: DescribeRoute -> Text
virtualRouterName} -> Text
virtualRouterName) (\s :: DescribeRoute
s@DescribeRoute' {} Text
a -> DescribeRoute
s {$sel:virtualRouterName:DescribeRoute' :: Text
virtualRouterName = Text
a} :: DescribeRoute)
instance Core.AWSRequest DescribeRoute where
type
AWSResponse DescribeRoute =
DescribeRouteResponse
request :: (Service -> Service) -> DescribeRoute -> Request DescribeRoute
request Service -> Service
overrides =
forall a. ToRequest a => Service -> a -> Request a
Request.get (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeRoute
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeRoute)))
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 ->
Int -> RouteData -> DescribeRouteResponse
DescribeRouteResponse'
forall (f :: * -> *) a b. Functor 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))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall a. FromJSON a => Object -> Either String a
Data.eitherParseJSON Object
x)
)
instance Prelude.Hashable DescribeRoute where
hashWithSalt :: Int -> DescribeRoute -> Int
hashWithSalt Int
_salt DescribeRoute' {Maybe Text
Text
virtualRouterName :: Text
routeName :: Text
meshName :: Text
meshOwner :: Maybe Text
$sel:virtualRouterName:DescribeRoute' :: DescribeRoute -> Text
$sel:routeName:DescribeRoute' :: DescribeRoute -> Text
$sel:meshName:DescribeRoute' :: DescribeRoute -> Text
$sel:meshOwner:DescribeRoute' :: DescribeRoute -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
meshOwner
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
meshName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
routeName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
virtualRouterName
instance Prelude.NFData DescribeRoute where
rnf :: DescribeRoute -> ()
rnf DescribeRoute' {Maybe Text
Text
virtualRouterName :: Text
routeName :: Text
meshName :: Text
meshOwner :: Maybe Text
$sel:virtualRouterName:DescribeRoute' :: DescribeRoute -> Text
$sel:routeName:DescribeRoute' :: DescribeRoute -> Text
$sel:meshName:DescribeRoute' :: DescribeRoute -> Text
$sel:meshOwner:DescribeRoute' :: DescribeRoute -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
meshOwner
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
meshName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
routeName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
virtualRouterName
instance Data.ToHeaders DescribeRoute where
toHeaders :: DescribeRoute -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToPath DescribeRoute where
toPath :: DescribeRoute -> ByteString
toPath DescribeRoute' {Maybe Text
Text
virtualRouterName :: Text
routeName :: Text
meshName :: Text
meshOwner :: Maybe Text
$sel:virtualRouterName:DescribeRoute' :: DescribeRoute -> Text
$sel:routeName:DescribeRoute' :: DescribeRoute -> Text
$sel:meshName:DescribeRoute' :: DescribeRoute -> Text
$sel:meshOwner:DescribeRoute' :: DescribeRoute -> Maybe Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/v20190125/meshes/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
meshName,
ByteString
"/virtualRouter/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
virtualRouterName,
ByteString
"/routes/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
routeName
]
instance Data.ToQuery DescribeRoute where
toQuery :: DescribeRoute -> QueryString
toQuery DescribeRoute' {Maybe Text
Text
virtualRouterName :: Text
routeName :: Text
meshName :: Text
meshOwner :: Maybe Text
$sel:virtualRouterName:DescribeRoute' :: DescribeRoute -> Text
$sel:routeName:DescribeRoute' :: DescribeRoute -> Text
$sel:meshName:DescribeRoute' :: DescribeRoute -> Text
$sel:meshOwner:DescribeRoute' :: DescribeRoute -> Maybe Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat [ByteString
"meshOwner" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
meshOwner]
data DescribeRouteResponse = DescribeRouteResponse'
{
DescribeRouteResponse -> Int
httpStatus :: Prelude.Int,
DescribeRouteResponse -> RouteData
route :: RouteData
}
deriving (DescribeRouteResponse -> DescribeRouteResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeRouteResponse -> DescribeRouteResponse -> Bool
$c/= :: DescribeRouteResponse -> DescribeRouteResponse -> Bool
== :: DescribeRouteResponse -> DescribeRouteResponse -> Bool
$c== :: DescribeRouteResponse -> DescribeRouteResponse -> Bool
Prelude.Eq, ReadPrec [DescribeRouteResponse]
ReadPrec DescribeRouteResponse
Int -> ReadS DescribeRouteResponse
ReadS [DescribeRouteResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeRouteResponse]
$creadListPrec :: ReadPrec [DescribeRouteResponse]
readPrec :: ReadPrec DescribeRouteResponse
$creadPrec :: ReadPrec DescribeRouteResponse
readList :: ReadS [DescribeRouteResponse]
$creadList :: ReadS [DescribeRouteResponse]
readsPrec :: Int -> ReadS DescribeRouteResponse
$creadsPrec :: Int -> ReadS DescribeRouteResponse
Prelude.Read, Int -> DescribeRouteResponse -> ShowS
[DescribeRouteResponse] -> ShowS
DescribeRouteResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeRouteResponse] -> ShowS
$cshowList :: [DescribeRouteResponse] -> ShowS
show :: DescribeRouteResponse -> String
$cshow :: DescribeRouteResponse -> String
showsPrec :: Int -> DescribeRouteResponse -> ShowS
$cshowsPrec :: Int -> DescribeRouteResponse -> ShowS
Prelude.Show, forall x. Rep DescribeRouteResponse x -> DescribeRouteResponse
forall x. DescribeRouteResponse -> Rep DescribeRouteResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeRouteResponse x -> DescribeRouteResponse
$cfrom :: forall x. DescribeRouteResponse -> Rep DescribeRouteResponse x
Prelude.Generic)
newDescribeRouteResponse ::
Prelude.Int ->
RouteData ->
DescribeRouteResponse
newDescribeRouteResponse :: Int -> RouteData -> DescribeRouteResponse
newDescribeRouteResponse Int
pHttpStatus_ RouteData
pRoute_ =
DescribeRouteResponse'
{ $sel:httpStatus:DescribeRouteResponse' :: Int
httpStatus = Int
pHttpStatus_,
$sel:route:DescribeRouteResponse' :: RouteData
route = RouteData
pRoute_
}
describeRouteResponse_httpStatus :: Lens.Lens' DescribeRouteResponse Prelude.Int
describeRouteResponse_httpStatus :: Lens' DescribeRouteResponse Int
describeRouteResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeRouteResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeRouteResponse' :: DescribeRouteResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeRouteResponse
s@DescribeRouteResponse' {} Int
a -> DescribeRouteResponse
s {$sel:httpStatus:DescribeRouteResponse' :: Int
httpStatus = Int
a} :: DescribeRouteResponse)
describeRouteResponse_route :: Lens.Lens' DescribeRouteResponse RouteData
describeRouteResponse_route :: Lens' DescribeRouteResponse RouteData
describeRouteResponse_route = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeRouteResponse' {RouteData
route :: RouteData
$sel:route:DescribeRouteResponse' :: DescribeRouteResponse -> RouteData
route} -> RouteData
route) (\s :: DescribeRouteResponse
s@DescribeRouteResponse' {} RouteData
a -> DescribeRouteResponse
s {$sel:route:DescribeRouteResponse' :: RouteData
route = RouteData
a} :: DescribeRouteResponse)
instance Prelude.NFData DescribeRouteResponse where
rnf :: DescribeRouteResponse -> ()
rnf DescribeRouteResponse' {Int
RouteData
route :: RouteData
httpStatus :: Int
$sel:route:DescribeRouteResponse' :: DescribeRouteResponse -> RouteData
$sel:httpStatus:DescribeRouteResponse' :: DescribeRouteResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf RouteData
route