{-# 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.ElasticSearch.RevokeVpcEndpointAccess
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Revokes access to an Amazon OpenSearch Service domain that was provided
-- through an interface VPC endpoint.
module Amazonka.ElasticSearch.RevokeVpcEndpointAccess
  ( -- * Creating a Request
    RevokeVpcEndpointAccess (..),
    newRevokeVpcEndpointAccess,

    -- * Request Lenses
    revokeVpcEndpointAccess_domainName,
    revokeVpcEndpointAccess_account,

    -- * Destructuring the Response
    RevokeVpcEndpointAccessResponse (..),
    newRevokeVpcEndpointAccessResponse,

    -- * Response Lenses
    revokeVpcEndpointAccessResponse_httpStatus,
  )
where

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

-- | Revokes access to an Amazon OpenSearch Service domain that was provided
-- through an interface VPC endpoint.
--
-- /See:/ 'newRevokeVpcEndpointAccess' smart constructor.
data RevokeVpcEndpointAccess = RevokeVpcEndpointAccess'
  { -- | The name of the OpenSearch Service domain.
    RevokeVpcEndpointAccess -> Text
domainName :: Prelude.Text,
    -- | The account ID to revoke access from.
    RevokeVpcEndpointAccess -> Text
account :: Prelude.Text
  }
  deriving (RevokeVpcEndpointAccess -> RevokeVpcEndpointAccess -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: RevokeVpcEndpointAccess -> RevokeVpcEndpointAccess -> Bool
$c/= :: RevokeVpcEndpointAccess -> RevokeVpcEndpointAccess -> Bool
== :: RevokeVpcEndpointAccess -> RevokeVpcEndpointAccess -> Bool
$c== :: RevokeVpcEndpointAccess -> RevokeVpcEndpointAccess -> Bool
Prelude.Eq, ReadPrec [RevokeVpcEndpointAccess]
ReadPrec RevokeVpcEndpointAccess
Int -> ReadS RevokeVpcEndpointAccess
ReadS [RevokeVpcEndpointAccess]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [RevokeVpcEndpointAccess]
$creadListPrec :: ReadPrec [RevokeVpcEndpointAccess]
readPrec :: ReadPrec RevokeVpcEndpointAccess
$creadPrec :: ReadPrec RevokeVpcEndpointAccess
readList :: ReadS [RevokeVpcEndpointAccess]
$creadList :: ReadS [RevokeVpcEndpointAccess]
readsPrec :: Int -> ReadS RevokeVpcEndpointAccess
$creadsPrec :: Int -> ReadS RevokeVpcEndpointAccess
Prelude.Read, Int -> RevokeVpcEndpointAccess -> ShowS
[RevokeVpcEndpointAccess] -> ShowS
RevokeVpcEndpointAccess -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [RevokeVpcEndpointAccess] -> ShowS
$cshowList :: [RevokeVpcEndpointAccess] -> ShowS
show :: RevokeVpcEndpointAccess -> String
$cshow :: RevokeVpcEndpointAccess -> String
showsPrec :: Int -> RevokeVpcEndpointAccess -> ShowS
$cshowsPrec :: Int -> RevokeVpcEndpointAccess -> ShowS
Prelude.Show, forall x. Rep RevokeVpcEndpointAccess x -> RevokeVpcEndpointAccess
forall x. RevokeVpcEndpointAccess -> Rep RevokeVpcEndpointAccess x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep RevokeVpcEndpointAccess x -> RevokeVpcEndpointAccess
$cfrom :: forall x. RevokeVpcEndpointAccess -> Rep RevokeVpcEndpointAccess x
Prelude.Generic)

-- |
-- Create a value of 'RevokeVpcEndpointAccess' 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:
--
-- 'domainName', 'revokeVpcEndpointAccess_domainName' - The name of the OpenSearch Service domain.
--
-- 'account', 'revokeVpcEndpointAccess_account' - The account ID to revoke access from.
newRevokeVpcEndpointAccess ::
  -- | 'domainName'
  Prelude.Text ->
  -- | 'account'
  Prelude.Text ->
  RevokeVpcEndpointAccess
newRevokeVpcEndpointAccess :: Text -> Text -> RevokeVpcEndpointAccess
newRevokeVpcEndpointAccess Text
pDomainName_ Text
pAccount_ =
  RevokeVpcEndpointAccess'
    { $sel:domainName:RevokeVpcEndpointAccess' :: Text
domainName = Text
pDomainName_,
      $sel:account:RevokeVpcEndpointAccess' :: Text
account = Text
pAccount_
    }

-- | The name of the OpenSearch Service domain.
revokeVpcEndpointAccess_domainName :: Lens.Lens' RevokeVpcEndpointAccess Prelude.Text
revokeVpcEndpointAccess_domainName :: Lens' RevokeVpcEndpointAccess Text
revokeVpcEndpointAccess_domainName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RevokeVpcEndpointAccess' {Text
domainName :: Text
$sel:domainName:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
domainName} -> Text
domainName) (\s :: RevokeVpcEndpointAccess
s@RevokeVpcEndpointAccess' {} Text
a -> RevokeVpcEndpointAccess
s {$sel:domainName:RevokeVpcEndpointAccess' :: Text
domainName = Text
a} :: RevokeVpcEndpointAccess)

-- | The account ID to revoke access from.
revokeVpcEndpointAccess_account :: Lens.Lens' RevokeVpcEndpointAccess Prelude.Text
revokeVpcEndpointAccess_account :: Lens' RevokeVpcEndpointAccess Text
revokeVpcEndpointAccess_account = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RevokeVpcEndpointAccess' {Text
account :: Text
$sel:account:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
account} -> Text
account) (\s :: RevokeVpcEndpointAccess
s@RevokeVpcEndpointAccess' {} Text
a -> RevokeVpcEndpointAccess
s {$sel:account:RevokeVpcEndpointAccess' :: Text
account = Text
a} :: RevokeVpcEndpointAccess)

instance Core.AWSRequest RevokeVpcEndpointAccess where
  type
    AWSResponse RevokeVpcEndpointAccess =
      RevokeVpcEndpointAccessResponse
  request :: (Service -> Service)
-> RevokeVpcEndpointAccess -> Request RevokeVpcEndpointAccess
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 RevokeVpcEndpointAccess
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse RevokeVpcEndpointAccess)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> () -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveEmpty
      ( \Int
s ResponseHeaders
h ()
x ->
          Int -> RevokeVpcEndpointAccessResponse
RevokeVpcEndpointAccessResponse'
            forall (f :: * -> *) a b. Functor 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 RevokeVpcEndpointAccess where
  hashWithSalt :: Int -> RevokeVpcEndpointAccess -> Int
hashWithSalt Int
_salt RevokeVpcEndpointAccess' {Text
account :: Text
domainName :: Text
$sel:account:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
$sel:domainName:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
domainName
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
account

instance Prelude.NFData RevokeVpcEndpointAccess where
  rnf :: RevokeVpcEndpointAccess -> ()
rnf RevokeVpcEndpointAccess' {Text
account :: Text
domainName :: Text
$sel:account:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
$sel:domainName:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
domainName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
account

instance Data.ToHeaders RevokeVpcEndpointAccess where
  toHeaders :: RevokeVpcEndpointAccess -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

instance Data.ToJSON RevokeVpcEndpointAccess where
  toJSON :: RevokeVpcEndpointAccess -> Value
toJSON RevokeVpcEndpointAccess' {Text
account :: Text
domainName :: Text
$sel:account:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
$sel:domainName:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [forall a. a -> Maybe a
Prelude.Just (Key
"Account" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
account)]
      )

instance Data.ToPath RevokeVpcEndpointAccess where
  toPath :: RevokeVpcEndpointAccess -> ByteString
toPath RevokeVpcEndpointAccess' {Text
account :: Text
domainName :: Text
$sel:account:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
$sel:domainName:RevokeVpcEndpointAccess' :: RevokeVpcEndpointAccess -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/2015-01-01/es/domain/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
domainName,
        ByteString
"/revokeVpcEndpointAccess"
      ]

instance Data.ToQuery RevokeVpcEndpointAccess where
  toQuery :: RevokeVpcEndpointAccess -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | Container for response parameters to the @RevokeVpcEndpointAccess@
-- operation. The response body for this operation is empty.
--
-- /See:/ 'newRevokeVpcEndpointAccessResponse' smart constructor.
data RevokeVpcEndpointAccessResponse = RevokeVpcEndpointAccessResponse'
  { -- | The response's http status code.
    RevokeVpcEndpointAccessResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (RevokeVpcEndpointAccessResponse
-> RevokeVpcEndpointAccessResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: RevokeVpcEndpointAccessResponse
-> RevokeVpcEndpointAccessResponse -> Bool
$c/= :: RevokeVpcEndpointAccessResponse
-> RevokeVpcEndpointAccessResponse -> Bool
== :: RevokeVpcEndpointAccessResponse
-> RevokeVpcEndpointAccessResponse -> Bool
$c== :: RevokeVpcEndpointAccessResponse
-> RevokeVpcEndpointAccessResponse -> Bool
Prelude.Eq, ReadPrec [RevokeVpcEndpointAccessResponse]
ReadPrec RevokeVpcEndpointAccessResponse
Int -> ReadS RevokeVpcEndpointAccessResponse
ReadS [RevokeVpcEndpointAccessResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [RevokeVpcEndpointAccessResponse]
$creadListPrec :: ReadPrec [RevokeVpcEndpointAccessResponse]
readPrec :: ReadPrec RevokeVpcEndpointAccessResponse
$creadPrec :: ReadPrec RevokeVpcEndpointAccessResponse
readList :: ReadS [RevokeVpcEndpointAccessResponse]
$creadList :: ReadS [RevokeVpcEndpointAccessResponse]
readsPrec :: Int -> ReadS RevokeVpcEndpointAccessResponse
$creadsPrec :: Int -> ReadS RevokeVpcEndpointAccessResponse
Prelude.Read, Int -> RevokeVpcEndpointAccessResponse -> ShowS
[RevokeVpcEndpointAccessResponse] -> ShowS
RevokeVpcEndpointAccessResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [RevokeVpcEndpointAccessResponse] -> ShowS
$cshowList :: [RevokeVpcEndpointAccessResponse] -> ShowS
show :: RevokeVpcEndpointAccessResponse -> String
$cshow :: RevokeVpcEndpointAccessResponse -> String
showsPrec :: Int -> RevokeVpcEndpointAccessResponse -> ShowS
$cshowsPrec :: Int -> RevokeVpcEndpointAccessResponse -> ShowS
Prelude.Show, forall x.
Rep RevokeVpcEndpointAccessResponse x
-> RevokeVpcEndpointAccessResponse
forall x.
RevokeVpcEndpointAccessResponse
-> Rep RevokeVpcEndpointAccessResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep RevokeVpcEndpointAccessResponse x
-> RevokeVpcEndpointAccessResponse
$cfrom :: forall x.
RevokeVpcEndpointAccessResponse
-> Rep RevokeVpcEndpointAccessResponse x
Prelude.Generic)

-- |
-- Create a value of 'RevokeVpcEndpointAccessResponse' 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:
--
-- 'httpStatus', 'revokeVpcEndpointAccessResponse_httpStatus' - The response's http status code.
newRevokeVpcEndpointAccessResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  RevokeVpcEndpointAccessResponse
newRevokeVpcEndpointAccessResponse :: Int -> RevokeVpcEndpointAccessResponse
newRevokeVpcEndpointAccessResponse Int
pHttpStatus_ =
  RevokeVpcEndpointAccessResponse'
    { $sel:httpStatus:RevokeVpcEndpointAccessResponse' :: Int
httpStatus =
        Int
pHttpStatus_
    }

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

instance
  Prelude.NFData
    RevokeVpcEndpointAccessResponse
  where
  rnf :: RevokeVpcEndpointAccessResponse -> ()
rnf RevokeVpcEndpointAccessResponse' {Int
httpStatus :: Int
$sel:httpStatus:RevokeVpcEndpointAccessResponse' :: RevokeVpcEndpointAccessResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus