{-# 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.SQS.RemovePermission -- 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 any permissions in the queue policy that matches the specified -- @Label@ parameter. -- -- - Only the owner of a queue can remove permissions from it. -- -- - Cross-account permissions don\'t apply to this action. For more -- information, see -- -- in the /Amazon SQS Developer Guide/. -- -- - To remove the ability to change queue permissions, you must deny -- permission to the @AddPermission@, @RemovePermission@, and -- @SetQueueAttributes@ actions in your IAM policy. module Amazonka.SQS.RemovePermission ( -- * Creating a Request RemovePermission (..), newRemovePermission, -- * Request Lenses removePermission_queueUrl, removePermission_label, -- * Destructuring the Response RemovePermissionResponse (..), newRemovePermissionResponse, ) 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 qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.SQS.Types -- | -- -- /See:/ 'newRemovePermission' smart constructor. data RemovePermission = RemovePermission' { -- | The URL of the Amazon SQS queue from which permissions are removed. -- -- Queue URLs and names are case-sensitive. queueUrl :: Prelude.Text, -- | The identification of the permission to remove. This is the label added -- using the @ @@AddPermission@@ @ action. label :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RemovePermission' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'queueUrl', 'removePermission_queueUrl' - The URL of the Amazon SQS queue from which permissions are removed. -- -- Queue URLs and names are case-sensitive. -- -- 'label', 'removePermission_label' - The identification of the permission to remove. This is the label added -- using the @ @@AddPermission@@ @ action. newRemovePermission :: -- | 'queueUrl' Prelude.Text -> -- | 'label' Prelude.Text -> RemovePermission newRemovePermission pQueueUrl_ pLabel_ = RemovePermission' { queueUrl = pQueueUrl_, label = pLabel_ } -- | The URL of the Amazon SQS queue from which permissions are removed. -- -- Queue URLs and names are case-sensitive. removePermission_queueUrl :: Lens.Lens' RemovePermission Prelude.Text removePermission_queueUrl = Lens.lens (\RemovePermission' {queueUrl} -> queueUrl) (\s@RemovePermission' {} a -> s {queueUrl = a} :: RemovePermission) -- | The identification of the permission to remove. This is the label added -- using the @ @@AddPermission@@ @ action. removePermission_label :: Lens.Lens' RemovePermission Prelude.Text removePermission_label = Lens.lens (\RemovePermission' {label} -> label) (\s@RemovePermission' {} a -> s {label = a} :: RemovePermission) instance Core.AWSRequest RemovePermission where type AWSResponse RemovePermission = RemovePermissionResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveNull RemovePermissionResponse' instance Prelude.Hashable RemovePermission where hashWithSalt _salt RemovePermission' {..} = _salt `Prelude.hashWithSalt` queueUrl `Prelude.hashWithSalt` label instance Prelude.NFData RemovePermission where rnf RemovePermission' {..} = Prelude.rnf queueUrl `Prelude.seq` Prelude.rnf label instance Data.ToHeaders RemovePermission where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath RemovePermission where toPath = Prelude.const "/" instance Data.ToQuery RemovePermission where toQuery RemovePermission' {..} = Prelude.mconcat [ "Action" Data.=: ("RemovePermission" :: Prelude.ByteString), "Version" Data.=: ("2012-11-05" :: Prelude.ByteString), "QueueUrl" Data.=: queueUrl, "Label" Data.=: label ] -- | /See:/ 'newRemovePermissionResponse' smart constructor. data RemovePermissionResponse = RemovePermissionResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RemovePermissionResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newRemovePermissionResponse :: RemovePermissionResponse newRemovePermissionResponse = RemovePermissionResponse' instance Prelude.NFData RemovePermissionResponse where rnf _ = ()