{-# 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.DeleteRoute
(
DeleteRoute (..),
newDeleteRoute,
deleteRoute_meshOwner,
deleteRoute_meshName,
deleteRoute_routeName,
deleteRoute_virtualRouterName,
DeleteRouteResponse (..),
newDeleteRouteResponse,
deleteRouteResponse_httpStatus,
deleteRouteResponse_route,
)
where
import Amazonka.AppMesh.Types
import qualified Amazonka.Core as Core
import qualified Amazonka.Lens as Lens
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DeleteRoute = DeleteRoute'
{
DeleteRoute -> Maybe Text
meshOwner :: Prelude.Maybe Prelude.Text,
DeleteRoute -> Text
meshName :: Prelude.Text,
DeleteRoute -> Text
routeName :: Prelude.Text,
DeleteRoute -> Text
virtualRouterName :: Prelude.Text
}
deriving (DeleteRoute -> DeleteRoute -> Bool
(DeleteRoute -> DeleteRoute -> Bool)
-> (DeleteRoute -> DeleteRoute -> Bool) -> Eq DeleteRoute
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteRoute -> DeleteRoute -> Bool
$c/= :: DeleteRoute -> DeleteRoute -> Bool
== :: DeleteRoute -> DeleteRoute -> Bool
$c== :: DeleteRoute -> DeleteRoute -> Bool
Prelude.Eq, ReadPrec [DeleteRoute]
ReadPrec DeleteRoute
Int -> ReadS DeleteRoute
ReadS [DeleteRoute]
(Int -> ReadS DeleteRoute)
-> ReadS [DeleteRoute]
-> ReadPrec DeleteRoute
-> ReadPrec [DeleteRoute]
-> Read DeleteRoute
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteRoute]
$creadListPrec :: ReadPrec [DeleteRoute]
readPrec :: ReadPrec DeleteRoute
$creadPrec :: ReadPrec DeleteRoute
readList :: ReadS [DeleteRoute]
$creadList :: ReadS [DeleteRoute]
readsPrec :: Int -> ReadS DeleteRoute
$creadsPrec :: Int -> ReadS DeleteRoute
Prelude.Read, Int -> DeleteRoute -> ShowS
[DeleteRoute] -> ShowS
DeleteRoute -> String
(Int -> DeleteRoute -> ShowS)
-> (DeleteRoute -> String)
-> ([DeleteRoute] -> ShowS)
-> Show DeleteRoute
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteRoute] -> ShowS
$cshowList :: [DeleteRoute] -> ShowS
show :: DeleteRoute -> String
$cshow :: DeleteRoute -> String
showsPrec :: Int -> DeleteRoute -> ShowS
$cshowsPrec :: Int -> DeleteRoute -> ShowS
Prelude.Show, (forall x. DeleteRoute -> Rep DeleteRoute x)
-> (forall x. Rep DeleteRoute x -> DeleteRoute)
-> Generic DeleteRoute
forall x. Rep DeleteRoute x -> DeleteRoute
forall x. DeleteRoute -> Rep DeleteRoute x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteRoute x -> DeleteRoute
$cfrom :: forall x. DeleteRoute -> Rep DeleteRoute x
Prelude.Generic)
newDeleteRoute ::
Prelude.Text ->
Prelude.Text ->
Prelude.Text ->
DeleteRoute
newDeleteRoute :: Text -> Text -> Text -> DeleteRoute
newDeleteRoute
Text
pMeshName_
Text
pRouteName_
Text
pVirtualRouterName_ =
DeleteRoute' :: Maybe Text -> Text -> Text -> Text -> DeleteRoute
DeleteRoute'
{ $sel:meshOwner:DeleteRoute' :: Maybe Text
meshOwner = Maybe Text
forall a. Maybe a
Prelude.Nothing,
$sel:meshName:DeleteRoute' :: Text
meshName = Text
pMeshName_,
$sel:routeName:DeleteRoute' :: Text
routeName = Text
pRouteName_,
$sel:virtualRouterName:DeleteRoute' :: Text
virtualRouterName = Text
pVirtualRouterName_
}
deleteRoute_meshOwner :: Lens.Lens' DeleteRoute (Prelude.Maybe Prelude.Text)
deleteRoute_meshOwner :: (Maybe Text -> f (Maybe Text)) -> DeleteRoute -> f DeleteRoute
deleteRoute_meshOwner = (DeleteRoute -> Maybe Text)
-> (DeleteRoute -> Maybe Text -> DeleteRoute)
-> Lens DeleteRoute DeleteRoute (Maybe Text) (Maybe Text)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteRoute' {Maybe Text
meshOwner :: Maybe Text
$sel:meshOwner:DeleteRoute' :: DeleteRoute -> Maybe Text
meshOwner} -> Maybe Text
meshOwner) (\s :: DeleteRoute
s@DeleteRoute' {} Maybe Text
a -> DeleteRoute
s {$sel:meshOwner:DeleteRoute' :: Maybe Text
meshOwner = Maybe Text
a} :: DeleteRoute)
deleteRoute_meshName :: Lens.Lens' DeleteRoute Prelude.Text
deleteRoute_meshName :: (Text -> f Text) -> DeleteRoute -> f DeleteRoute
deleteRoute_meshName = (DeleteRoute -> Text)
-> (DeleteRoute -> Text -> DeleteRoute)
-> Lens DeleteRoute DeleteRoute Text Text
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteRoute' {Text
meshName :: Text
$sel:meshName:DeleteRoute' :: DeleteRoute -> Text
meshName} -> Text
meshName) (\s :: DeleteRoute
s@DeleteRoute' {} Text
a -> DeleteRoute
s {$sel:meshName:DeleteRoute' :: Text
meshName = Text
a} :: DeleteRoute)
deleteRoute_routeName :: Lens.Lens' DeleteRoute Prelude.Text
deleteRoute_routeName :: (Text -> f Text) -> DeleteRoute -> f DeleteRoute
deleteRoute_routeName = (DeleteRoute -> Text)
-> (DeleteRoute -> Text -> DeleteRoute)
-> Lens DeleteRoute DeleteRoute Text Text
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteRoute' {Text
routeName :: Text
$sel:routeName:DeleteRoute' :: DeleteRoute -> Text
routeName} -> Text
routeName) (\s :: DeleteRoute
s@DeleteRoute' {} Text
a -> DeleteRoute
s {$sel:routeName:DeleteRoute' :: Text
routeName = Text
a} :: DeleteRoute)
deleteRoute_virtualRouterName :: Lens.Lens' DeleteRoute Prelude.Text
deleteRoute_virtualRouterName :: (Text -> f Text) -> DeleteRoute -> f DeleteRoute
deleteRoute_virtualRouterName = (DeleteRoute -> Text)
-> (DeleteRoute -> Text -> DeleteRoute)
-> Lens DeleteRoute DeleteRoute Text Text
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteRoute' {Text
virtualRouterName :: Text
$sel:virtualRouterName:DeleteRoute' :: DeleteRoute -> Text
virtualRouterName} -> Text
virtualRouterName) (\s :: DeleteRoute
s@DeleteRoute' {} Text
a -> DeleteRoute
s {$sel:virtualRouterName:DeleteRoute' :: Text
virtualRouterName = Text
a} :: DeleteRoute)
instance Core.AWSRequest DeleteRoute where
type AWSResponse DeleteRoute = DeleteRouteResponse
request :: DeleteRoute -> Request DeleteRoute
request = Service -> DeleteRoute -> Request DeleteRoute
forall a. ToRequest a => Service -> a -> Request a
Request.delete Service
defaultService
response :: Logger
-> Service
-> Proxy DeleteRoute
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteRoute)))
response =
(Int
-> ResponseHeaders
-> Object
-> Either String (AWSResponse DeleteRoute))
-> Logger
-> Service
-> Proxy DeleteRoute
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteRoute)))
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> Logger
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
( \Int
s ResponseHeaders
h Object
x ->
Int -> RouteData -> DeleteRouteResponse
DeleteRouteResponse'
(Int -> RouteData -> DeleteRouteResponse)
-> Either String Int
-> Either String (RouteData -> DeleteRouteResponse)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Int -> Either String Int
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (Int -> Int
forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
Either String (RouteData -> DeleteRouteResponse)
-> Either String RouteData -> Either String DeleteRouteResponse
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object -> Either String RouteData
forall a. FromJSON a => Object -> Either String a
Core.eitherParseJSON Object
x)
)
instance Prelude.Hashable DeleteRoute
instance Prelude.NFData DeleteRoute
instance Core.ToHeaders DeleteRoute where
toHeaders :: DeleteRoute -> ResponseHeaders
toHeaders =
ResponseHeaders -> DeleteRoute -> ResponseHeaders
forall a b. a -> b -> a
Prelude.const
( [ResponseHeaders] -> ResponseHeaders
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Content-Type"
HeaderName -> ByteString -> ResponseHeaders
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Core.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Core.ToPath DeleteRoute where
toPath :: DeleteRoute -> ByteString
toPath DeleteRoute' {Maybe Text
Text
virtualRouterName :: Text
routeName :: Text
meshName :: Text
meshOwner :: Maybe Text
$sel:virtualRouterName:DeleteRoute' :: DeleteRoute -> Text
$sel:routeName:DeleteRoute' :: DeleteRoute -> Text
$sel:meshName:DeleteRoute' :: DeleteRoute -> Text
$sel:meshOwner:DeleteRoute' :: DeleteRoute -> Maybe Text
..} =
[ByteString] -> ByteString
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/v20190125/meshes/",
Text -> ByteString
forall a. ToByteString a => a -> ByteString
Core.toBS Text
meshName,
ByteString
"/virtualRouter/",
Text -> ByteString
forall a. ToByteString a => a -> ByteString
Core.toBS Text
virtualRouterName,
ByteString
"/routes/",
Text -> ByteString
forall a. ToByteString a => a -> ByteString
Core.toBS Text
routeName
]
instance Core.ToQuery DeleteRoute where
toQuery :: DeleteRoute -> QueryString
toQuery DeleteRoute' {Maybe Text
Text
virtualRouterName :: Text
routeName :: Text
meshName :: Text
meshOwner :: Maybe Text
$sel:virtualRouterName:DeleteRoute' :: DeleteRoute -> Text
$sel:routeName:DeleteRoute' :: DeleteRoute -> Text
$sel:meshName:DeleteRoute' :: DeleteRoute -> Text
$sel:meshOwner:DeleteRoute' :: DeleteRoute -> Maybe Text
..} =
[QueryString] -> QueryString
forall a. Monoid a => [a] -> a
Prelude.mconcat [ByteString
"meshOwner" ByteString -> Maybe Text -> QueryString
forall a. ToQuery a => ByteString -> a -> QueryString
Core.=: Maybe Text
meshOwner]
data DeleteRouteResponse = DeleteRouteResponse'
{
DeleteRouteResponse -> Int
httpStatus :: Prelude.Int,
DeleteRouteResponse -> RouteData
route :: RouteData
}
deriving (DeleteRouteResponse -> DeleteRouteResponse -> Bool
(DeleteRouteResponse -> DeleteRouteResponse -> Bool)
-> (DeleteRouteResponse -> DeleteRouteResponse -> Bool)
-> Eq DeleteRouteResponse
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteRouteResponse -> DeleteRouteResponse -> Bool
$c/= :: DeleteRouteResponse -> DeleteRouteResponse -> Bool
== :: DeleteRouteResponse -> DeleteRouteResponse -> Bool
$c== :: DeleteRouteResponse -> DeleteRouteResponse -> Bool
Prelude.Eq, ReadPrec [DeleteRouteResponse]
ReadPrec DeleteRouteResponse
Int -> ReadS DeleteRouteResponse
ReadS [DeleteRouteResponse]
(Int -> ReadS DeleteRouteResponse)
-> ReadS [DeleteRouteResponse]
-> ReadPrec DeleteRouteResponse
-> ReadPrec [DeleteRouteResponse]
-> Read DeleteRouteResponse
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteRouteResponse]
$creadListPrec :: ReadPrec [DeleteRouteResponse]
readPrec :: ReadPrec DeleteRouteResponse
$creadPrec :: ReadPrec DeleteRouteResponse
readList :: ReadS [DeleteRouteResponse]
$creadList :: ReadS [DeleteRouteResponse]
readsPrec :: Int -> ReadS DeleteRouteResponse
$creadsPrec :: Int -> ReadS DeleteRouteResponse
Prelude.Read, Int -> DeleteRouteResponse -> ShowS
[DeleteRouteResponse] -> ShowS
DeleteRouteResponse -> String
(Int -> DeleteRouteResponse -> ShowS)
-> (DeleteRouteResponse -> String)
-> ([DeleteRouteResponse] -> ShowS)
-> Show DeleteRouteResponse
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteRouteResponse] -> ShowS
$cshowList :: [DeleteRouteResponse] -> ShowS
show :: DeleteRouteResponse -> String
$cshow :: DeleteRouteResponse -> String
showsPrec :: Int -> DeleteRouteResponse -> ShowS
$cshowsPrec :: Int -> DeleteRouteResponse -> ShowS
Prelude.Show, (forall x. DeleteRouteResponse -> Rep DeleteRouteResponse x)
-> (forall x. Rep DeleteRouteResponse x -> DeleteRouteResponse)
-> Generic DeleteRouteResponse
forall x. Rep DeleteRouteResponse x -> DeleteRouteResponse
forall x. DeleteRouteResponse -> Rep DeleteRouteResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteRouteResponse x -> DeleteRouteResponse
$cfrom :: forall x. DeleteRouteResponse -> Rep DeleteRouteResponse x
Prelude.Generic)
newDeleteRouteResponse ::
Prelude.Int ->
RouteData ->
DeleteRouteResponse
newDeleteRouteResponse :: Int -> RouteData -> DeleteRouteResponse
newDeleteRouteResponse Int
pHttpStatus_ RouteData
pRoute_ =
DeleteRouteResponse' :: Int -> RouteData -> DeleteRouteResponse
DeleteRouteResponse'
{ $sel:httpStatus:DeleteRouteResponse' :: Int
httpStatus = Int
pHttpStatus_,
$sel:route:DeleteRouteResponse' :: RouteData
route = RouteData
pRoute_
}
deleteRouteResponse_httpStatus :: Lens.Lens' DeleteRouteResponse Prelude.Int
deleteRouteResponse_httpStatus :: (Int -> f Int) -> DeleteRouteResponse -> f DeleteRouteResponse
deleteRouteResponse_httpStatus = (DeleteRouteResponse -> Int)
-> (DeleteRouteResponse -> Int -> DeleteRouteResponse)
-> Lens DeleteRouteResponse DeleteRouteResponse Int Int
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteRouteResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteRouteResponse' :: DeleteRouteResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteRouteResponse
s@DeleteRouteResponse' {} Int
a -> DeleteRouteResponse
s {$sel:httpStatus:DeleteRouteResponse' :: Int
httpStatus = Int
a} :: DeleteRouteResponse)
deleteRouteResponse_route :: Lens.Lens' DeleteRouteResponse RouteData
deleteRouteResponse_route :: (RouteData -> f RouteData)
-> DeleteRouteResponse -> f DeleteRouteResponse
deleteRouteResponse_route = (DeleteRouteResponse -> RouteData)
-> (DeleteRouteResponse -> RouteData -> DeleteRouteResponse)
-> Lens DeleteRouteResponse DeleteRouteResponse RouteData RouteData
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteRouteResponse' {RouteData
route :: RouteData
$sel:route:DeleteRouteResponse' :: DeleteRouteResponse -> RouteData
route} -> RouteData
route) (\s :: DeleteRouteResponse
s@DeleteRouteResponse' {} RouteData
a -> DeleteRouteResponse
s {$sel:route:DeleteRouteResponse' :: RouteData
route = RouteData
a} :: DeleteRouteResponse)
instance Prelude.NFData DeleteRouteResponse