{-# 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.CloudWatchLogs.DeleteLogStream
(
DeleteLogStream (..),
newDeleteLogStream,
deleteLogStream_logGroupName,
deleteLogStream_logStreamName,
DeleteLogStreamResponse (..),
newDeleteLogStreamResponse,
)
where
import Amazonka.CloudWatchLogs.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 DeleteLogStream = DeleteLogStream'
{
DeleteLogStream -> Text
logGroupName :: Prelude.Text,
DeleteLogStream -> Text
logStreamName :: Prelude.Text
}
deriving (DeleteLogStream -> DeleteLogStream -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteLogStream -> DeleteLogStream -> Bool
$c/= :: DeleteLogStream -> DeleteLogStream -> Bool
== :: DeleteLogStream -> DeleteLogStream -> Bool
$c== :: DeleteLogStream -> DeleteLogStream -> Bool
Prelude.Eq, ReadPrec [DeleteLogStream]
ReadPrec DeleteLogStream
Int -> ReadS DeleteLogStream
ReadS [DeleteLogStream]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteLogStream]
$creadListPrec :: ReadPrec [DeleteLogStream]
readPrec :: ReadPrec DeleteLogStream
$creadPrec :: ReadPrec DeleteLogStream
readList :: ReadS [DeleteLogStream]
$creadList :: ReadS [DeleteLogStream]
readsPrec :: Int -> ReadS DeleteLogStream
$creadsPrec :: Int -> ReadS DeleteLogStream
Prelude.Read, Int -> DeleteLogStream -> ShowS
[DeleteLogStream] -> ShowS
DeleteLogStream -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteLogStream] -> ShowS
$cshowList :: [DeleteLogStream] -> ShowS
show :: DeleteLogStream -> String
$cshow :: DeleteLogStream -> String
showsPrec :: Int -> DeleteLogStream -> ShowS
$cshowsPrec :: Int -> DeleteLogStream -> ShowS
Prelude.Show, forall x. Rep DeleteLogStream x -> DeleteLogStream
forall x. DeleteLogStream -> Rep DeleteLogStream x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteLogStream x -> DeleteLogStream
$cfrom :: forall x. DeleteLogStream -> Rep DeleteLogStream x
Prelude.Generic)
newDeleteLogStream ::
Prelude.Text ->
Prelude.Text ->
DeleteLogStream
newDeleteLogStream :: Text -> Text -> DeleteLogStream
newDeleteLogStream Text
pLogGroupName_ Text
pLogStreamName_ =
DeleteLogStream'
{ $sel:logGroupName:DeleteLogStream' :: Text
logGroupName = Text
pLogGroupName_,
$sel:logStreamName:DeleteLogStream' :: Text
logStreamName = Text
pLogStreamName_
}
deleteLogStream_logGroupName :: Lens.Lens' DeleteLogStream Prelude.Text
deleteLogStream_logGroupName :: Lens' DeleteLogStream Text
deleteLogStream_logGroupName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteLogStream' {Text
logGroupName :: Text
$sel:logGroupName:DeleteLogStream' :: DeleteLogStream -> Text
logGroupName} -> Text
logGroupName) (\s :: DeleteLogStream
s@DeleteLogStream' {} Text
a -> DeleteLogStream
s {$sel:logGroupName:DeleteLogStream' :: Text
logGroupName = Text
a} :: DeleteLogStream)
deleteLogStream_logStreamName :: Lens.Lens' DeleteLogStream Prelude.Text
deleteLogStream_logStreamName :: Lens' DeleteLogStream Text
deleteLogStream_logStreamName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteLogStream' {Text
logStreamName :: Text
$sel:logStreamName:DeleteLogStream' :: DeleteLogStream -> Text
logStreamName} -> Text
logStreamName) (\s :: DeleteLogStream
s@DeleteLogStream' {} Text
a -> DeleteLogStream
s {$sel:logStreamName:DeleteLogStream' :: Text
logStreamName = Text
a} :: DeleteLogStream)
instance Core.AWSRequest DeleteLogStream where
type
AWSResponse DeleteLogStream =
DeleteLogStreamResponse
request :: (Service -> Service) -> DeleteLogStream -> Request DeleteLogStream
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 DeleteLogStream
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteLogStream)))
response =
forall (m :: * -> *) a.
MonadResource m =>
AWSResponse a
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveNull DeleteLogStreamResponse
DeleteLogStreamResponse'
instance Prelude.Hashable DeleteLogStream where
hashWithSalt :: Int -> DeleteLogStream -> Int
hashWithSalt Int
_salt DeleteLogStream' {Text
logStreamName :: Text
logGroupName :: Text
$sel:logStreamName:DeleteLogStream' :: DeleteLogStream -> Text
$sel:logGroupName:DeleteLogStream' :: DeleteLogStream -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
logGroupName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
logStreamName
instance Prelude.NFData DeleteLogStream where
rnf :: DeleteLogStream -> ()
rnf DeleteLogStream' {Text
logStreamName :: Text
logGroupName :: Text
$sel:logStreamName:DeleteLogStream' :: DeleteLogStream -> Text
$sel:logGroupName:DeleteLogStream' :: DeleteLogStream -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
logGroupName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
logStreamName
instance Data.ToHeaders DeleteLogStream where
toHeaders :: DeleteLogStream -> [Header]
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 -> [Header]
Data.=# ( ByteString
"Logs_20140328.DeleteLogStream" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> [Header]
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON DeleteLogStream where
toJSON :: DeleteLogStream -> Value
toJSON DeleteLogStream' {Text
logStreamName :: Text
logGroupName :: Text
$sel:logStreamName:DeleteLogStream' :: DeleteLogStream -> Text
$sel:logGroupName:DeleteLogStream' :: DeleteLogStream -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just (Key
"logGroupName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
logGroupName),
forall a. a -> Maybe a
Prelude.Just
(Key
"logStreamName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
logStreamName)
]
)
instance Data.ToPath DeleteLogStream where
toPath :: DeleteLogStream -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DeleteLogStream where
toQuery :: DeleteLogStream -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteLogStreamResponse = DeleteLogStreamResponse'
{
}
deriving (DeleteLogStreamResponse -> DeleteLogStreamResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteLogStreamResponse -> DeleteLogStreamResponse -> Bool
$c/= :: DeleteLogStreamResponse -> DeleteLogStreamResponse -> Bool
== :: DeleteLogStreamResponse -> DeleteLogStreamResponse -> Bool
$c== :: DeleteLogStreamResponse -> DeleteLogStreamResponse -> Bool
Prelude.Eq, ReadPrec [DeleteLogStreamResponse]
ReadPrec DeleteLogStreamResponse
Int -> ReadS DeleteLogStreamResponse
ReadS [DeleteLogStreamResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteLogStreamResponse]
$creadListPrec :: ReadPrec [DeleteLogStreamResponse]
readPrec :: ReadPrec DeleteLogStreamResponse
$creadPrec :: ReadPrec DeleteLogStreamResponse
readList :: ReadS [DeleteLogStreamResponse]
$creadList :: ReadS [DeleteLogStreamResponse]
readsPrec :: Int -> ReadS DeleteLogStreamResponse
$creadsPrec :: Int -> ReadS DeleteLogStreamResponse
Prelude.Read, Int -> DeleteLogStreamResponse -> ShowS
[DeleteLogStreamResponse] -> ShowS
DeleteLogStreamResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteLogStreamResponse] -> ShowS
$cshowList :: [DeleteLogStreamResponse] -> ShowS
show :: DeleteLogStreamResponse -> String
$cshow :: DeleteLogStreamResponse -> String
showsPrec :: Int -> DeleteLogStreamResponse -> ShowS
$cshowsPrec :: Int -> DeleteLogStreamResponse -> ShowS
Prelude.Show, forall x. Rep DeleteLogStreamResponse x -> DeleteLogStreamResponse
forall x. DeleteLogStreamResponse -> Rep DeleteLogStreamResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteLogStreamResponse x -> DeleteLogStreamResponse
$cfrom :: forall x. DeleteLogStreamResponse -> Rep DeleteLogStreamResponse x
Prelude.Generic)
newDeleteLogStreamResponse ::
DeleteLogStreamResponse
newDeleteLogStreamResponse :: DeleteLogStreamResponse
newDeleteLogStreamResponse = DeleteLogStreamResponse
DeleteLogStreamResponse'
instance Prelude.NFData DeleteLogStreamResponse where
rnf :: DeleteLogStreamResponse -> ()
rnf DeleteLogStreamResponse
_ = ()