{-# 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.Redshift.DeauthorizeDataShare
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- From a datashare producer account, removes authorization from the
-- specified datashare.
module Amazonka.Redshift.DeauthorizeDataShare
  ( -- * Creating a Request
    DeauthorizeDataShare (..),
    newDeauthorizeDataShare,

    -- * Request Lenses
    deauthorizeDataShare_dataShareArn,
    deauthorizeDataShare_consumerIdentifier,

    -- * Destructuring the Response
    DataShare (..),
    newDataShare,

    -- * Response Lenses
    dataShare_allowPubliclyAccessibleConsumers,
    dataShare_dataShareArn,
    dataShare_dataShareAssociations,
    dataShare_managedBy,
    dataShare_producerArn,
  )
where

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 Amazonka.Redshift.Types
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newDeauthorizeDataShare' smart constructor.
data DeauthorizeDataShare = DeauthorizeDataShare'
  { -- | The Amazon Resource Name (ARN) of the datashare to remove authorization
    -- from.
    DeauthorizeDataShare -> Text
dataShareArn :: Prelude.Text,
    -- | The identifier of the data consumer that is to have authorization
    -- removed from the datashare. This identifier is an Amazon Web Services
    -- account ID or a keyword, such as ADX.
    DeauthorizeDataShare -> Text
consumerIdentifier :: Prelude.Text
  }
  deriving (DeauthorizeDataShare -> DeauthorizeDataShare -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DeauthorizeDataShare -> DeauthorizeDataShare -> Bool
$c/= :: DeauthorizeDataShare -> DeauthorizeDataShare -> Bool
== :: DeauthorizeDataShare -> DeauthorizeDataShare -> Bool
$c== :: DeauthorizeDataShare -> DeauthorizeDataShare -> Bool
Prelude.Eq, ReadPrec [DeauthorizeDataShare]
ReadPrec DeauthorizeDataShare
Int -> ReadS DeauthorizeDataShare
ReadS [DeauthorizeDataShare]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DeauthorizeDataShare]
$creadListPrec :: ReadPrec [DeauthorizeDataShare]
readPrec :: ReadPrec DeauthorizeDataShare
$creadPrec :: ReadPrec DeauthorizeDataShare
readList :: ReadS [DeauthorizeDataShare]
$creadList :: ReadS [DeauthorizeDataShare]
readsPrec :: Int -> ReadS DeauthorizeDataShare
$creadsPrec :: Int -> ReadS DeauthorizeDataShare
Prelude.Read, Int -> DeauthorizeDataShare -> ShowS
[DeauthorizeDataShare] -> ShowS
DeauthorizeDataShare -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DeauthorizeDataShare] -> ShowS
$cshowList :: [DeauthorizeDataShare] -> ShowS
show :: DeauthorizeDataShare -> String
$cshow :: DeauthorizeDataShare -> String
showsPrec :: Int -> DeauthorizeDataShare -> ShowS
$cshowsPrec :: Int -> DeauthorizeDataShare -> ShowS
Prelude.Show, forall x. Rep DeauthorizeDataShare x -> DeauthorizeDataShare
forall x. DeauthorizeDataShare -> Rep DeauthorizeDataShare x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DeauthorizeDataShare x -> DeauthorizeDataShare
$cfrom :: forall x. DeauthorizeDataShare -> Rep DeauthorizeDataShare x
Prelude.Generic)

-- |
-- Create a value of 'DeauthorizeDataShare' 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:
--
-- 'dataShareArn', 'deauthorizeDataShare_dataShareArn' - The Amazon Resource Name (ARN) of the datashare to remove authorization
-- from.
--
-- 'consumerIdentifier', 'deauthorizeDataShare_consumerIdentifier' - The identifier of the data consumer that is to have authorization
-- removed from the datashare. This identifier is an Amazon Web Services
-- account ID or a keyword, such as ADX.
newDeauthorizeDataShare ::
  -- | 'dataShareArn'
  Prelude.Text ->
  -- | 'consumerIdentifier'
  Prelude.Text ->
  DeauthorizeDataShare
newDeauthorizeDataShare :: Text -> Text -> DeauthorizeDataShare
newDeauthorizeDataShare
  Text
pDataShareArn_
  Text
pConsumerIdentifier_ =
    DeauthorizeDataShare'
      { $sel:dataShareArn:DeauthorizeDataShare' :: Text
dataShareArn =
          Text
pDataShareArn_,
        $sel:consumerIdentifier:DeauthorizeDataShare' :: Text
consumerIdentifier = Text
pConsumerIdentifier_
      }

-- | The Amazon Resource Name (ARN) of the datashare to remove authorization
-- from.
deauthorizeDataShare_dataShareArn :: Lens.Lens' DeauthorizeDataShare Prelude.Text
deauthorizeDataShare_dataShareArn :: Lens' DeauthorizeDataShare Text
deauthorizeDataShare_dataShareArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeauthorizeDataShare' {Text
dataShareArn :: Text
$sel:dataShareArn:DeauthorizeDataShare' :: DeauthorizeDataShare -> Text
dataShareArn} -> Text
dataShareArn) (\s :: DeauthorizeDataShare
s@DeauthorizeDataShare' {} Text
a -> DeauthorizeDataShare
s {$sel:dataShareArn:DeauthorizeDataShare' :: Text
dataShareArn = Text
a} :: DeauthorizeDataShare)

-- | The identifier of the data consumer that is to have authorization
-- removed from the datashare. This identifier is an Amazon Web Services
-- account ID or a keyword, such as ADX.
deauthorizeDataShare_consumerIdentifier :: Lens.Lens' DeauthorizeDataShare Prelude.Text
deauthorizeDataShare_consumerIdentifier :: Lens' DeauthorizeDataShare Text
deauthorizeDataShare_consumerIdentifier = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DeauthorizeDataShare' {Text
consumerIdentifier :: Text
$sel:consumerIdentifier:DeauthorizeDataShare' :: DeauthorizeDataShare -> Text
consumerIdentifier} -> Text
consumerIdentifier) (\s :: DeauthorizeDataShare
s@DeauthorizeDataShare' {} Text
a -> DeauthorizeDataShare
s {$sel:consumerIdentifier:DeauthorizeDataShare' :: Text
consumerIdentifier = Text
a} :: DeauthorizeDataShare)

instance Core.AWSRequest DeauthorizeDataShare where
  type AWSResponse DeauthorizeDataShare = DataShare
  request :: (Service -> Service)
-> DeauthorizeDataShare -> Request DeauthorizeDataShare
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DeauthorizeDataShare
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse DeauthorizeDataShare)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
Text
-> (Int
    -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXMLWrapper
      Text
"DeauthorizeDataShareResult"
      (\Int
s ResponseHeaders
h [Node]
x -> forall a. FromXML a => [Node] -> Either String a
Data.parseXML [Node]
x)

instance Prelude.Hashable DeauthorizeDataShare where
  hashWithSalt :: Int -> DeauthorizeDataShare -> Int
hashWithSalt Int
_salt DeauthorizeDataShare' {Text
consumerIdentifier :: Text
dataShareArn :: Text
$sel:consumerIdentifier:DeauthorizeDataShare' :: DeauthorizeDataShare -> Text
$sel:dataShareArn:DeauthorizeDataShare' :: DeauthorizeDataShare -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
dataShareArn
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
consumerIdentifier

instance Prelude.NFData DeauthorizeDataShare where
  rnf :: DeauthorizeDataShare -> ()
rnf DeauthorizeDataShare' {Text
consumerIdentifier :: Text
dataShareArn :: Text
$sel:consumerIdentifier:DeauthorizeDataShare' :: DeauthorizeDataShare -> Text
$sel:dataShareArn:DeauthorizeDataShare' :: DeauthorizeDataShare -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
dataShareArn
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
consumerIdentifier

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

instance Data.ToPath DeauthorizeDataShare where
  toPath :: DeauthorizeDataShare -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery DeauthorizeDataShare where
  toQuery :: DeauthorizeDataShare -> QueryString
toQuery DeauthorizeDataShare' {Text
consumerIdentifier :: Text
dataShareArn :: Text
$sel:consumerIdentifier:DeauthorizeDataShare' :: DeauthorizeDataShare -> Text
$sel:dataShareArn:DeauthorizeDataShare' :: DeauthorizeDataShare -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"Action"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"DeauthorizeDataShare" :: Prelude.ByteString),
        ByteString
"Version"
          forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2012-12-01" :: Prelude.ByteString),
        ByteString
"DataShareArn" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
dataShareArn,
        ByteString
"ConsumerIdentifier" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
consumerIdentifier
      ]