{-# 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.ImageBuilder.DeleteImage
(
DeleteImage (..),
newDeleteImage,
deleteImage_imageBuildVersionArn,
DeleteImageResponse (..),
newDeleteImageResponse,
deleteImageResponse_imageBuildVersionArn,
deleteImageResponse_requestId,
deleteImageResponse_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
data DeleteImage = DeleteImage'
{
DeleteImage -> Text
imageBuildVersionArn :: Prelude.Text
}
deriving (DeleteImage -> DeleteImage -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteImage -> DeleteImage -> Bool
$c/= :: DeleteImage -> DeleteImage -> Bool
== :: DeleteImage -> DeleteImage -> Bool
$c== :: DeleteImage -> DeleteImage -> Bool
Prelude.Eq, ReadPrec [DeleteImage]
ReadPrec DeleteImage
Int -> ReadS DeleteImage
ReadS [DeleteImage]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteImage]
$creadListPrec :: ReadPrec [DeleteImage]
readPrec :: ReadPrec DeleteImage
$creadPrec :: ReadPrec DeleteImage
readList :: ReadS [DeleteImage]
$creadList :: ReadS [DeleteImage]
readsPrec :: Int -> ReadS DeleteImage
$creadsPrec :: Int -> ReadS DeleteImage
Prelude.Read, Int -> DeleteImage -> ShowS
[DeleteImage] -> ShowS
DeleteImage -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteImage] -> ShowS
$cshowList :: [DeleteImage] -> ShowS
show :: DeleteImage -> String
$cshow :: DeleteImage -> String
showsPrec :: Int -> DeleteImage -> ShowS
$cshowsPrec :: Int -> DeleteImage -> ShowS
Prelude.Show, forall x. Rep DeleteImage x -> DeleteImage
forall x. DeleteImage -> Rep DeleteImage x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteImage x -> DeleteImage
$cfrom :: forall x. DeleteImage -> Rep DeleteImage x
Prelude.Generic)
newDeleteImage ::
Prelude.Text ->
DeleteImage
newDeleteImage :: Text -> DeleteImage
newDeleteImage Text
pImageBuildVersionArn_ =
DeleteImage'
{ $sel:imageBuildVersionArn:DeleteImage' :: Text
imageBuildVersionArn =
Text
pImageBuildVersionArn_
}
deleteImage_imageBuildVersionArn :: Lens.Lens' DeleteImage Prelude.Text
deleteImage_imageBuildVersionArn :: Lens' DeleteImage Text
deleteImage_imageBuildVersionArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImage' {Text
imageBuildVersionArn :: Text
$sel:imageBuildVersionArn:DeleteImage' :: DeleteImage -> Text
imageBuildVersionArn} -> Text
imageBuildVersionArn) (\s :: DeleteImage
s@DeleteImage' {} Text
a -> DeleteImage
s {$sel:imageBuildVersionArn:DeleteImage' :: Text
imageBuildVersionArn = Text
a} :: DeleteImage)
instance Core.AWSRequest DeleteImage where
type AWSResponse DeleteImage = DeleteImageResponse
request :: (Service -> Service) -> DeleteImage -> Request DeleteImage
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 DeleteImage
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteImage)))
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 -> DeleteImageResponse
DeleteImageResponse'
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
"imageBuildVersionArn")
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 DeleteImage where
hashWithSalt :: Int -> DeleteImage -> Int
hashWithSalt Int
_salt DeleteImage' {Text
imageBuildVersionArn :: Text
$sel:imageBuildVersionArn:DeleteImage' :: DeleteImage -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
imageBuildVersionArn
instance Prelude.NFData DeleteImage where
rnf :: DeleteImage -> ()
rnf DeleteImage' {Text
imageBuildVersionArn :: Text
$sel:imageBuildVersionArn:DeleteImage' :: DeleteImage -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
imageBuildVersionArn
instance Data.ToHeaders DeleteImage where
toHeaders :: DeleteImage -> 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 DeleteImage where
toPath :: DeleteImage -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/DeleteImage"
instance Data.ToQuery DeleteImage where
toQuery :: DeleteImage -> QueryString
toQuery DeleteImage' {Text
imageBuildVersionArn :: Text
$sel:imageBuildVersionArn:DeleteImage' :: DeleteImage -> Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ByteString
"imageBuildVersionArn" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
imageBuildVersionArn]
data DeleteImageResponse = DeleteImageResponse'
{
DeleteImageResponse -> Maybe Text
imageBuildVersionArn :: Prelude.Maybe Prelude.Text,
DeleteImageResponse -> Maybe Text
requestId :: Prelude.Maybe Prelude.Text,
DeleteImageResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteImageResponse -> DeleteImageResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteImageResponse -> DeleteImageResponse -> Bool
$c/= :: DeleteImageResponse -> DeleteImageResponse -> Bool
== :: DeleteImageResponse -> DeleteImageResponse -> Bool
$c== :: DeleteImageResponse -> DeleteImageResponse -> Bool
Prelude.Eq, ReadPrec [DeleteImageResponse]
ReadPrec DeleteImageResponse
Int -> ReadS DeleteImageResponse
ReadS [DeleteImageResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteImageResponse]
$creadListPrec :: ReadPrec [DeleteImageResponse]
readPrec :: ReadPrec DeleteImageResponse
$creadPrec :: ReadPrec DeleteImageResponse
readList :: ReadS [DeleteImageResponse]
$creadList :: ReadS [DeleteImageResponse]
readsPrec :: Int -> ReadS DeleteImageResponse
$creadsPrec :: Int -> ReadS DeleteImageResponse
Prelude.Read, Int -> DeleteImageResponse -> ShowS
[DeleteImageResponse] -> ShowS
DeleteImageResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteImageResponse] -> ShowS
$cshowList :: [DeleteImageResponse] -> ShowS
show :: DeleteImageResponse -> String
$cshow :: DeleteImageResponse -> String
showsPrec :: Int -> DeleteImageResponse -> ShowS
$cshowsPrec :: Int -> DeleteImageResponse -> ShowS
Prelude.Show, forall x. Rep DeleteImageResponse x -> DeleteImageResponse
forall x. DeleteImageResponse -> Rep DeleteImageResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteImageResponse x -> DeleteImageResponse
$cfrom :: forall x. DeleteImageResponse -> Rep DeleteImageResponse x
Prelude.Generic)
newDeleteImageResponse ::
Prelude.Int ->
DeleteImageResponse
newDeleteImageResponse :: Int -> DeleteImageResponse
newDeleteImageResponse Int
pHttpStatus_ =
DeleteImageResponse'
{ $sel:imageBuildVersionArn:DeleteImageResponse' :: Maybe Text
imageBuildVersionArn =
forall a. Maybe a
Prelude.Nothing,
$sel:requestId:DeleteImageResponse' :: Maybe Text
requestId = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DeleteImageResponse' :: Int
httpStatus = Int
pHttpStatus_
}
deleteImageResponse_imageBuildVersionArn :: Lens.Lens' DeleteImageResponse (Prelude.Maybe Prelude.Text)
deleteImageResponse_imageBuildVersionArn :: Lens' DeleteImageResponse (Maybe Text)
deleteImageResponse_imageBuildVersionArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImageResponse' {Maybe Text
imageBuildVersionArn :: Maybe Text
$sel:imageBuildVersionArn:DeleteImageResponse' :: DeleteImageResponse -> Maybe Text
imageBuildVersionArn} -> Maybe Text
imageBuildVersionArn) (\s :: DeleteImageResponse
s@DeleteImageResponse' {} Maybe Text
a -> DeleteImageResponse
s {$sel:imageBuildVersionArn:DeleteImageResponse' :: Maybe Text
imageBuildVersionArn = Maybe Text
a} :: DeleteImageResponse)
deleteImageResponse_requestId :: Lens.Lens' DeleteImageResponse (Prelude.Maybe Prelude.Text)
deleteImageResponse_requestId :: Lens' DeleteImageResponse (Maybe Text)
deleteImageResponse_requestId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImageResponse' {Maybe Text
requestId :: Maybe Text
$sel:requestId:DeleteImageResponse' :: DeleteImageResponse -> Maybe Text
requestId} -> Maybe Text
requestId) (\s :: DeleteImageResponse
s@DeleteImageResponse' {} Maybe Text
a -> DeleteImageResponse
s {$sel:requestId:DeleteImageResponse' :: Maybe Text
requestId = Maybe Text
a} :: DeleteImageResponse)
deleteImageResponse_httpStatus :: Lens.Lens' DeleteImageResponse Prelude.Int
deleteImageResponse_httpStatus :: Lens' DeleteImageResponse Int
deleteImageResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImageResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteImageResponse' :: DeleteImageResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteImageResponse
s@DeleteImageResponse' {} Int
a -> DeleteImageResponse
s {$sel:httpStatus:DeleteImageResponse' :: Int
httpStatus = Int
a} :: DeleteImageResponse)
instance Prelude.NFData DeleteImageResponse where
rnf :: DeleteImageResponse -> ()
rnf DeleteImageResponse' {Int
Maybe Text
httpStatus :: Int
requestId :: Maybe Text
imageBuildVersionArn :: Maybe Text
$sel:httpStatus:DeleteImageResponse' :: DeleteImageResponse -> Int
$sel:requestId:DeleteImageResponse' :: DeleteImageResponse -> Maybe Text
$sel:imageBuildVersionArn:DeleteImageResponse' :: DeleteImageResponse -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
imageBuildVersionArn
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