{-# 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.OpenSearchServerless.DeleteCollection
(
DeleteCollection (..),
newDeleteCollection,
deleteCollection_clientToken,
deleteCollection_id,
DeleteCollectionResponse (..),
newDeleteCollectionResponse,
deleteCollectionResponse_deleteCollectionDetail,
deleteCollectionResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.OpenSearchServerless.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DeleteCollection = DeleteCollection'
{
DeleteCollection -> Maybe Text
clientToken :: Prelude.Maybe Prelude.Text,
DeleteCollection -> Text
id :: Prelude.Text
}
deriving (DeleteCollection -> DeleteCollection -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteCollection -> DeleteCollection -> Bool
$c/= :: DeleteCollection -> DeleteCollection -> Bool
== :: DeleteCollection -> DeleteCollection -> Bool
$c== :: DeleteCollection -> DeleteCollection -> Bool
Prelude.Eq, ReadPrec [DeleteCollection]
ReadPrec DeleteCollection
Int -> ReadS DeleteCollection
ReadS [DeleteCollection]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteCollection]
$creadListPrec :: ReadPrec [DeleteCollection]
readPrec :: ReadPrec DeleteCollection
$creadPrec :: ReadPrec DeleteCollection
readList :: ReadS [DeleteCollection]
$creadList :: ReadS [DeleteCollection]
readsPrec :: Int -> ReadS DeleteCollection
$creadsPrec :: Int -> ReadS DeleteCollection
Prelude.Read, Int -> DeleteCollection -> ShowS
[DeleteCollection] -> ShowS
DeleteCollection -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteCollection] -> ShowS
$cshowList :: [DeleteCollection] -> ShowS
show :: DeleteCollection -> String
$cshow :: DeleteCollection -> String
showsPrec :: Int -> DeleteCollection -> ShowS
$cshowsPrec :: Int -> DeleteCollection -> ShowS
Prelude.Show, forall x. Rep DeleteCollection x -> DeleteCollection
forall x. DeleteCollection -> Rep DeleteCollection x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteCollection x -> DeleteCollection
$cfrom :: forall x. DeleteCollection -> Rep DeleteCollection x
Prelude.Generic)
newDeleteCollection ::
Prelude.Text ->
DeleteCollection
newDeleteCollection :: Text -> DeleteCollection
newDeleteCollection Text
pId_ =
DeleteCollection'
{ $sel:clientToken:DeleteCollection' :: Maybe Text
clientToken = forall a. Maybe a
Prelude.Nothing,
$sel:id:DeleteCollection' :: Text
id = Text
pId_
}
deleteCollection_clientToken :: Lens.Lens' DeleteCollection (Prelude.Maybe Prelude.Text)
deleteCollection_clientToken :: Lens' DeleteCollection (Maybe Text)
deleteCollection_clientToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteCollection' {Maybe Text
clientToken :: Maybe Text
$sel:clientToken:DeleteCollection' :: DeleteCollection -> Maybe Text
clientToken} -> Maybe Text
clientToken) (\s :: DeleteCollection
s@DeleteCollection' {} Maybe Text
a -> DeleteCollection
s {$sel:clientToken:DeleteCollection' :: Maybe Text
clientToken = Maybe Text
a} :: DeleteCollection)
deleteCollection_id :: Lens.Lens' DeleteCollection Prelude.Text
deleteCollection_id :: Lens' DeleteCollection Text
deleteCollection_id = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteCollection' {Text
id :: Text
$sel:id:DeleteCollection' :: DeleteCollection -> Text
id} -> Text
id) (\s :: DeleteCollection
s@DeleteCollection' {} Text
a -> DeleteCollection
s {$sel:id:DeleteCollection' :: Text
id = Text
a} :: DeleteCollection)
instance Core.AWSRequest DeleteCollection where
type
AWSResponse DeleteCollection =
DeleteCollectionResponse
request :: (Service -> Service)
-> DeleteCollection -> Request DeleteCollection
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 DeleteCollection
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteCollection)))
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 DeleteCollectionDetail -> Int -> DeleteCollectionResponse
DeleteCollectionResponse'
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
"deleteCollectionDetail")
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 DeleteCollection where
hashWithSalt :: Int -> DeleteCollection -> Int
hashWithSalt Int
_salt DeleteCollection' {Maybe Text
Text
id :: Text
clientToken :: Maybe Text
$sel:id:DeleteCollection' :: DeleteCollection -> Text
$sel:clientToken:DeleteCollection' :: DeleteCollection -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
clientToken
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
id
instance Prelude.NFData DeleteCollection where
rnf :: DeleteCollection -> ()
rnf DeleteCollection' {Maybe Text
Text
id :: Text
clientToken :: Maybe Text
$sel:id:DeleteCollection' :: DeleteCollection -> Text
$sel:clientToken:DeleteCollection' :: DeleteCollection -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clientToken
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
id
instance Data.ToHeaders DeleteCollection where
toHeaders :: DeleteCollection -> 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
"OpenSearchServerless.DeleteCollection" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.0" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON DeleteCollection where
toJSON :: DeleteCollection -> Value
toJSON DeleteCollection' {Maybe Text
Text
id :: Text
clientToken :: Maybe Text
$sel:id:DeleteCollection' :: DeleteCollection -> Text
$sel:clientToken:DeleteCollection' :: DeleteCollection -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"clientToken" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
clientToken,
forall a. a -> Maybe a
Prelude.Just (Key
"id" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
id)
]
)
instance Data.ToPath DeleteCollection where
toPath :: DeleteCollection -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DeleteCollection where
toQuery :: DeleteCollection -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteCollectionResponse = DeleteCollectionResponse'
{
DeleteCollectionResponse -> Maybe DeleteCollectionDetail
deleteCollectionDetail :: Prelude.Maybe DeleteCollectionDetail,
DeleteCollectionResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteCollectionResponse -> DeleteCollectionResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteCollectionResponse -> DeleteCollectionResponse -> Bool
$c/= :: DeleteCollectionResponse -> DeleteCollectionResponse -> Bool
== :: DeleteCollectionResponse -> DeleteCollectionResponse -> Bool
$c== :: DeleteCollectionResponse -> DeleteCollectionResponse -> Bool
Prelude.Eq, ReadPrec [DeleteCollectionResponse]
ReadPrec DeleteCollectionResponse
Int -> ReadS DeleteCollectionResponse
ReadS [DeleteCollectionResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteCollectionResponse]
$creadListPrec :: ReadPrec [DeleteCollectionResponse]
readPrec :: ReadPrec DeleteCollectionResponse
$creadPrec :: ReadPrec DeleteCollectionResponse
readList :: ReadS [DeleteCollectionResponse]
$creadList :: ReadS [DeleteCollectionResponse]
readsPrec :: Int -> ReadS DeleteCollectionResponse
$creadsPrec :: Int -> ReadS DeleteCollectionResponse
Prelude.Read, Int -> DeleteCollectionResponse -> ShowS
[DeleteCollectionResponse] -> ShowS
DeleteCollectionResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteCollectionResponse] -> ShowS
$cshowList :: [DeleteCollectionResponse] -> ShowS
show :: DeleteCollectionResponse -> String
$cshow :: DeleteCollectionResponse -> String
showsPrec :: Int -> DeleteCollectionResponse -> ShowS
$cshowsPrec :: Int -> DeleteCollectionResponse -> ShowS
Prelude.Show, forall x.
Rep DeleteCollectionResponse x -> DeleteCollectionResponse
forall x.
DeleteCollectionResponse -> Rep DeleteCollectionResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DeleteCollectionResponse x -> DeleteCollectionResponse
$cfrom :: forall x.
DeleteCollectionResponse -> Rep DeleteCollectionResponse x
Prelude.Generic)
newDeleteCollectionResponse ::
Prelude.Int ->
DeleteCollectionResponse
newDeleteCollectionResponse :: Int -> DeleteCollectionResponse
newDeleteCollectionResponse Int
pHttpStatus_ =
DeleteCollectionResponse'
{ $sel:deleteCollectionDetail:DeleteCollectionResponse' :: Maybe DeleteCollectionDetail
deleteCollectionDetail =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DeleteCollectionResponse' :: Int
httpStatus = Int
pHttpStatus_
}
deleteCollectionResponse_deleteCollectionDetail :: Lens.Lens' DeleteCollectionResponse (Prelude.Maybe DeleteCollectionDetail)
deleteCollectionResponse_deleteCollectionDetail :: Lens' DeleteCollectionResponse (Maybe DeleteCollectionDetail)
deleteCollectionResponse_deleteCollectionDetail = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteCollectionResponse' {Maybe DeleteCollectionDetail
deleteCollectionDetail :: Maybe DeleteCollectionDetail
$sel:deleteCollectionDetail:DeleteCollectionResponse' :: DeleteCollectionResponse -> Maybe DeleteCollectionDetail
deleteCollectionDetail} -> Maybe DeleteCollectionDetail
deleteCollectionDetail) (\s :: DeleteCollectionResponse
s@DeleteCollectionResponse' {} Maybe DeleteCollectionDetail
a -> DeleteCollectionResponse
s {$sel:deleteCollectionDetail:DeleteCollectionResponse' :: Maybe DeleteCollectionDetail
deleteCollectionDetail = Maybe DeleteCollectionDetail
a} :: DeleteCollectionResponse)
deleteCollectionResponse_httpStatus :: Lens.Lens' DeleteCollectionResponse Prelude.Int
deleteCollectionResponse_httpStatus :: Lens' DeleteCollectionResponse Int
deleteCollectionResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteCollectionResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteCollectionResponse' :: DeleteCollectionResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteCollectionResponse
s@DeleteCollectionResponse' {} Int
a -> DeleteCollectionResponse
s {$sel:httpStatus:DeleteCollectionResponse' :: Int
httpStatus = Int
a} :: DeleteCollectionResponse)
instance Prelude.NFData DeleteCollectionResponse where
rnf :: DeleteCollectionResponse -> ()
rnf DeleteCollectionResponse' {Int
Maybe DeleteCollectionDetail
httpStatus :: Int
deleteCollectionDetail :: Maybe DeleteCollectionDetail
$sel:httpStatus:DeleteCollectionResponse' :: DeleteCollectionResponse -> Int
$sel:deleteCollectionDetail:DeleteCollectionResponse' :: DeleteCollectionResponse -> Maybe DeleteCollectionDetail
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe DeleteCollectionDetail
deleteCollectionDetail
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus