{-# 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.CloudWatchEvents.DeleteArchive
(
DeleteArchive (..),
newDeleteArchive,
deleteArchive_archiveName,
DeleteArchiveResponse (..),
newDeleteArchiveResponse,
deleteArchiveResponse_httpStatus,
)
where
import Amazonka.CloudWatchEvents.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 DeleteArchive = DeleteArchive'
{
DeleteArchive -> Text
archiveName :: Prelude.Text
}
deriving (DeleteArchive -> DeleteArchive -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteArchive -> DeleteArchive -> Bool
$c/= :: DeleteArchive -> DeleteArchive -> Bool
== :: DeleteArchive -> DeleteArchive -> Bool
$c== :: DeleteArchive -> DeleteArchive -> Bool
Prelude.Eq, ReadPrec [DeleteArchive]
ReadPrec DeleteArchive
Int -> ReadS DeleteArchive
ReadS [DeleteArchive]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteArchive]
$creadListPrec :: ReadPrec [DeleteArchive]
readPrec :: ReadPrec DeleteArchive
$creadPrec :: ReadPrec DeleteArchive
readList :: ReadS [DeleteArchive]
$creadList :: ReadS [DeleteArchive]
readsPrec :: Int -> ReadS DeleteArchive
$creadsPrec :: Int -> ReadS DeleteArchive
Prelude.Read, Int -> DeleteArchive -> ShowS
[DeleteArchive] -> ShowS
DeleteArchive -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteArchive] -> ShowS
$cshowList :: [DeleteArchive] -> ShowS
show :: DeleteArchive -> String
$cshow :: DeleteArchive -> String
showsPrec :: Int -> DeleteArchive -> ShowS
$cshowsPrec :: Int -> DeleteArchive -> ShowS
Prelude.Show, forall x. Rep DeleteArchive x -> DeleteArchive
forall x. DeleteArchive -> Rep DeleteArchive x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteArchive x -> DeleteArchive
$cfrom :: forall x. DeleteArchive -> Rep DeleteArchive x
Prelude.Generic)
newDeleteArchive ::
Prelude.Text ->
DeleteArchive
newDeleteArchive :: Text -> DeleteArchive
newDeleteArchive Text
pArchiveName_ =
DeleteArchive' {$sel:archiveName:DeleteArchive' :: Text
archiveName = Text
pArchiveName_}
deleteArchive_archiveName :: Lens.Lens' DeleteArchive Prelude.Text
deleteArchive_archiveName :: Lens' DeleteArchive Text
deleteArchive_archiveName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteArchive' {Text
archiveName :: Text
$sel:archiveName:DeleteArchive' :: DeleteArchive -> Text
archiveName} -> Text
archiveName) (\s :: DeleteArchive
s@DeleteArchive' {} Text
a -> DeleteArchive
s {$sel:archiveName:DeleteArchive' :: Text
archiveName = Text
a} :: DeleteArchive)
instance Core.AWSRequest DeleteArchive where
type
AWSResponse DeleteArchive =
DeleteArchiveResponse
request :: (Service -> Service) -> DeleteArchive -> Request DeleteArchive
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 DeleteArchive
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteArchive)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> () -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveEmpty
( \Int
s ResponseHeaders
h ()
x ->
Int -> DeleteArchiveResponse
DeleteArchiveResponse'
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))
)
instance Prelude.Hashable DeleteArchive where
hashWithSalt :: Int -> DeleteArchive -> Int
hashWithSalt Int
_salt DeleteArchive' {Text
archiveName :: Text
$sel:archiveName:DeleteArchive' :: DeleteArchive -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
archiveName
instance Prelude.NFData DeleteArchive where
rnf :: DeleteArchive -> ()
rnf DeleteArchive' {Text
archiveName :: Text
$sel:archiveName:DeleteArchive' :: DeleteArchive -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
archiveName
instance Data.ToHeaders DeleteArchive where
toHeaders :: DeleteArchive -> 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
"AWSEvents.DeleteArchive" :: 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 DeleteArchive where
toJSON :: DeleteArchive -> Value
toJSON DeleteArchive' {Text
archiveName :: Text
$sel:archiveName:DeleteArchive' :: DeleteArchive -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[forall a. a -> Maybe a
Prelude.Just (Key
"ArchiveName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
archiveName)]
)
instance Data.ToPath DeleteArchive where
toPath :: DeleteArchive -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DeleteArchive where
toQuery :: DeleteArchive -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteArchiveResponse = DeleteArchiveResponse'
{
DeleteArchiveResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteArchiveResponse -> DeleteArchiveResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteArchiveResponse -> DeleteArchiveResponse -> Bool
$c/= :: DeleteArchiveResponse -> DeleteArchiveResponse -> Bool
== :: DeleteArchiveResponse -> DeleteArchiveResponse -> Bool
$c== :: DeleteArchiveResponse -> DeleteArchiveResponse -> Bool
Prelude.Eq, ReadPrec [DeleteArchiveResponse]
ReadPrec DeleteArchiveResponse
Int -> ReadS DeleteArchiveResponse
ReadS [DeleteArchiveResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteArchiveResponse]
$creadListPrec :: ReadPrec [DeleteArchiveResponse]
readPrec :: ReadPrec DeleteArchiveResponse
$creadPrec :: ReadPrec DeleteArchiveResponse
readList :: ReadS [DeleteArchiveResponse]
$creadList :: ReadS [DeleteArchiveResponse]
readsPrec :: Int -> ReadS DeleteArchiveResponse
$creadsPrec :: Int -> ReadS DeleteArchiveResponse
Prelude.Read, Int -> DeleteArchiveResponse -> ShowS
[DeleteArchiveResponse] -> ShowS
DeleteArchiveResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteArchiveResponse] -> ShowS
$cshowList :: [DeleteArchiveResponse] -> ShowS
show :: DeleteArchiveResponse -> String
$cshow :: DeleteArchiveResponse -> String
showsPrec :: Int -> DeleteArchiveResponse -> ShowS
$cshowsPrec :: Int -> DeleteArchiveResponse -> ShowS
Prelude.Show, forall x. Rep DeleteArchiveResponse x -> DeleteArchiveResponse
forall x. DeleteArchiveResponse -> Rep DeleteArchiveResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteArchiveResponse x -> DeleteArchiveResponse
$cfrom :: forall x. DeleteArchiveResponse -> Rep DeleteArchiveResponse x
Prelude.Generic)
newDeleteArchiveResponse ::
Prelude.Int ->
DeleteArchiveResponse
newDeleteArchiveResponse :: Int -> DeleteArchiveResponse
newDeleteArchiveResponse Int
pHttpStatus_ =
DeleteArchiveResponse' {$sel:httpStatus:DeleteArchiveResponse' :: Int
httpStatus = Int
pHttpStatus_}
deleteArchiveResponse_httpStatus :: Lens.Lens' DeleteArchiveResponse Prelude.Int
deleteArchiveResponse_httpStatus :: Lens' DeleteArchiveResponse Int
deleteArchiveResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteArchiveResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteArchiveResponse' :: DeleteArchiveResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteArchiveResponse
s@DeleteArchiveResponse' {} Int
a -> DeleteArchiveResponse
s {$sel:httpStatus:DeleteArchiveResponse' :: Int
httpStatus = Int
a} :: DeleteArchiveResponse)
instance Prelude.NFData DeleteArchiveResponse where
rnf :: DeleteArchiveResponse -> ()
rnf DeleteArchiveResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteArchiveResponse' :: DeleteArchiveResponse -> Int
..} =
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus