{-# 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.FraudDetector.DeleteLabel
-- 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 a label.
--
-- You cannot delete labels that are included in an event type in Amazon
-- Fraud Detector.
--
-- You cannot delete a label assigned to an event ID. You must first delete
-- the relevant event ID.
--
-- When you delete a label, Amazon Fraud Detector permanently deletes that
-- label and the data is no longer stored in Amazon Fraud Detector.
module Amazonka.FraudDetector.DeleteLabel
  ( -- * Creating a Request
    DeleteLabel (..),
    newDeleteLabel,

    -- * Request Lenses
    deleteLabel_name,

    -- * Destructuring the Response
    DeleteLabelResponse (..),
    newDeleteLabelResponse,

    -- * Response Lenses
    deleteLabelResponse_httpStatus,
  )
where

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

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

-- |
-- Create a value of 'DeleteLabel' 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:
--
-- 'name', 'deleteLabel_name' - The name of the label to delete.
newDeleteLabel ::
  -- | 'name'
  Prelude.Text ->
  DeleteLabel
newDeleteLabel :: Text -> DeleteLabel
newDeleteLabel Text
pName_ = DeleteLabel' {$sel:name:DeleteLabel' :: Text
name = Text
pName_}

-- | The name of the label to delete.
deleteLabel_name :: Lens.Lens' DeleteLabel Prelude.Text
deleteLabel_name :: Lens' DeleteLabel Text
deleteLabel_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteLabel' {Text
name :: Text
$sel:name:DeleteLabel' :: DeleteLabel -> Text
name} -> Text
name) (\s :: DeleteLabel
s@DeleteLabel' {} Text
a -> DeleteLabel
s {$sel:name:DeleteLabel' :: Text
name = Text
a} :: DeleteLabel)

instance Core.AWSRequest DeleteLabel where
  type AWSResponse DeleteLabel = DeleteLabelResponse
  request :: (Service -> Service) -> DeleteLabel -> Request DeleteLabel
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 DeleteLabel
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteLabel)))
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 -> DeleteLabelResponse
DeleteLabelResponse'
            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 DeleteLabel where
  hashWithSalt :: Int -> DeleteLabel -> Int
hashWithSalt Int
_salt DeleteLabel' {Text
name :: Text
$sel:name:DeleteLabel' :: DeleteLabel -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
name

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

instance Data.ToHeaders DeleteLabel where
  toHeaders :: DeleteLabel -> 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
"AWSHawksNestServiceFacade.DeleteLabel" ::
                          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 DeleteLabel where
  toJSON :: DeleteLabel -> Value
toJSON DeleteLabel' {Text
name :: Text
$sel:name:DeleteLabel' :: DeleteLabel -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [forall a. a -> Maybe a
Prelude.Just (Key
"name" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
name)]
      )

instance Data.ToPath DeleteLabel where
  toPath :: DeleteLabel -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

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

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

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

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

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