{-# 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.GuardDuty.DeleteDetector
-- 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 an Amazon GuardDuty detector that is specified by the detector
-- ID.
module Amazonka.GuardDuty.DeleteDetector
  ( -- * Creating a Request
    DeleteDetector (..),
    newDeleteDetector,

    -- * Request Lenses
    deleteDetector_detectorId,

    -- * Destructuring the Response
    DeleteDetectorResponse (..),
    newDeleteDetectorResponse,

    -- * Response Lenses
    deleteDetectorResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.GuardDuty.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newDeleteDetector' smart constructor.
data DeleteDetector = DeleteDetector'
  { -- | The unique ID of the detector that you want to delete.
    DeleteDetector -> Text
detectorId :: Prelude.Text
  }
  deriving (DeleteDetector -> DeleteDetector -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteDetector -> DeleteDetector -> Bool
$c/= :: DeleteDetector -> DeleteDetector -> Bool
== :: DeleteDetector -> DeleteDetector -> Bool
$c== :: DeleteDetector -> DeleteDetector -> Bool
Prelude.Eq, ReadPrec [DeleteDetector]
ReadPrec DeleteDetector
Int -> ReadS DeleteDetector
ReadS [DeleteDetector]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteDetector]
$creadListPrec :: ReadPrec [DeleteDetector]
readPrec :: ReadPrec DeleteDetector
$creadPrec :: ReadPrec DeleteDetector
readList :: ReadS [DeleteDetector]
$creadList :: ReadS [DeleteDetector]
readsPrec :: Int -> ReadS DeleteDetector
$creadsPrec :: Int -> ReadS DeleteDetector
Prelude.Read, Int -> DeleteDetector -> ShowS
[DeleteDetector] -> ShowS
DeleteDetector -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteDetector] -> ShowS
$cshowList :: [DeleteDetector] -> ShowS
show :: DeleteDetector -> String
$cshow :: DeleteDetector -> String
showsPrec :: Int -> DeleteDetector -> ShowS
$cshowsPrec :: Int -> DeleteDetector -> ShowS
Prelude.Show, forall x. Rep DeleteDetector x -> DeleteDetector
forall x. DeleteDetector -> Rep DeleteDetector x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteDetector x -> DeleteDetector
$cfrom :: forall x. DeleteDetector -> Rep DeleteDetector x
Prelude.Generic)

-- |
-- Create a value of 'DeleteDetector' 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:
--
-- 'detectorId', 'deleteDetector_detectorId' - The unique ID of the detector that you want to delete.
newDeleteDetector ::
  -- | 'detectorId'
  Prelude.Text ->
  DeleteDetector
newDeleteDetector :: Text -> DeleteDetector
newDeleteDetector Text
pDetectorId_ =
  DeleteDetector' {$sel:detectorId:DeleteDetector' :: Text
detectorId = Text
pDetectorId_}

-- | The unique ID of the detector that you want to delete.
deleteDetector_detectorId :: Lens.Lens' DeleteDetector Prelude.Text
deleteDetector_detectorId :: Lens' DeleteDetector Text
deleteDetector_detectorId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteDetector' {Text
detectorId :: Text
$sel:detectorId:DeleteDetector' :: DeleteDetector -> Text
detectorId} -> Text
detectorId) (\s :: DeleteDetector
s@DeleteDetector' {} Text
a -> DeleteDetector
s {$sel:detectorId:DeleteDetector' :: Text
detectorId = Text
a} :: DeleteDetector)

instance Core.AWSRequest DeleteDetector where
  type
    AWSResponse DeleteDetector =
      DeleteDetectorResponse
  request :: (Service -> Service) -> DeleteDetector -> Request DeleteDetector
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.delete (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DeleteDetector
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteDetector)))
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 -> DeleteDetectorResponse
DeleteDetectorResponse'
            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 DeleteDetector where
  hashWithSalt :: Int -> DeleteDetector -> Int
hashWithSalt Int
_salt DeleteDetector' {Text
detectorId :: Text
$sel:detectorId:DeleteDetector' :: DeleteDetector -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
detectorId

instance Prelude.NFData DeleteDetector where
  rnf :: DeleteDetector -> ()
