{-# 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.AppStream.DeleteImageBuilder
(
DeleteImageBuilder (..),
newDeleteImageBuilder,
deleteImageBuilder_name,
DeleteImageBuilderResponse (..),
newDeleteImageBuilderResponse,
deleteImageBuilderResponse_imageBuilder,
deleteImageBuilderResponse_httpStatus,
)
where
import Amazonka.AppStream.Types
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DeleteImageBuilder = DeleteImageBuilder'
{
DeleteImageBuilder -> Text
name :: Prelude.Text
}
deriving (DeleteImageBuilder -> DeleteImageBuilder -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteImageBuilder -> DeleteImageBuilder -> Bool
$c/= :: DeleteImageBuilder -> DeleteImageBuilder -> Bool
== :: DeleteImageBuilder -> DeleteImageBuilder -> Bool
$c== :: DeleteImageBuilder -> DeleteImageBuilder -> Bool
Prelude.Eq, ReadPrec [DeleteImageBuilder]
ReadPrec DeleteImageBuilder
Int -> ReadS DeleteImageBuilder
ReadS [DeleteImageBuilder]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteImageBuilder]
$creadListPrec :: ReadPrec [DeleteImageBuilder]
readPrec :: ReadPrec DeleteImageBuilder
$creadPrec :: ReadPrec DeleteImageBuilder
readList :: ReadS [DeleteImageBuilder]
$creadList :: ReadS [DeleteImageBuilder]
readsPrec :: Int -> ReadS DeleteImageBuilder
$creadsPrec :: Int -> ReadS DeleteImageBuilder
Prelude.Read, Int -> DeleteImageBuilder -> ShowS
[DeleteImageBuilder] -> ShowS
DeleteImageBuilder -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteImageBuilder] -> ShowS
$cshowList :: [DeleteImageBuilder] -> ShowS
show :: DeleteImageBuilder -> String
$cshow :: DeleteImageBuilder -> String
showsPrec :: Int -> DeleteImageBuilder -> ShowS
$cshowsPrec :: Int -> DeleteImageBuilder -> ShowS
Prelude.Show, forall x. Rep DeleteImageBuilder x -> DeleteImageBuilder
forall x. DeleteImageBuilder -> Rep DeleteImageBuilder x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteImageBuilder x -> DeleteImageBuilder
$cfrom :: forall x. DeleteImageBuilder -> Rep DeleteImageBuilder x
Prelude.Generic)
newDeleteImageBuilder ::
Prelude.Text ->
DeleteImageBuilder
newDeleteImageBuilder :: Text -> DeleteImageBuilder
newDeleteImageBuilder Text
pName_ =
DeleteImageBuilder' {$sel:name:DeleteImageBuilder' :: Text
name = Text
pName_}
deleteImageBuilder_name :: Lens.Lens' DeleteImageBuilder Prelude.Text
deleteImageBuilder_name :: Lens' DeleteImageBuilder Text
deleteImageBuilder_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImageBuilder' {Text
name :: Text
$sel:name:DeleteImageBuilder' :: DeleteImageBuilder -> Text
name} -> Text
name) (\s :: DeleteImageBuilder
s@DeleteImageBuilder' {} Text
a -> DeleteImageBuilder
s {$sel:name:DeleteImageBuilder' :: Text
name = Text
a} :: DeleteImageBuilder)
instance Core.AWSRequest DeleteImageBuilder where
type
AWSResponse DeleteImageBuilder =
DeleteImageBuilderResponse
request :: (Service -> Service)
-> DeleteImageBuilder -> Request DeleteImageBuilder
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 DeleteImageBuilder
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse DeleteImageBuilder)))
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 ImageBuilder -> Int -> DeleteImageBuilderResponse
DeleteImageBuilderResponse'
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
"ImageBuilder")
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 DeleteImageBuilder where
hashWithSalt :: Int -> DeleteImageBuilder -> Int
hashWithSalt Int
_salt DeleteImageBuilder' {Text
name :: Text
$sel:name:DeleteImageBuilder' :: DeleteImageBuilder -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
name
instance Prelude.NFData DeleteImageBuilder where
rnf :: DeleteImageBuilder -> ()
rnf DeleteImageBuilder' {Text
name :: Text
$sel:name:DeleteImageBuilder' :: DeleteImageBuilder -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
name
instance Data.ToHeaders DeleteImageBuilder where
toHeaders :: DeleteImageBuilder -> 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
"PhotonAdminProxyService.DeleteImageBuilder" ::
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 DeleteImageBuilder where
toJSON :: DeleteImageBuilder -> Value
toJSON DeleteImageBuilder' {Text
name :: Text
$sel:name:DeleteImageBuilder' :: DeleteImageBuilder -> 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 DeleteImageBuilder where
toPath :: DeleteImageBuilder -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DeleteImageBuilder where
toQuery :: DeleteImageBuilder -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteImageBuilderResponse = DeleteImageBuilderResponse'
{
DeleteImageBuilderResponse -> Maybe ImageBuilder
imageBuilder :: Prelude.Maybe ImageBuilder,
DeleteImageBuilderResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteImageBuilderResponse -> DeleteImageBuilderResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteImageBuilderResponse -> DeleteImageBuilderResponse -> Bool
$c/= :: DeleteImageBuilderResponse -> DeleteImageBuilderResponse -> Bool
== :: DeleteImageBuilderResponse -> DeleteImageBuilderResponse -> Bool
$c== :: DeleteImageBuilderResponse -> DeleteImageBuilderResponse -> Bool
Prelude.Eq, ReadPrec [DeleteImageBuilderResponse]
ReadPrec DeleteImageBuilderResponse
Int -> ReadS DeleteImageBuilderResponse
ReadS [DeleteImageBuilderResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteImageBuilderResponse]
$creadListPrec :: ReadPrec [DeleteImageBuilderResponse]
readPrec :: ReadPrec DeleteImageBuilderResponse
$creadPrec :: ReadPrec DeleteImageBuilderResponse
readList :: ReadS [DeleteImageBuilderResponse]
$creadList :: ReadS [DeleteImageBuilderResponse]
readsPrec :: Int -> ReadS DeleteImageBuilderResponse
$creadsPrec :: Int -> ReadS DeleteImageBuilderResponse
Prelude.Read, Int -> DeleteImageBuilderResponse -> ShowS
[DeleteImageBuilderResponse] -> ShowS
DeleteImageBuilderResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteImageBuilderResponse] -> ShowS
$cshowList :: [DeleteImageBuilderResponse] -> ShowS
show :: DeleteImageBuilderResponse -> String
$cshow :: DeleteImageBuilderResponse -> String
showsPrec :: Int -> DeleteImageBuilderResponse -> ShowS
$cshowsPrec :: Int -> DeleteImageBuilderResponse -> ShowS
Prelude.Show, forall x.
Rep DeleteImageBuilderResponse x -> DeleteImageBuilderResponse
forall x.
DeleteImageBuilderResponse -> Rep DeleteImageBuilderResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteImageBuilderResponse x -> DeleteImageBuilderResponse
$cfrom :: forall x.
DeleteImageBuilderResponse -> Rep DeleteImageBuilderResponse x
Prelude.Generic)
newDeleteImageBuilderResponse ::
Prelude.Int ->
DeleteImageBuilderResponse
newDeleteImageBuilderResponse :: Int -> DeleteImageBuilderResponse
newDeleteImageBuilderResponse Int
pHttpStatus_ =
DeleteImageBuilderResponse'
{ $sel:imageBuilder:DeleteImageBuilderResponse' :: Maybe ImageBuilder
imageBuilder =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DeleteImageBuilderResponse' :: Int
httpStatus = Int
pHttpStatus_
}
deleteImageBuilderResponse_imageBuilder :: Lens.Lens' DeleteImageBuilderResponse (Prelude.Maybe ImageBuilder)
deleteImageBuilderResponse_imageBuilder :: Lens' DeleteImageBuilderResponse (Maybe ImageBuilder)
deleteImageBuilderResponse_imageBuilder = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImageBuilderResponse' {Maybe ImageBuilder
imageBuilder :: Maybe ImageBuilder
$sel:imageBuilder:DeleteImageBuilderResponse' :: DeleteImageBuilderResponse -> Maybe ImageBuilder
imageBuilder} -> Maybe ImageBuilder
imageBuilder) (\s :: DeleteImageBuilderResponse
s@DeleteImageBuilderResponse' {} Maybe ImageBuilder
a -> DeleteImageBuilderResponse
s {$sel:imageBuilder:DeleteImageBuilderResponse' :: Maybe ImageBuilder
imageBuilder = Maybe ImageBuilder
a} :: DeleteImageBuilderResponse)
deleteImageBuilderResponse_httpStatus :: Lens.Lens' DeleteImageBuilderResponse Prelude.Int
deleteImageBuilderResponse_httpStatus :: Lens' DeleteImageBuilderResponse Int
deleteImageBuilderResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteImageBuilderResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteImageBuilderResponse' :: DeleteImageBuilderResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteImageBuilderResponse
s@DeleteImageBuilderResponse' {} Int
a -> DeleteImageBuilderResponse
s {$sel:httpStatus:DeleteImageBuilderResponse' :: Int
httpStatus = Int
a} :: DeleteImageBuilderResponse)
instance Prelude.NFData DeleteImageBuilderResponse where
rnf :: DeleteImageBuilderResponse -> ()
rnf DeleteImageBuilderResponse' {Int
Maybe ImageBuilder
httpStatus :: Int
imageBuilder :: Maybe ImageBuilder
$sel:httpStatus:DeleteImageBuilderResponse' :: DeleteImageBuilderResponse -> Int
$sel:imageBuilder:DeleteImageBuilderResponse' :: DeleteImageBuilderResponse -> Maybe ImageBuilder
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe ImageBuilder
imageBuilder
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus