{-# 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.AuthorizeClusterSecurityGroupIngress -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Adds an inbound (ingress) rule to an Amazon Redshift security group. -- Depending on whether the application accessing your cluster is running -- on the Internet or an Amazon EC2 instance, you can authorize inbound -- access to either a Classless Interdomain Routing (CIDR)\/Internet -- Protocol (IP) range or to an Amazon EC2 security group. You can add as -- many as 20 ingress rules to an Amazon Redshift security group. -- -- If you authorize access to an Amazon EC2 security group, specify -- /EC2SecurityGroupName/ and /EC2SecurityGroupOwnerId/. The Amazon EC2 -- security group and Amazon Redshift cluster must be in the same Amazon -- Web Services Region. -- -- If you authorize access to a CIDR\/IP address range, specify /CIDRIP/. -- For an overview of CIDR blocks, see the Wikipedia article on -- . -- -- You must also associate the security group with a cluster so that -- clients running on these IP addresses or the EC2 instance are authorized -- to connect to the cluster. For information about managing security -- groups, go to -- -- in the /Amazon Redshift Cluster Management Guide/. module Amazonka.Redshift.AuthorizeClusterSecurityGroupIngress ( -- * Creating a Request AuthorizeClusterSecurityGroupIngress (..), newAuthorizeClusterSecurityGroupIngress, -- * Request Lenses authorizeClusterSecurityGroupIngress_cidrip, authorizeClusterSecurityGroupIngress_eC2SecurityGroupName, authorizeClusterSecurityGroupIngress_eC2SecurityGroupOwnerId, authorizeClusterSecurityGroupIngress_clusterSecurityGroupName, -- * Destructuring the Response AuthorizeClusterSecurityGroupIngressResponse (..), newAuthorizeClusterSecurityGroupIngressResponse, -- * Response Lenses authorizeClusterSecurityGroupIngressResponse_clusterSecurityGroup, authorizeClusterSecurityGroupIngressResponse_httpStatus, ) 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:/ 'newAuthorizeClusterSecurityGroupIngress' smart constructor. data AuthorizeClusterSecurityGroupIngress = AuthorizeClusterSecurityGroupIngress' { -- | The IP range to be added the Amazon Redshift security group. cidrip :: Prelude.Maybe Prelude.Text, -- | The EC2 security group to be added the Amazon Redshift security group. eC2SecurityGroupName :: Prelude.Maybe Prelude.Text, -- | The Amazon Web Services account number of the owner of the security -- group specified by the /EC2SecurityGroupName/ parameter. The Amazon Web -- Services Access Key ID is not an acceptable value. -- -- Example: @111122223333@ eC2SecurityGroupOwnerId :: Prelude.Maybe Prelude.Text, -- | The name of the security group to which the ingress rule is added. clusterSecurityGroupName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AuthorizeClusterSecurityGroupIngress' 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: -- -- 'cidrip', 'authorizeClusterSecurityGroupIngress_cidrip' - The IP range to be added the Amazon Redshift security group. -- -- 'eC2SecurityGroupName', 'authorizeClusterSecurityGroupIngress_eC2SecurityGroupName' - The EC2 security group to be added the Amazon Redshift security group. -- -- 'eC2SecurityGroupOwnerId', 'authorizeClusterSecurityGroupIngress_eC2SecurityGroupOwnerId' - The Amazon Web Services account number of the owner of the security -- group specified by the /EC2SecurityGroupName/ parameter. The Amazon Web -- Services Access Key ID is not an acceptable value. -- -- Example: @111122223333@ -- -- 'clusterSecurityGroupName', 'authorizeClusterSecurityGroupIngress_clusterSecurityGroupName' - The name of the security group to which the ingress rule is added. newAuthorizeClusterSecurityGroupIngress :: -- | 'clusterSecurityGroupName' Prelude.Text -> AuthorizeClusterSecurityGroupIngress newAuthorizeClusterSecurityGroupIngress pClusterSecurityGroupName_ = AuthorizeClusterSecurityGroupIngress' { cidrip = Prelude.Nothing, eC2SecurityGroupName = Prelude.Nothing, eC2SecurityGroupOwnerId = Prelude.Nothing, clusterSecurityGroupName = pClusterSecurityGroupName_ } -- | The IP range to be added the Amazon Redshift security group. authorizeClusterSecurityGroupIngress_cidrip :: Lens.Lens' AuthorizeClusterSecurityGroupIngress (Prelude.Maybe Prelude.Text) authorizeClusterSecurityGroupIngress_cidrip = Lens.lens (\AuthorizeClusterSecurityGroupIngress' {cidrip} -> cidrip) (\s@AuthorizeClusterSecurityGroupIngress' {} a -> s {cidrip = a} :: AuthorizeClusterSecurityGroupIngress) -- | The EC2 security group to be added the Amazon Redshift security group. authorizeClusterSecurityGroupIngress_eC2SecurityGroupName :: Lens.Lens' AuthorizeClusterSecurityGroupIngress (Prelude.Maybe Prelude.Text) authorizeClusterSecurityGroupIngress_eC2SecurityGroupName = Lens.lens (\AuthorizeClusterSecurityGroupIngress' {eC2SecurityGroupName} -> eC2SecurityGroupName) (\s@AuthorizeClusterSecurityGroupIngress' {} a -> s {eC2SecurityGroupName = a} :: AuthorizeClusterSecurityGroupIngress) -- | The Amazon Web Services account number of the owner of the security -- group specified by the /EC2SecurityGroupName/ parameter. The Amazon Web -- Services Access Key ID is not an acceptable value. -- -- Example: @111122223333@ authorizeClusterSecurityGroupIngress_eC2SecurityGroupOwnerId :: Lens.Lens' AuthorizeClusterSecurityGroupIngress (Prelude.Maybe Prelude.Text) authorizeClusterSecurityGroupIngress_eC2SecurityGroupOwnerId = Lens.lens (\AuthorizeClusterSecurityGroupIngress' {eC2SecurityGroupOwnerId} -> eC2SecurityGroupOwnerId) (\s@AuthorizeClusterSecurityGroupIngress' {} a -> s {eC2SecurityGroupOwnerId = a} :: AuthorizeClusterSecurityGroupIngress) -- | The name of the security group to which the ingress rule is added. authorizeClusterSecurityGroupIngress_clusterSecurityGroupName :: Lens.Lens' AuthorizeClusterSecurityGroupIngress Prelude.Text authorizeClusterSecurityGroupIngress_clusterSecurityGroupName = Lens.lens (\AuthorizeClusterSecurityGroupIngress' {clusterSecurityGroupName} -> clusterSecurityGroupName) (\s@AuthorizeClusterSecurityGroupIngress' {} a -> s {clusterSecurityGroupName = a} :: AuthorizeClusterSecurityGroupIngress) instance Core.AWSRequest AuthorizeClusterSecurityGroupIngress where type AWSResponse AuthorizeClusterSecurityGroupIngress = AuthorizeClusterSecurityGroupIngressResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "AuthorizeClusterSecurityGroupIngressResult" ( \s h x -> AuthorizeClusterSecurityGroupIngressResponse' Prelude.<$> (x Data..@? "ClusterSecurityGroup") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable AuthorizeClusterSecurityGroupIngress where hashWithSalt _salt AuthorizeClusterSecurityGroupIngress' {..} = _salt `Prelude.hashWithSalt` cidrip `Prelude.hashWithSalt` eC2SecurityGroupName `Prelude.hashWithSalt` eC2SecurityGroupOwnerId `Prelude.hashWithSalt` clusterSecurityGroupName instance Prelude.NFData AuthorizeClusterSecurityGroupIngress where rnf AuthorizeClusterSecurityGroupIngress' {..} = Prelude.rnf cidrip `Prelude.seq` Prelude.rnf eC2SecurityGroupName `Prelude.seq` Prelude.rnf eC2SecurityGroupOwnerId `Prelude.seq` Prelude.rnf clusterSecurityGroupName instance Data.ToHeaders AuthorizeClusterSecurityGroupIngress where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath AuthorizeClusterSecurityGroupIngress where toPath = Prelude.const "/" instance Data.ToQuery AuthorizeClusterSecurityGroupIngress where toQuery AuthorizeClusterSecurityGroupIngress' {..} = Prelude.mconcat [ "Action" Data.=: ( "AuthorizeClusterSecurityGroupIngress" :: Prelude.ByteString ), "Version" Data.=: ("2012-12-01" :: Prelude.ByteString), "CIDRIP" Data.=: cidrip, "EC2SecurityGroupName" Data.=: eC2SecurityGroupName, "EC2SecurityGroupOwnerId" Data.=: eC2SecurityGroupOwnerId, "ClusterSecurityGroupName" Data.=: clusterSecurityGroupName ] -- | /See:/ 'newAuthorizeClusterSecurityGroupIngressResponse' smart constructor. data AuthorizeClusterSecurityGroupIngressResponse = AuthorizeClusterSecurityGroupIngressResponse' { clusterSecurityGroup :: Prelude.Maybe ClusterSecurityGroup, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AuthorizeClusterSecurityGroupIngressResponse' 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: -- -- 'clusterSecurityGroup', 'authorizeClusterSecurityGroupIngressResponse_clusterSecurityGroup' - Undocumented member. -- -- 'httpStatus', 'authorizeClusterSecurityGroupIngressResponse_httpStatus' - The response's http status code. newAuthorizeClusterSecurityGroupIngressResponse :: -- | 'httpStatus' Prelude.Int -> AuthorizeClusterSecurityGroupIngressResponse newAuthorizeClusterSecurityGroupIngressResponse pHttpStatus_ = AuthorizeClusterSecurityGroupIngressResponse' { clusterSecurityGroup = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Undocumented member. authorizeClusterSecurityGroupIngressResponse_clusterSecurityGroup :: Lens.Lens' AuthorizeClusterSecurityGroupIngressResponse (Prelude.Maybe ClusterSecurityGroup) authorizeClusterSecurityGroupIngressResponse_clusterSecurityGroup = Lens.lens (\AuthorizeClusterSecurityGroupIngressResponse' {clusterSecurityGroup} -> clusterSecurityGroup) (\s@AuthorizeClusterSecurityGroupIngressResponse' {} a -> s {clusterSecurityGroup = a} :: AuthorizeClusterSecurityGroupIngressResponse) -- | The response's http status code. authorizeClusterSecurityGroupIngressResponse_httpStatus :: Lens.Lens' AuthorizeClusterSecurityGroupIngressResponse Prelude.Int authorizeClusterSecurityGroupIngressResponse_httpStatus = Lens.lens (\AuthorizeClusterSecurityGroupIngressResponse' {httpStatus} -> httpStatus) (\s@AuthorizeClusterSecurityGroupIngressResponse' {} a -> s {httpStatus = a} :: AuthorizeClusterSecurityGroupIngressResponse) instance Prelude.NFData AuthorizeClusterSecurityGroupIngressResponse where rnf AuthorizeClusterSecurityGroupIngressResponse' {..} = Prelude.rnf clusterSecurityGroup `Prelude.seq` Prelude.rnf httpStatus