{-# 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.ImageBuilder.DeleteImagePipeline
-- 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 image pipeline.
module Amazonka.ImageBuilder.DeleteImagePipeline
  ( -- * Creating a Request
    DeleteImagePipeline (..),
    newDeleteImagePipeline,

    -- * Request Lenses
    deleteImagePipeline_imagePipelineArn,

    -- * Destructuring the Response
    DeleteImagePipelineResponse (..),
    newDeleteImagePipelineResponse,

    -- * Response Lenses
    deleteImagePipelineResponse_imagePipelineArn,
    deleteImagePipelineResponse_requestId,
    deleteImagePipelineResponse_httpStatus,
  )
where

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

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

-- |
-- Create a value of 'DeleteImagePipeline' 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:
--
-- 'imagePipelineArn', 'deleteImagePipeline_imagePipelineArn' - The Amazon Resource Name (ARN) of the image pipeline to delete.
newDeleteImagePipeline ::
  -- | 'imagePipelineArn'
  Prelude.Text ->
  DeleteImagePipeline
newDeleteImagePipeline :: Text -> DeleteImagePipeline
newDeleteImagePipeline Text
pImagePipelineArn_ =
  DeleteImagePipeline'
    { $sel:imagePipelineArn:DeleteImagePipeline' :: Text
imagePipelineArn =
        Text
pImagePipelineArn_
    }

-- | The Amazon Resource Name (ARN) of the image pipeline to delete.
deleteImagePipeline_imagePipelineArn :: Lens.Lens' DeleteImagePipeline Prelude.Text
deleteImagePipeline_imagePipelineArn :: Lens' DeleteImagePipeline Text
deleteImagePipeline_imagePipelineArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImagePipeline' {Text
imagePipelineArn :: Text
$sel:imagePipelineArn:DeleteImagePipeline' :: DeleteImagePipeline -> Text
imagePipelineArn} -> Text
imagePipelineArn) (\s :: DeleteImagePipeline
s@DeleteImagePipeline' {} Text
a -> DeleteImagePipeline
s {$sel:imagePipelineArn:DeleteImagePipeline' :: Text
imagePipelineArn = Text
a} :: DeleteImagePipeline)

instance Core.AWSRequest DeleteImagePipeline where
  type
    AWSResponse DeleteImagePipeline =
      DeleteImagePipelineResponse
  request :: (Service -> Service)
-> DeleteImagePipeline -> Request DeleteImagePipeline
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 DeleteImagePipeline
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DeleteImagePipeline)))
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 -> Maybe Text -> Int -> DeleteImagePipelineResponse
DeleteImagePipelineResponse'
            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
"imagePipelineArn")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"requestId")
            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 DeleteImagePipeline where
  hashWithSalt :: Int -> DeleteImagePipeline -> Int
hashWithSalt Int
_salt DeleteImagePipeline' {Text
imagePipelineArn :: Text
$sel:imagePipelineArn:DeleteImagePipeline' :: DeleteImagePipeline -> Text
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
imagePipelineArn

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

instance Data.ToHeaders DeleteImagePipeline where
  toHeaders :: DeleteImagePipeline -> 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 DeleteImagePipeline where
  toPath :: DeleteImagePipeline -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/DeleteImagePipeline"

instance Data.ToQuery DeleteImagePipeline where
  toQuery :: DeleteImagePipeline -> QueryString
toQuery DeleteImagePipeline' {Text
imagePipelineArn :: Text
$sel:imagePipelineArn:DeleteImagePipeline' :: DeleteImagePipeline -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ByteString
"imagePipelineArn" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
imagePipelineArn]