rnf DeleteDetector' {Text
detectorId :: Text
$sel:detectorId:DeleteDetector' :: DeleteDetector -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
detectorId

instance Data.ToHeaders DeleteDetector where
  toHeaders :: DeleteDetector -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToPath DeleteDetector where
  toPath :: DeleteDetector -> ByteString
toPath DeleteDetector' {Text
detectorId :: Text
$sel:detectorId:DeleteDetector' :: DeleteDetector -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ByteString
"/detector/", forall a. ToByteString a => a -> ByteString
Data.toBS Text
detectorId]

instance Data.ToQuery DeleteDetector where
  toQuery :: DeleteDetector -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newDeleteDetectorResponse' smart constructor.
data DeleteDetectorResponse = DeleteDetectorResponse'
  { -- | The response's http status code.
    DeleteDetectorResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DeleteDetectorResponse -> DeleteDetectorResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteDetectorResponse -> DeleteDetectorResponse -> Bool
$c/= :: DeleteDetectorResponse -> DeleteDetectorResponse -> Bool
== :: DeleteDetectorResponse -> DeleteDetectorResponse -> Bool
$c== :: DeleteDetectorResponse -> DeleteDetectorResponse -> Bool
Prelude.Eq, ReadPrec [DeleteDetectorResponse]
ReadPrec DeleteDetectorResponse
Int -> ReadS DeleteDetectorResponse
ReadS [DeleteDetectorResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteDetectorResponse]
$creadListPrec :: ReadPrec [DeleteDetectorResponse]
readPrec :: ReadPrec DeleteDetectorResponse
$creadPrec :: ReadPrec DeleteDetectorResponse
readList :: ReadS [DeleteDetectorResponse]
$creadList :: ReadS [DeleteDetectorResponse]
readsPrec :: Int -> ReadS DeleteDetectorResponse
$creadsPrec :: Int -> ReadS DeleteDetectorResponse
Prelude.Read, Int -> DeleteDetectorResponse -> ShowS
[DeleteDetectorResponse] -> ShowS
DeleteDetectorResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteDetectorResponse] -> ShowS
$cshowList :: [DeleteDetectorResponse] -> ShowS
show :: DeleteDetectorResponse -> String
$cshow :: DeleteDetectorResponse -> String
showsPrec :: Int -> DeleteDetectorResponse -> ShowS
$cshowsPrec :: Int -> DeleteDetectorResponse -> ShowS
Prelude.Show, forall x. Rep DeleteDetectorResponse x -> DeleteDetectorResponse
forall x. DeleteDetectorResponse -> Rep DeleteDetectorResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteDetectorResponse x -> DeleteDetectorResponse
$cfrom :: forall x. DeleteDetectorResponse -> Rep DeleteDetectorResponse x
Prelude.Generic)

-- |
-- Create a value of 'DeleteDetectorResponse' 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:
--
-- 'httpStatus', 'deleteDetectorResponse_httpStatus' - The response's http status code.
newDeleteDetectorResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DeleteDetectorResponse
newDeleteDetectorResponse :: Int -> DeleteDetectorResponse
newDeleteDetectorResponse Int
pHttpStatus_ =
  DeleteDetectorResponse' {$sel:httpStatus:DeleteDetectorResponse' :: Int
httpStatus = Int
pHttpStatus_}

-- | The response's http status code.
deleteDetectorResponse_httpStatus :: Lens.Lens' DeleteDetectorResponse Prelude.Int
deleteDetectorResponse_httpStatus :: Lens' DeleteDetectorResponse Int
deleteDetectorResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteDetectorResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteDetectorResponse' :: DeleteDetectorResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteDetectorResponse
s@DeleteDetectorResponse' {} Int
a -> DeleteDetectorResponse
s {$sel:httpStatus:DeleteDetectorResponse' :: Int
httpStatus = Int
a} :: DeleteDetectorResponse)

instance Prelude.NFData DeleteDetectorResponse where
  rnf :: DeleteDetectorResponse -> ()
rnf DeleteDetectorResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteDetectorResponse' :: DeleteDetectorResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus