{-# 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.ElasticTranscoder.UpdatePipelineStatus
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- The UpdatePipelineStatus operation pauses or reactivates a pipeline, so
-- that the pipeline stops or restarts the processing of jobs.
--
-- Changing the pipeline status is useful if you want to cancel one or more
-- jobs. You can\'t cancel jobs after Elastic Transcoder has started
-- processing them; if you pause the pipeline to which you submitted the
-- jobs, you have more time to get the job IDs for the jobs that you want
-- to cancel, and to send a CancelJob request.
module Amazonka.ElasticTranscoder.UpdatePipelineStatus
  ( -- * Creating a Request
    UpdatePipelineStatus (..),
    newUpdatePipelineStatus,

    -- * Request Lenses
    updatePipelineStatus_id,
    updatePipelineStatus_status,

    -- * Destructuring the Response
    UpdatePipelineStatusResponse (..),
    newUpdatePipelineStatusResponse,

    -- * Response Lenses
    updatePipelineStatusResponse_pipeline,
    updatePipelineStatusResponse_httpStatus,
  )
where

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

-- | The @UpdatePipelineStatusRequest@ structure.
--
-- /See:/ 'newUpdatePipelineStatus' smart constructor.
data UpdatePipelineStatus = UpdatePipelineStatus'
  { -- | The identifier of the pipeline to update.
    UpdatePipelineStatus -> Text
id :: Prelude.Text,
    -- | The desired status of the pipeline:
    --
    -- -   @Active@: The pipeline is processing jobs.
    --
    -- -   @Paused@: The pipeline is not currently processing jobs.
    UpdatePipelineStatus -> Text
status :: Prelude.Text
  }
  deriving (UpdatePipelineStatus -> UpdatePipelineStatus -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdatePipelineStatus -> UpdatePipelineStatus -> Bool
$c/= :: UpdatePipelineStatus -> UpdatePipelineStatus -> Bool
== :: UpdatePipelineStatus -> UpdatePipelineStatus -> Bool
$c== :: UpdatePipelineStatus -> UpdatePipelineStatus -> Bool
Prelude.Eq, ReadPrec [UpdatePipelineStatus]
ReadPrec UpdatePipelineStatus
Int -> ReadS UpdatePipelineStatus
ReadS [UpdatePipelineStatus]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdatePipelineStatus]
$creadListPrec :: ReadPrec [UpdatePipelineStatus]
readPrec :: ReadPrec UpdatePipelineStatus
$creadPrec :: ReadPrec UpdatePipelineStatus
readList :: ReadS [UpdatePipelineStatus]
$creadList :: ReadS [UpdatePipelineStatus]
readsPrec :: Int -> ReadS UpdatePipelineStatus
$creadsPrec :: Int -> ReadS UpdatePipelineStatus
Prelude.Read, Int -> UpdatePipelineStatus -> ShowS
[UpdatePipelineStatus] -> ShowS
UpdatePipelineStatus -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdatePipelineStatus] -> ShowS
$cshowList :: [UpdatePipelineStatus] -> ShowS
show :: UpdatePipelineStatus -> String
$cshow :: UpdatePipelineStatus -> String
showsPrec :: Int -> UpdatePipelineStatus -> ShowS
$cshowsPrec :: Int -> UpdatePipelineStatus -> ShowS
Prelude.Show, forall x. Rep UpdatePipelineStatus x -> UpdatePipelineStatus
forall x. UpdatePipelineStatus -> Rep UpdatePipelineStatus x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdatePipelineStatus x -> UpdatePipelineStatus
$cfrom :: forall x. UpdatePipelineStatus -> Rep UpdatePipelineStatus x
Prelude.Generic)

-- |
-- Create a value of 'UpdatePipelineStatus' 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:
--
-- 'id', 'updatePipelineStatus_id' - The identifier of the pipeline to update.
--
-- 'status', 'updatePipelineStatus_status' - The desired status of the pipeline:
--
-- -   @Active@: The pipeline is processing jobs.
--
-- -   @Paused@: The pipeline is not currently processing jobs.
newUpdatePipelineStatus ::
  -- | 'id'
  Prelude.Text ->
  -- | 'status'
  Prelude.Text ->
  UpdatePipelineStatus
