{-# 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.OpenSearch.DeleteDomain
(
DeleteDomain (..),
newDeleteDomain,
deleteDomain_domainName,
DeleteDomainResponse (..),
newDeleteDomainResponse,
deleteDomainResponse_domainStatus,
deleteDomainResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.OpenSearch.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DeleteDomain = DeleteDomain'
{
DeleteDomain -> Text
domainName :: Prelude.Text
}
deriving (DeleteDomain -> DeleteDomain -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteDomain -> DeleteDomain -> Bool
$c/= :: DeleteDomain -> DeleteDomain -> Bool
== :: DeleteDomain -> DeleteDomain -> Bool
$c== :: DeleteDomain -> DeleteDomain -> Bool
Prelude.Eq, ReadPrec [DeleteDomain]
ReadPrec DeleteDomain
Int -> ReadS DeleteDomain
ReadS [DeleteDomain]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteDomain]
$creadListPrec :: ReadPrec [DeleteDomain]
readPrec :: ReadPrec DeleteDomain
$creadPrec :: ReadPrec DeleteDomain
readList :: ReadS [DeleteDomain]
$creadList :: ReadS [DeleteDomain]
readsPrec :: Int -> ReadS DeleteDomain
$creadsPrec :: Int -> ReadS DeleteDomain
Prelude.Read, Int -> DeleteDomain -> ShowS
[DeleteDomain] -> ShowS
DeleteDomain -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteDomain] -> ShowS
$cshowList :: [DeleteDomain] -> ShowS
show :: DeleteDomain -> String
$cshow :: DeleteDomain -> String
showsPrec :: Int -> DeleteDomain -> ShowS
$cshowsPrec :: Int -> DeleteDomain -> ShowS
Prelude.Show, forall x. Rep DeleteDomain x -> DeleteDomain
forall x. DeleteDomain -> Rep DeleteDomain x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteDomain x -> DeleteDomain
$cfrom :: forall x. DeleteDomain -> Rep DeleteDomain x
Prelude.Generic)
newDeleteDomain ::
Prelude.Text ->
DeleteDomain
newDeleteDomain :: Text -> DeleteDomain
newDeleteDomain Text
pDomainName_ =
DeleteDomain' {$sel:domainName:DeleteDomain' :: Text
domainName = Text
pDomainName_}
deleteDomain_domainName :: Lens.Lens' DeleteDomain Prelude.Text
deleteDomain_domainName :: Lens' DeleteDomain Text
deleteDomain_domainName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteDomain' {Text
domainName :: Text
$sel:domainName:DeleteDomain' :: DeleteDomain -> Text
domainName} -> Text
domainName) (\s :: DeleteDomain
s@DeleteDomain' {} Text
a -> DeleteDomain
s {$sel:domainName:DeleteDomain' :: Text
domainName = Text
a} :: DeleteDomain)
instance Core.AWSRequest DeleteDomain where
type AWSResponse DeleteDomain = DeleteDomainResponse
request :: (Service -> Service) -> DeleteDomain -> Request DeleteDomain
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 DeleteDomain
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DeleteDomain)))
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 DomainStatus -> Int -> DeleteDomainResponse
DeleteDomainResponse'
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
"DomainStatus")
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 DeleteDomain where
hashWithSalt :: Int -> DeleteDomain -> Int
hashWithSalt Int
_salt DeleteDomain' {Text
domainName :: Text
$sel:domainName:DeleteDomain' :: DeleteDomain -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
domainName
instance Prelude.NFData DeleteDomain where
rnf :: DeleteDomain -> ()
rnf DeleteDomain' {Text
domainName :: Text
$sel:domainName:DeleteDomain' :: DeleteDomain -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
domainName
instance Data.ToHeaders DeleteDomain where
toHeaders :: DeleteDomain -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
instance Data.ToPath DeleteDomain where
toPath :: DeleteDomain -> ByteString
toPath DeleteDomain' {Text
domainName :: Text
$sel:domainName:DeleteDomain' :: DeleteDomain -> Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/2021-01-01/opensearch/domain/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
domainName
]
instance Data.ToQuery DeleteDomain where
toQuery :: DeleteDomain -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DeleteDomainResponse = DeleteDomainResponse'
{
DeleteDomainResponse -> Maybe DomainStatus
domainStatus :: Prelude.Maybe DomainStatus,
DeleteDomainResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DeleteDomainResponse -> DeleteDomainResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeleteDomainResponse -> DeleteDomainResponse -> Bool
$c/= :: DeleteDomainResponse -> DeleteDomainResponse -> Bool
== :: DeleteDomainResponse -> DeleteDomainResponse -> Bool
$c== :: DeleteDomainResponse -> DeleteDomainResponse -> Bool
Prelude.Eq, ReadPrec [DeleteDomainResponse]
ReadPrec DeleteDomainResponse
Int -> ReadS DeleteDomainResponse
ReadS [DeleteDomainResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeleteDomainResponse]
$creadListPrec :: ReadPrec [DeleteDomainResponse]
readPrec :: ReadPrec DeleteDomainResponse
$creadPrec :: ReadPrec DeleteDomainResponse
readList :: ReadS [DeleteDomainResponse]
$creadList :: ReadS [DeleteDomainResponse]
readsPrec :: Int -> ReadS DeleteDomainResponse
$creadsPrec :: Int -> ReadS DeleteDomainResponse
Prelude.Read, Int -> DeleteDomainResponse -> ShowS
[DeleteDomainResponse] -> ShowS
DeleteDomainResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeleteDomainResponse] -> ShowS
$cshowList :: [DeleteDomainResponse] -> ShowS
show :: DeleteDomainResponse -> String
$cshow :: DeleteDomainResponse -> String
showsPrec :: Int -> DeleteDomainResponse -> ShowS
$cshowsPrec :: Int -> DeleteDomainResponse -> ShowS
Prelude.Show, forall x. Rep DeleteDomainResponse x -> DeleteDomainResponse
forall x. DeleteDomainResponse -> Rep DeleteDomainResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeleteDomainResponse x -> DeleteDomainResponse
$cfrom :: forall x. DeleteDomainResponse -> Rep DeleteDomainResponse x
Prelude.Generic)
newDeleteDomainResponse ::
Prelude.Int ->
DeleteDomainResponse
newDeleteDomainResponse :: Int -> DeleteDomainResponse
newDeleteDomainResponse Int
pHttpStatus_ =
DeleteDomainResponse'
{ $sel:domainStatus:DeleteDomainResponse' :: Maybe DomainStatus
domainStatus =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DeleteDomainResponse' :: Int
httpStatus = Int
pHttpStatus_
}
deleteDomainResponse_domainStatus :: Lens.Lens' DeleteDomainResponse (Prelude.Maybe DomainStatus)
deleteDomainResponse_domainStatus :: Lens' DeleteDomainResponse (Maybe DomainStatus)
deleteDomainResponse_domainStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteDomainResponse' {Maybe DomainStatus
domainStatus :: Maybe DomainStatus
$sel:domainStatus:DeleteDomainResponse' :: DeleteDomainResponse -> Maybe DomainStatus
domainStatus} -> Maybe DomainStatus
domainStatus) (\s :: DeleteDomainResponse
s@DeleteDomainResponse' {} Maybe DomainStatus
a -> DeleteDomainResponse
s {$sel:domainStatus:DeleteDomainResponse' :: Maybe DomainStatus
domainStatus = Maybe DomainStatus
a} :: DeleteDomainResponse)
deleteDomainResponse_httpStatus :: Lens.Lens' DeleteDomainResponse Prelude.Int
deleteDomainResponse_httpStatus :: Lens' DeleteDomainResponse Int
deleteDomainResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeleteDomainResponse' {Int
httpStatus :: Int
$sel:httpStatus:DeleteDomainResponse' :: DeleteDomainResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DeleteDomainResponse
s@DeleteDomainResponse' {} Int
a -> DeleteDomainResponse
s {$sel:httpStatus:DeleteDomainResponse' :: Int
httpStatus = Int
a} :: DeleteDomainResponse)
instance Prelude.NFData DeleteDomainResponse where
rnf :: DeleteDomainResponse -> ()
rnf DeleteDomainResponse' {Int
Maybe DomainStatus
httpStatus :: Int
domainStatus :: Maybe DomainStatus
$sel:httpStatus:DeleteDomainResponse' :: DeleteDomainResponse -> Int
$sel:domainStatus:DeleteDomainResponse' :: DeleteDomainResponse -> Maybe DomainStatus
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe DomainStatus
domainStatus
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus