{-# 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 #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.CloudWatchLogs.DeleteLogStream
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Deletes the specified log stream and permanently deletes all the
-- archived log events associated with the log stream.
module Amazonka.CloudWatchLogs.DeleteLogStream
  ( -- * Creating a Request
    DeleteLogStream (..),
    newDeleteLogStream,

    -- * Request Lenses
    deleteLogStream_logGroupName,
    deleteLogStream_logStreamName,

    -- * Destructuring the Response
    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

-- | /See:/ 'newDeleteLogStream' smart constructor.
data DeleteLogStream = DeleteLogStream'
  { -- | The name of the log group.
    DeleteLogStream -> Text
logGroupName :: Prelude.Text,
    -- | The name of the log stream.
    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)

-- |
-- Create a value of 'DeleteLogStream' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'logGroupName', 'deleteLogStream_logGroupName' - The name of the log group.
--
-- 'logStreamName', 'deleteLogStream_logStreamName' - The name of the log stream.
newDeleteLogStream ::
  -- | 'logGroupName'
  Prelude.Text ->
  -- | 'logStreamName'
  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_
    }

-- | The name of the log group.
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)

-- | The name of the log stream.
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

-- | /See:/ 'newDeleteLogStreamResponse' smart constructor.
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)

-- |
-- Create a value of 'DeleteLogStreamResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
newDeleteLogStreamResponse ::
  DeleteLogStreamResponse
newDeleteLogStreamResponse :: DeleteLogStreamResponse
newDeleteLogStreamResponse = DeleteLogStreamResponse
DeleteLogStreamResponse'

instance Prelude.NFData DeleteLogStreamResponse where
  rnf :: DeleteLogStreamResponse -> ()
rnf DeleteLogStreamResponse
_ = ()