newUpdatePipelineStatus :: Text -> Text -> UpdatePipelineStatus
newUpdatePipelineStatus Text
pId_ Text
pStatus_ =
  UpdatePipelineStatus' {$sel:id:UpdatePipelineStatus' :: Text
id = Text
pId_, $sel:status:UpdatePipelineStatus' :: Text
status = Text
pStatus_}

-- | The identifier of the pipeline to update.
updatePipelineStatus_id :: Lens.Lens' UpdatePipelineStatus Prelude.Text
updatePipelineStatus_id :: Lens' UpdatePipelineStatus Text
updatePipelineStatus_id = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdatePipelineStatus' {Text
id :: Text
$sel:id:UpdatePipelineStatus' :: UpdatePipelineStatus -> Text
id} -> Text
id) (\s :: UpdatePipelineStatus
s@UpdatePipelineStatus' {} Text
a -> UpdatePipelineStatus
s {$sel:id:UpdatePipelineStatus' :: Text
id = Text
a} :: UpdatePipelineStatus)

-- | The desired status of the pipeline:
--
-- -   @Active@: The pipeline is processing jobs.
--
-- -   @Paused@: The pipeline is not currently processing jobs.
updatePipelineStatus_status :: Lens.Lens' UpdatePipelineStatus Prelude.Text
updatePipelineStatus_status :: Lens' UpdatePipelineStatus Text
updatePipelineStatus_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdatePipelineStatus' {Text
status :: Text
$sel:status:UpdatePipelineStatus' :: UpdatePipelineStatus -> Text
status} -> Text
status) (\s :: UpdatePipelineStatus
s@UpdatePipelineStatus' {} Text
a -> UpdatePipelineStatus
s {$sel:status:UpdatePipelineStatus' :: Text
status = Text
a} :: UpdatePipelineStatus)

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

instance Prelude.NFData UpdatePipelineStatus where
  rnf :: UpdatePipelineStatus -> ()
rnf UpdatePipelineStatus' {Text
status :: Text
id :: Text
$sel:status:UpdatePipelineStatus' :: UpdatePipelineStatus -> Text
$sel:id:UpdatePipelineStatus' :: UpdatePipelineStatus -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
id seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
status

instance Data.ToHeaders UpdatePipelineStatus where
  toHeaders :: UpdatePipelineStatus -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

instance Data.ToJSON UpdatePipelineStatus where
  toJSON :: UpdatePipelineStatus -> Value
toJSON UpdatePipelineStatus' {Text
status :: Text
id :: Text
$sel:status:UpdatePipelineStatus' :: UpdatePipelineStatus -> Text
$sel:id:UpdatePipelineStatus' :: UpdatePipelineStatus -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [forall a. a -> Maybe a
Prelude.Just (Key
"Status" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
status)]
      )

instance Data.ToPath UpdatePipelineStatus where
  toPath :: UpdatePipelineStatus -> ByteString
toPath UpdatePipelineStatus' {Text
status :: Text
id :: Text
$sel:status:UpdatePipelineStatus' :: UpdatePipelineStatus -> Text
$sel:id:UpdatePipelineStatus' :: UpdatePipelineStatus -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ByteString
"/2012-09-25/pipelines/", forall a. ToByteString a => a -> ByteString
Data.toBS Text
id, ByteString
"/status"]

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

-- | When you update status for a pipeline, Elastic Transcoder returns the
-- values that you specified in the request.
--
-- /See:/ 'newUpdatePipelineStatusResponse' smart constructor.
data UpdatePipelineStatusResponse = UpdatePipelineStatusResponse'
  { -- | A section of the response body that provides information about the
    -- pipeline.
    UpdatePipelineStatusResponse -> Maybe Pipeline
pipeline :: Prelude.Maybe Pipeline,
    -- | The response's http status code.
    UpdatePipelineStatusResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (UpdatePipelineStatusResponse
-> UpdatePipelineStatusResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdatePipelineStatusResponse
-> UpdatePipelineStatusResponse -> Bool
$c/= :: UpdatePipelineStatusResponse
-> UpdatePipelineStatusResponse -> Bool
== :: UpdatePipelineStatusResponse
-> UpdatePipelineStatusResponse -> Bool
$c== :: UpdatePipelineStatusResponse
-> UpdatePipelineStatusResponse -> Bool
Prelude.Eq, ReadPrec [UpdatePipelineStatusResponse]
ReadPrec UpdatePipelineStatusResponse
Int -> ReadS UpdatePipelineStatusResponse
ReadS [UpdatePipelineStatusResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdatePipelineStatusResponse]
$creadListPrec :: ReadPrec [UpdatePipelineStatusResponse]
readPrec :: ReadPrec UpdatePipelineStatusResponse
$creadPrec :: ReadPrec UpdatePipelineStatusResponse
readList :: ReadS [UpdatePipelineStatusResponse]
$creadList :: ReadS [UpdatePipelineStatusResponse]
readsPrec :: Int -> ReadS UpdatePipelineStatusResponse
$creadsPrec :: Int -> ReadS UpdatePipelineStatusResponse
Prelude.Read, Int -> UpdatePipelineStatusResponse -> ShowS
[UpdatePipelineStatusResponse] -> ShowS
UpdatePipelineStatusResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdatePipelineStatusResponse] -> ShowS
$cshowList :: [UpdatePipelineStatusResponse] -> ShowS
show :: UpdatePipelineStatusResponse -> String
$cshow :: UpdatePipelineStatusResponse -> String
showsPrec :: Int -> UpdatePipelineStatusResponse -> ShowS
$cshowsPrec :: Int -> UpdatePipelineStatusResponse -> ShowS
Prelude.Show, forall x.
Rep UpdatePipelineStatusResponse x -> UpdatePipelineStatusResponse
forall x.
UpdatePipelineStatusResponse -> Rep UpdatePipelineStatusResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep UpdatePipelineStatusResponse x -> UpdatePipelineStatusResponse
$cfrom :: forall x.
UpdatePipelineStatusResponse -> Rep UpdatePipelineStatusResponse x
Prelude.Generic)

-- |
-- Create a value of 'UpdatePipelineStatusResponse' 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:
--
-- 'pipeline', 'updatePipelineStatusResponse_pipeline' - A section of the response body that provides information about the
-- pipeline.
--
-- 'httpStatus', 'updatePipelineStatusResponse_httpStatus' - The response's http status code.
newUpdatePipelineStatusResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  UpdatePipelineStatusResponse
newUpdatePipelineStatusResponse :: Int -> UpdatePipelineStatusResponse
newUpdatePipelineStatusResponse Int
pHttpStatus_ =
  UpdatePipelineStatusResponse'
    { $sel:pipeline:UpdatePipelineStatusResponse' :: Maybe Pipeline
pipeline =
        forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:UpdatePipelineStatusResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | A section of the response body that provides information about the
-- pipeline.
updatePipelineStatusResponse_pipeline :: Lens.Lens' UpdatePipelineStatusResponse (Prelude.Maybe Pipeline)
updatePipelineStatusResponse_pipeline :: Lens' UpdatePipelineStatusResponse (Maybe Pipeline)
updatePipelineStatusResponse_pipeline = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdatePipelineStatusResponse' {Maybe Pipeline
pipeline :: Maybe Pipeline
$sel:pipeline:UpdatePipelineStatusResponse' :: UpdatePipelineStatusResponse -> Maybe Pipeline
pipeline} -> Maybe Pipeline
pipeline) (\s :: UpdatePipelineStatusResponse
s@UpdatePipelineStatusResponse' {} Maybe Pipeline
a -> UpdatePipelineStatusResponse
s {$sel:pipeline:UpdatePipelineStatusResponse' :: Maybe Pipeline
pipeline = Maybe Pipeline
a} :: UpdatePipelineStatusResponse)

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

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