{-# 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.Glue.StopTrigger
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Stops a specified trigger.
module Amazonka.Glue.StopTrigger
  ( -- * Creating a Request
    StopTrigger (..),
    newStopTrigger,

    -- * Request Lenses
    stopTrigger_name,

    -- * Destructuring the Response
    StopTriggerResponse (..),
    newStopTriggerResponse,

    -- * Response Lenses
    stopTriggerResponse_name,
    stopTriggerResponse_httpStatus,
  )
where

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

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

-- |
-- Create a value of 'StopTrigger' 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', 'stopTrigger_name' - The name of the trigger to stop.
newStopTrigger ::
  -- | 'name'
  Prelude.Text ->
  StopTrigger
newStopTrigger :: Text -> StopTrigger
newStopTrigger Text
pName_ = StopTrigger' {$sel:name:StopTrigger' :: Text
name = Text
pName_}

-- | The name of the trigger to stop.
stopTrigger_name :: Lens.Lens' StopTrigger Prelude.Text
stopTrigger_name :: Lens' StopTrigger Text
stopTrigger_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StopTrigger' {Text
name :: Text
$sel:name:StopTrigger' :: StopTrigger -> Text
name} -> Text
name) (\s :: StopTrigger
s@StopTrigger' {} Text
a -> StopTrigger
s {$sel:name:StopTrigger' :: Text
name = Text
a} :: StopTrigger)

instance Core.AWSRequest StopTrigger where
  type AWSResponse StopTrigger = StopTriggerResponse
  request :: (Service -> Service) -> StopTrigger -> Request StopTrigger
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 StopTrigger
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse StopTrigger)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Maybe Text -> Int -> StopTriggerResponse
StopTriggerResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"Name")
            forall (f :: * -> *) a b. Applicative f => 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 StopTrigger where
  hashWithSalt :: Int -> StopTrigger -> Int
hashWithSalt Int
_salt StopTrigger' {Text
name :: Text
$sel:name:StopTrigger' :: StopTrigger -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
name

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

instance Data.ToHeaders StopTrigger where
  toHeaders :: StopTrigger -> 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
"AWSGlue.StopTrigger" :: 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 StopTrigger where
  toJSON :: StopTrigger -> Value
toJSON StopTrigger' {Text
name :: Text
$sel:name:StopTrigger' :: StopTrigger -> 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 StopTrigger where
  toPath :: StopTrigger -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

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

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

-- |
-- Create a value of 'StopTriggerResponse' 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', 'stopTriggerResponse_name' - The name of the trigger that was stopped.
--
-- 'httpStatus', 'stopTriggerResponse_httpStatus' - The response's http status code.
newStopTriggerResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  StopTriggerResponse
newStopTriggerResponse :: Int -> StopTriggerResponse
newStopTriggerResponse Int
pHttpStatus_ =
  StopTriggerResponse'
    { $sel:name:StopTriggerResponse' :: Maybe Text
name = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:StopTriggerResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The name of the trigger that was stopped.
stopTriggerResponse_name :: Lens.Lens' StopTriggerResponse (Prelude.Maybe Prelude.Text)
stopTriggerResponse_name :: Lens' StopTriggerResponse (Maybe Text)
stopTriggerResponse_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StopTriggerResponse' {Maybe Text
name :: Maybe Text
$sel:name:StopTriggerResponse' :: StopTriggerResponse -> Maybe Text
name} -> Maybe Text
name) (\s :: StopTriggerResponse
s@StopTriggerResponse' {} Maybe Text
a -> StopTriggerResponse
s {$sel:name:StopTriggerResponse' :: Maybe Text
name = Maybe Text
a} :: StopTriggerResponse)

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

instance Prelude.NFData StopTriggerResponse where
  rnf :: StopTriggerResponse -> ()
rnf StopTriggerResponse' {Int
Maybe Text
httpStatus :: Int
name :: Maybe Text
$sel:httpStatus:StopTriggerResponse' :: StopTriggerResponse -> Int
$sel:name:StopTriggerResponse' :: StopTriggerResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
name
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus