{-# 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.EC2.UpdateSecurityGroupRuleDescriptionsEgress -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- [VPC only] Updates the description of an egress (outbound) security -- group rule. You can replace an existing description, or add a -- description to a rule that did not have one previously. You can remove a -- description for a security group rule by omitting the description -- parameter in the request. module Amazonka.EC2.UpdateSecurityGroupRuleDescriptionsEgress ( -- * Creating a Request UpdateSecurityGroupRuleDescriptionsEgress (..), newUpdateSecurityGroupRuleDescriptionsEgress, -- * Request Lenses updateSecurityGroupRuleDescriptionsEgress_dryRun, updateSecurityGroupRuleDescriptionsEgress_groupId, updateSecurityGroupRuleDescriptionsEgress_groupName, updateSecurityGroupRuleDescriptionsEgress_ipPermissions, updateSecurityGroupRuleDescriptionsEgress_securityGroupRuleDescriptions, -- * Destructuring the Response UpdateSecurityGroupRuleDescriptionsEgressResponse (..), newUpdateSecurityGroupRuleDescriptionsEgressResponse, -- * Response Lenses updateSecurityGroupRuleDescriptionsEgressResponse_return, updateSecurityGroupRuleDescriptionsEgressResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.EC2.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateSecurityGroupRuleDescriptionsEgress' smart constructor. data UpdateSecurityGroupRuleDescriptionsEgress = UpdateSecurityGroupRuleDescriptionsEgress' { -- | Checks whether you have the required permissions for the action, without -- actually making the request, and provides an error response. If you have -- the required permissions, the error response is @DryRunOperation@. -- Otherwise, it is @UnauthorizedOperation@. dryRun :: Prelude.Maybe Prelude.Bool, -- | The ID of the security group. You must specify either the security group -- ID or the security group name in the request. For security groups in a -- nondefault VPC, you must specify the security group ID. groupId :: Prelude.Maybe Prelude.Text, -- | [Default VPC] The name of the security group. You must specify either -- the security group ID or the security group name in the request. groupName :: Prelude.Maybe Prelude.Text, -- | The IP permissions for the security group rule. You must specify either -- the IP permissions or the description. ipPermissions :: Prelude.Maybe [IpPermission], -- | The description for the egress security group rules. You must specify -- either the description or the IP permissions. securityGroupRuleDescriptions :: Prelude.Maybe [SecurityGroupRuleDescription] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateSecurityGroupRuleDescriptionsEgress' 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: -- -- 'dryRun', 'updateSecurityGroupRuleDescriptionsEgress_dryRun' - Checks whether you have the required permissions for the action, without -- actually making the request, and provides an error response. If you have -- the required permissions, the error response is @DryRunOperation@. -- Otherwise, it is @UnauthorizedOperation@. -- -- 'groupId', 'updateSecurityGroupRuleDescriptionsEgress_groupId' - The ID of the security group. You must specify either the security group -- ID or the security group name in the request. For security groups in a -- nondefault VPC, you must specify the security group ID. -- -- 'groupName', 'updateSecurityGroupRuleDescriptionsEgress_groupName' - [Default VPC] The name of the security group. You must specify either -- the security group ID or the security group name in the request. -- -- 'ipPermissions', 'updateSecurityGroupRuleDescriptionsEgress_ipPermissions' - The IP permissions for the security group rule. You must specify either -- the IP permissions or the description. -- -- 'securityGroupRuleDescriptions', 'updateSecurityGroupRuleDescriptionsEgress_securityGroupRuleDescriptions' - The description for the egress security group rules. You must specify -- either the description or the IP permissions. newUpdateSecurityGroupRuleDescriptionsEgress :: UpdateSecurityGroupRuleDescriptionsEgress newUpdateSecurityGroupRuleDescriptionsEgress = UpdateSecurityGroupRuleDescriptionsEgress' { dryRun = Prelude.Nothing, groupId = Prelude.Nothing, groupName = Prelude.Nothing, ipPermissions = Prelude.Nothing, securityGroupRuleDescriptions = Prelude.Nothing } -- | Checks whether you have the required permissions for the action, without -- actually making the request, and provides an error response. If you have -- the required permissions, the error response is @DryRunOperation@. -- Otherwise, it is @UnauthorizedOperation@. updateSecurityGroupRuleDescriptionsEgress_dryRun :: Lens.Lens' UpdateSecurityGroupRuleDescriptionsEgress (Prelude.Maybe Prelude.Bool) updateSecurityGroupRuleDescriptionsEgress_dryRun = Lens.lens (\UpdateSecurityGroupRuleDescriptionsEgress' {dryRun} -> dryRun) (\s@UpdateSecurityGroupRuleDescriptionsEgress' {} a -> s {dryRun = a} :: UpdateSecurityGroupRuleDescriptionsEgress) -- | The ID of the security group. You must specify either the security group -- ID or the security group name in the request. For security groups in a -- nondefault VPC, you must specify the security group ID. updateSecurityGroupRuleDescriptionsEgress_groupId :: Lens.Lens' UpdateSecurityGroupRuleDescriptionsEgress (Prelude.Maybe Prelude.Text) updateSecurityGroupRuleDescriptionsEgress_groupId = Lens.lens (\UpdateSecurityGroupRuleDescriptionsEgress' {groupId} -> groupId) (\s@UpdateSecurityGroupRuleDescriptionsEgress' {} a -> s {groupId = a} :: UpdateSecurityGroupRuleDescriptionsEgress) -- | [Default VPC] The name of the security group. You must specify either -- the security group ID or the security group name in the request. updateSecurityGroupRuleDescriptionsEgress_groupName :: Lens.Lens' UpdateSecurityGroupRuleDescriptionsEgress (Prelude.Maybe Prelude.Text) updateSecurityGroupRuleDescriptionsEgress_groupName = Lens.lens (\UpdateSecurityGroupRuleDescriptionsEgress' {groupName} -> groupName) (\s@UpdateSecurityGroupRuleDescriptionsEgress' {} a -> s {groupName = a} :: UpdateSecurityGroupRuleDescriptionsEgress) -- | The IP permissions for the security group rule. You must specify either -- the IP permissions or the description. updateSecurityGroupRuleDescriptionsEgress_ipPermissions :: Lens.Lens' UpdateSecurityGroupRuleDescriptionsEgress (Prelude.Maybe [IpPermission]) updateSecurityGroupRuleDescriptionsEgress_ipPermissions = Lens.lens (\UpdateSecurityGroupRuleDescriptionsEgress' {ipPermissions} -> ipPermissions) (\s@UpdateSecurityGroupRuleDescriptionsEgress' {} a -> s {ipPermissions = a} :: UpdateSecurityGroupRuleDescriptionsEgress) Prelude.. Lens.mapping Lens.coerced -- | The description for the egress security group rules. You must specify -- either the description or the IP permissions. updateSecurityGroupRuleDescriptionsEgress_securityGroupRuleDescriptions :: Lens.Lens' UpdateSecurityGroupRuleDescriptionsEgress (Prelude.Maybe [SecurityGroupRuleDescription]) updateSecurityGroupRuleDescriptionsEgress_securityGroupRuleDescriptions = Lens.lens (\UpdateSecurityGroupRuleDescriptionsEgress' {securityGroupRuleDescriptions} -> securityGroupRuleDescriptions) (\s@UpdateSecurityGroupRuleDescriptionsEgress' {} a -> s {securityGroupRuleDescriptions = a} :: UpdateSecurityGroupRuleDescriptionsEgress) Prelude.. Lens.mapping Lens.coerced instance Core.AWSRequest UpdateSecurityGroupRuleDescriptionsEgress where type AWSResponse UpdateSecurityGroupRuleDescriptionsEgress = UpdateSecurityGroupRuleDescriptionsEgressResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXML ( \s h x -> UpdateSecurityGroupRuleDescriptionsEgressResponse' Prelude.<$> (x Data..@? "return") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateSecurityGroupRuleDescriptionsEgress where hashWithSalt _salt UpdateSecurityGroupRuleDescriptionsEgress' {..} = _salt `Prelude.hashWithSalt` dryRun `Prelude.hashWithSalt` groupId `Prelude.hashWithSalt` groupName `Prelude.hashWithSalt` ipPermissions `Prelude.hashWithSalt` securityGroupRuleDescriptions instance Prelude.NFData UpdateSecurityGroupRuleDescriptionsEgress where rnf UpdateSecurityGroupRuleDescriptionsEgress' {..} = Prelude.rnf dryRun `Prelude.seq` Prelude.rnf groupId `Prelude.seq` Prelude.rnf groupName `Prelude.seq` Prelude.rnf ipPermissions `Prelude.seq` Prelude.rnf securityGroupRuleDescriptions instance Data.ToHeaders UpdateSecurityGroupRuleDescriptionsEgress where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath UpdateSecurityGroupRuleDescriptionsEgress where toPath = Prelude.const "/" instance Data.ToQuery UpdateSecurityGroupRuleDescriptionsEgress where toQuery UpdateSecurityGroupRuleDescriptionsEgress' {..} = Prelude.mconcat [ "Action" Data.=: ( "UpdateSecurityGroupRuleDescriptionsEgress" :: Prelude.ByteString ), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), "DryRun" Data.=: dryRun, "GroupId" Data.=: groupId, "GroupName" Data.=: groupName, Data.toQuery ( Data.toQueryList "IpPermissions" Prelude.<$> ipPermissions ), Data.toQuery ( Data.toQueryList "SecurityGroupRuleDescription" Prelude.<$> securityGroupRuleDescriptions ) ] -- | /See:/ 'newUpdateSecurityGroupRuleDescriptionsEgressResponse' smart constructor. data UpdateSecurityGroupRuleDescriptionsEgressResponse = UpdateSecurityGroupRuleDescriptionsEgressResponse' { -- | Returns @true@ if the request succeeds; otherwise, returns an error. return' :: Prelude.Maybe Prelude.Bool, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateSecurityGroupRuleDescriptionsEgressResponse' 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: -- -- 'return'', 'updateSecurityGroupRuleDescriptionsEgressResponse_return' - Returns @true@ if the request succeeds; otherwise, returns an error. -- -- 'httpStatus', 'updateSecurityGroupRuleDescriptionsEgressResponse_httpStatus' - The response's http status code. newUpdateSecurityGroupRuleDescriptionsEgressResponse :: -- | 'httpStatus' Prelude.Int -> UpdateSecurityGroupRuleDescriptionsEgressResponse newUpdateSecurityGroupRuleDescriptionsEgressResponse pHttpStatus_ = UpdateSecurityGroupRuleDescriptionsEgressResponse' { return' = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Returns @true@ if the request succeeds; otherwise, returns an error. updateSecurityGroupRuleDescriptionsEgressResponse_return :: Lens.Lens' UpdateSecurityGroupRuleDescriptionsEgressResponse (Prelude.Maybe Prelude.Bool) updateSecurityGroupRuleDescriptionsEgressResponse_return = Lens.lens (\UpdateSecurityGroupRuleDescriptionsEgressResponse' {return'} -> return') (\s@UpdateSecurityGroupRuleDescriptionsEgressResponse' {} a -> s {return' = a} :: UpdateSecurityGroupRuleDescriptionsEgressResponse) -- | The response's http status code. updateSecurityGroupRuleDescriptionsEgressResponse_httpStatus :: Lens.Lens' UpdateSecurityGroupRuleDescriptionsEgressResponse Prelude.Int updateSecurityGroupRuleDescriptionsEgressResponse_httpStatus = Lens.lens (\UpdateSecurityGroupRuleDescriptionsEgressResponse' {httpStatus} -> httpStatus) (\s@UpdateSecurityGroupRuleDescriptionsEgressResponse' {} a -> s {httpStatus = a} :: UpdateSecurityGroupRuleDescriptionsEgressResponse) instance Prelude.NFData UpdateSecurityGroupRuleDescriptionsEgressResponse where rnf UpdateSecurityGroupRuleDescriptionsEgressResponse' {..} = Prelude.rnf return' `Prelude.seq` Prelude.rnf httpStatus