{-# 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.BackupGateway.DeleteGateway
(
DeleteGateway (..),
newDeleteGateway,
deleteGateway_gatewayArn,
DeleteGatewayResponse (..),
newDeleteGatewayResponse,
deleteGatewayResponse_gatewayArn,
deleteGatewayResponse_httpStatus,
)
where
import Amazonka.BackupGateway.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 DeleteGateway = DeleteGateway'
{
DeleteGateway -> Text
gatewayArn :: Prelude.Text
}
deriving (DeleteGateway -> DeleteGateway -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteGateway -> DeleteGateway -> Bool
$c/= :: DeleteGateway -> DeleteGateway -> Bool
== :: DeleteGateway -> DeleteGateway -> Bool
$c== :: DeleteGateway -> DeleteGateway -> Bool
Prelude.Eq, ReadPrec [DeleteGateway]
ReadPrec DeleteGateway
Int -> ReadS DeleteGateway
ReadS [DeleteGateway]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteGateway]
$creadListPrec :: ReadPrec [DeleteGateway]
readPrec :: ReadPrec DeleteGateway
$creadPrec :: ReadPrec DeleteGateway
readList :: ReadS [DeleteGateway]
$creadList :: ReadS [DeleteGateway]
readsPrec :: Int -> ReadS DeleteGateway
$creadsPrec :: Int -> ReadS DeleteGateway
Prelude.Read, Int -> DeleteGateway -> ShowS
[DeleteGateway] -> ShowS
DeleteGateway -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteGateway] -> ShowS
$cshowList :: [DeleteGateway] -> ShowS
show :: DeleteGateway -> String
$cshow :: DeleteGateway -> String
showsPrec :: Int -> DeleteGateway -> ShowS
$cshowsPrec :: Int -> DeleteGateway -> ShowS
Prelude.Show, forall x. Rep DeleteGateway x -> DeleteGateway
forall x. DeleteGateway -> Rep DeleteGateway x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteGateway x -> DeleteGateway
$cfrom :: forall x. DeleteGateway -> Rep DeleteGateway x
Prelude.Generic)
newDeleteGateway ::
Prelude.Text ->
DeleteGateway
newDeleteGateway :: Text -> DeleteGateway
newDeleteGateway Text
pGatewayArn_ =
DeleteGateway' {$sel:gatewayArn:DeleteGateway' :: Text
gatewayArn = Text
pGatewayArn_}
deleteGateway_gatewayArn :: Lens.Lens' DeleteGateway Prelude.Text
deleteGateway_gatewayArn :: Lens' DeleteGateway Text
deleteGateway_gatewayArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteGateway' {Text
gatewayArn :: Text
$sel:gatewayArn:DeleteGateway' :: DeleteGateway -> Text
gatewayArn} -> Text
gatewayArn) (\s :: DeleteGateway
s@DeleteGateway' {} Text
a -> DeleteGateway
s {$sel:gatewayArn:DeleteGateway' :: Text
gatewayArn = Text
a} :: DeleteGateway)
instance Core.AWSRequest DeleteGateway where
type
AWSResponse DeleteGateway =
DeleteGatewayResponse
request :: (Service -> Service) -> DeleteGateway -> Request DeleteGateway
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 DeleteGateway
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteGateway)))
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 -> DeleteGatewayResponse
DeleteGatewayResponse'
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
"GatewayArn")
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 DeleteGateway where
hashWithSalt :: Int -> DeleteGateway -> Int
hashWithSalt Int
_salt DeleteGateway' {Text
gatewayArn :: Text
$sel:gatewayArn:DeleteGateway' :: DeleteGateway -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
gatewayArn
instance Prelude.NFData DeleteGateway where
rnf :: DeleteGateway -> ()
rnf DeleteGateway' {Text
gatewayArn :: Text
$sel:gatewayArn:DeleteGateway' :: DeleteGateway -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
gatewayArn
instance Data.ToHeaders DeleteGateway where
toHeaders :: DeleteGateway -> 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
"BackupOnPremises_v20210101.DeleteGateway" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.0" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON DeleteGateway where
toJSON :: DeleteGateway -> Value
toJSON DeleteGateway' {Text
gatewayArn :: Text
$sel:gatewayArn:DeleteGateway' :: DeleteGateway -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[forall a. a -> Maybe a
Prelude.Just (Key
"GatewayArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
gatewayArn)]
)
instance Data.ToPath DeleteGateway where
toPath :: DeleteGateway -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DeleteGateway where
toQuery :: DeleteGateway -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteGatewayResponse = DeleteGatewayResponse'
{
DeleteGatewayResponse -> Maybe Text
gatewayArn :: Prelude.Maybe Prelude.Text,
DeleteGatewayResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteGatewayResponse -> DeleteGatewayResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteGatewayResponse -> DeleteGatewayResponse -> Bool
$c/= :: DeleteGatewayResponse -> DeleteGatewayResponse -> Bool
== :: DeleteGatewayResponse -> DeleteGatewayResponse -> Bool
$c== :: DeleteGatewayResponse -> DeleteGatewayResponse -> Bool
Prelude.Eq, ReadPrec [DeleteGatewayResponse]
ReadPrec DeleteGatewayResponse
Int -> ReadS DeleteGatewayResponse
ReadS [DeleteGatewayResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteGatewayResponse]
$creadListPrec :: ReadPrec [DeleteGatewayResponse]
readPrec :: ReadPrec DeleteGatewayResponse
$creadPrec :: ReadPrec DeleteGatewayResponse
readList :: ReadS [DeleteGatewayResponse]
$creadList :: ReadS [DeleteGatewayResponse]
readsPrec :: Int -> ReadS DeleteGatewayResponse
$creadsPrec :: Int -> ReadS DeleteGatewayResponse
Prelude.Read, Int -> DeleteGatewayResponse -> ShowS
[DeleteGatewayResponse] -> ShowS
DeleteGatewayResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteGatewayResponse] -> ShowS
$cshowList :: [DeleteGatewayResponse] -> ShowS
show :: DeleteGatewayResponse -> String
$cshow :: DeleteGatewayResponse -> String
showsPrec :: Int -> DeleteGatewayResponse -> ShowS
$cshowsPrec :: Int -> DeleteGatewayResponse -> ShowS
Prelude.Show, forall x. Rep DeleteGatewayResponse x -> DeleteGatewayResponse
forall x. DeleteGatewayResponse -> Rep DeleteGatewayResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteGatewayResponse x -> DeleteGatewayResponse
$cfrom :: forall x. DeleteGatewayResponse -> Rep DeleteGatewayResponse x
Prelude.Generic)
newDeleteGatewayResponse ::
Prelude.Int ->
DeleteGatewayResponse
newDeleteGatewayResponse :: Int -> DeleteGatewayResponse
newDeleteGatewayResponse Int
pHttpStatus_ =
DeleteGatewayResponse'
{ $sel:gatewayArn:DeleteGatewayResponse' :: Maybe Text
gatewayArn =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DeleteGatewayResponse' :: Int
httpStatus = Int
pHttpStatus_
}
deleteGatewayResponse_gatewayArn :: Lens.Lens' DeleteGatewayResponse (Prelude.Maybe Prelude.Text)
deleteGatewayResponse_gatewayArn :: Lens' DeleteGatewayResponse (Maybe Text)
deleteGatewayResponse_gatewayArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteGatewayResponse' {Maybe Text
gatewayArn :: Maybe Text
$sel:gatewayArn:DeleteGatewayResponse' :: DeleteGatewayResponse -> Maybe Text
gatewayArn} -> Maybe Text
gatewayArn) (\s :: DeleteGatewayResponse
s@DeleteGatewayResponse' {} Maybe Text
a -> DeleteGatewayResponse
s {$sel:gatewayArn:DeleteGatewayResponse' :: Maybe Text
gatewayArn = Maybe Text
a} :: DeleteGatewayResponse)
deleteGatewayResponse_httpStatus :: Lens.Lens' DeleteGatewayResponse Prelude.Int
deleteGatewayResponse_httpStatus :: Lens' DeleteGatewayResponse Int
deleteGatewayResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteGatewayResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteGatewayResponse' :: DeleteGatewayResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteGatewayResponse
s@DeleteGatewayResponse' {} Int
a -> DeleteGatewayResponse
s {$sel:httpStatus:DeleteGatewayResponse' :: Int
httpStatus = Int
a} :: DeleteGatewayResponse)
instance Prelude.NFData DeleteGatewayResponse where
rnf :: DeleteGatewayResponse -> ()
rnf DeleteGatewayResponse' {Int
Maybe Text
httpStatus :: Int
gatewayArn :: Maybe Text
$sel:httpStatus:DeleteGatewayResponse' :: DeleteGatewayResponse -> Int
$sel:gatewayArn:DeleteGatewayResponse' :: DeleteGatewayResponse -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
gatewayArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus