{-# 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.FraudDetector.DeleteDetector
(
DeleteDetector (..),
newDeleteDetector,
deleteDetector_detectorId,
DeleteDetectorResponse (..),
newDeleteDetectorResponse,
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.FraudDetector.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DeleteDetector = DeleteDetector'
{
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)
newDeleteDetector ::
Prelude.Text ->
DeleteDetector
newDeleteDetector :: Text -> DeleteDetector
newDeleteDetector Text
pDetectorId_ =
DeleteDetector' {$sel:detectorId:DeleteDetector' :: Text
detectorId = Text
pDetectorId_}
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, ToJSON a) => Service -> a -> Request a
Request.postJSON (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
"X-Amz-Target"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"AWSHawksNestServiceFacade.DeleteDetector" ::
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 DeleteDetector where
toJSON :: DeleteDetector -> Value
toJSON DeleteDetector' {Text
detectorId :: Text
$sel:detectorId:DeleteDetector' :: DeleteDetector -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[forall a. a -> Maybe a
Prelude.Just (Key
"detectorId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
detectorId)]
)
instance Data.ToPath DeleteDetector where
toPath :: DeleteDetector -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DeleteDetector where
toQuery :: DeleteDetector -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteDetectorResponse = DeleteDetectorResponse'
{
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)
newDeleteDetectorResponse ::
Prelude.Int ->
DeleteDetectorResponse
newDeleteDetectorResponse :: Int -> DeleteDetectorResponse
newDeleteDetectorResponse Int
pHttpStatus_ =
DeleteDetectorResponse' {$sel:httpStatus:DeleteDetectorResponse' :: Int
httpStatus = Int
pHttpStatus_}
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