-- | /See:/ 'newDeleteImagePipelineResponse' smart constructor.
data DeleteImagePipelineResponse = DeleteImagePipelineResponse'
  { -- | The Amazon Resource Name (ARN) of the image pipeline that was deleted.
    DeleteImagePipelineResponse -> Maybe Text
imagePipelineArn :: Prelude.Maybe Prelude.Text,
    -- | The request ID that uniquely identifies this request.
    DeleteImagePipelineResponse -> Maybe Text
requestId :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    DeleteImagePipelineResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DeleteImagePipelineResponse -> DeleteImagePipelineResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteImagePipelineResponse -> DeleteImagePipelineResponse -> Bool
$c/= :: DeleteImagePipelineResponse -> DeleteImagePipelineResponse -> Bool
== :: DeleteImagePipelineResponse -> DeleteImagePipelineResponse -> Bool
$c== :: DeleteImagePipelineResponse -> DeleteImagePipelineResponse -> Bool
Prelude.Eq, ReadPrec [DeleteImagePipelineResponse]
ReadPrec DeleteImagePipelineResponse
Int -> ReadS DeleteImagePipelineResponse
ReadS [DeleteImagePipelineResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteImagePipelineResponse]
$creadListPrec :: ReadPrec [DeleteImagePipelineResponse]
readPrec :: ReadPrec DeleteImagePipelineResponse
$creadPrec :: ReadPrec DeleteImagePipelineResponse
readList :: ReadS [DeleteImagePipelineResponse]
$creadList :: ReadS [DeleteImagePipelineResponse]
readsPrec :: Int -> ReadS DeleteImagePipelineResponse
$creadsPrec :: Int -> ReadS DeleteImagePipelineResponse
Prelude.Read, Int -> DeleteImagePipelineResponse -> ShowS
[DeleteImagePipelineResponse] -> ShowS
DeleteImagePipelineResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteImagePipelineResponse] -> ShowS
$cshowList :: [DeleteImagePipelineResponse] -> ShowS
show :: DeleteImagePipelineResponse -> String
$cshow :: DeleteImagePipelineResponse -> String
showsPrec :: Int -> DeleteImagePipelineResponse -> ShowS
$cshowsPrec :: Int -> DeleteImagePipelineResponse -> ShowS
Prelude.Show, forall x.
Rep DeleteImagePipelineResponse x -> DeleteImagePipelineResponse
forall x.
DeleteImagePipelineResponse -> Rep DeleteImagePipelineResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteImagePipelineResponse x -> DeleteImagePipelineResponse
$cfrom :: forall x.
DeleteImagePipelineResponse -> Rep DeleteImagePipelineResponse x
Prelude.Generic)

-- |
-- Create a value of 'DeleteImagePipelineResponse' 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:
--
-- 'imagePipelineArn', 'deleteImagePipelineResponse_imagePipelineArn' - The Amazon Resource Name (ARN) of the image pipeline that was deleted.
--
-- 'requestId', 'deleteImagePipelineResponse_requestId' - The request ID that uniquely identifies this request.
--
-- 'httpStatus', 'deleteImagePipelineResponse_httpStatus' - The response's http status code.
newDeleteImagePipelineResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DeleteImagePipelineResponse
newDeleteImagePipelineResponse :: Int -> DeleteImagePipelineResponse
newDeleteImagePipelineResponse Int
pHttpStatus_ =
  DeleteImagePipelineResponse'
    { $sel:imagePipelineArn:DeleteImagePipelineResponse' :: Maybe Text
imagePipelineArn =
        forall a. Maybe a
Prelude.Nothing,
      $sel:requestId:DeleteImagePipelineResponse' :: Maybe Text
requestId = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DeleteImagePipelineResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The Amazon Resource Name (ARN) of the image pipeline that was deleted.
deleteImagePipelineResponse_imagePipelineArn :: Lens.Lens' DeleteImagePipelineResponse (Prelude.Maybe Prelude.Text)
deleteImagePipelineResponse_imagePipelineArn :: Lens' DeleteImagePipelineResponse (Maybe Text)
deleteImagePipelineResponse_imagePipelineArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImagePipelineResponse' {Maybe Text
imagePipelineArn :: Maybe Text
$sel:imagePipelineArn:DeleteImagePipelineResponse' :: DeleteImagePipelineResponse -> Maybe Text
imagePipelineArn} -> Maybe Text
imagePipelineArn) (\s :: DeleteImagePipelineResponse
s@DeleteImagePipelineResponse' {} Maybe Text
a -> DeleteImagePipelineResponse
s {$sel:imagePipelineArn:DeleteImagePipelineResponse' :: Maybe Text
imagePipelineArn = Maybe Text
a} :: DeleteImagePipelineResponse)

-- | The request ID that uniquely identifies this request.
deleteImagePipelineResponse_requestId :: Lens.Lens' DeleteImagePipelineResponse (Prelude.Maybe Prelude.Text)
deleteImagePipelineResponse_requestId :: Lens' DeleteImagePipelineResponse (Maybe Text)
deleteImagePipelineResponse_requestId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImagePipelineResponse' {Maybe Text
requestId :: Maybe Text
$sel:requestId:DeleteImagePipelineResponse' :: DeleteImagePipelineResponse -> Maybe Text
requestId} -> Maybe Text
requestId) (\s :: DeleteImagePipelineResponse
s@DeleteImagePipelineResponse' {} Maybe Text
a -> DeleteImagePipelineResponse
s {$sel:requestId:DeleteImagePipelineResponse' :: Maybe Text
requestId = Maybe Text
a} :: DeleteImagePipelineResponse)

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

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