{-# 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.ReplaceTransitGatewayRoute -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Replaces the specified route in the specified transit gateway route -- table. module Amazonka.EC2.ReplaceTransitGatewayRoute ( -- * Creating a Request ReplaceTransitGatewayRoute (..), newReplaceTransitGatewayRoute, -- * Request Lenses replaceTransitGatewayRoute_blackhole, replaceTransitGatewayRoute_dryRun, replaceTransitGatewayRoute_transitGatewayAttachmentId, replaceTransitGatewayRoute_destinationCidrBlock, replaceTransitGatewayRoute_transitGatewayRouteTableId, -- * Destructuring the Response ReplaceTransitGatewayRouteResponse (..), newReplaceTransitGatewayRouteResponse, -- * Response Lenses replaceTransitGatewayRouteResponse_route, replaceTransitGatewayRouteResponse_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:/ 'newReplaceTransitGatewayRoute' smart constructor. data ReplaceTransitGatewayRoute = ReplaceTransitGatewayRoute' { -- | Indicates whether traffic matching this route is to be dropped. blackhole :: Prelude.Maybe Prelude.Bool, -- | 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 attachment. transitGatewayAttachmentId :: Prelude.Maybe Prelude.Text, -- | The CIDR range used for the destination match. Routing decisions are -- based on the most specific match. destinationCidrBlock :: Prelude.Text, -- | The ID of the route table. transitGatewayRouteTableId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ReplaceTransitGatewayRoute' 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: -- -- 'blackhole', 'replaceTransitGatewayRoute_blackhole' - Indicates whether traffic matching this route is to be dropped. -- -- 'dryRun', 'replaceTransitGatewayRoute_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@. -- -- 'transitGatewayAttachmentId', 'replaceTransitGatewayRoute_transitGatewayAttachmentId' - The ID of the attachment. -- -- 'destinationCidrBlock', 'replaceTransitGatewayRoute_destinationCidrBlock' - The CIDR range used for the destination match. Routing decisions are -- based on the most specific match. -- -- 'transitGatewayRouteTableId', 'replaceTransitGatewayRoute_transitGatewayRouteTableId' - The ID of the route table. newReplaceTransitGatewayRoute :: -- | 'destinationCidrBlock' Prelude.Text -> -- | 'transitGatewayRouteTableId' Prelude.Text -> ReplaceTransitGatewayRoute newReplaceTransitGatewayRoute pDestinationCidrBlock_ pTransitGatewayRouteTableId_ = ReplaceTransitGatewayRoute' { blackhole = Prelude.Nothing, dryRun = Prelude.Nothing, transitGatewayAttachmentId = Prelude.Nothing, destinationCidrBlock = pDestinationCidrBlock_, transitGatewayRouteTableId = pTransitGatewayRouteTableId_ } -- | Indicates whether traffic matching this route is to be dropped. replaceTransitGatewayRoute_blackhole :: Lens.Lens' ReplaceTransitGatewayRoute (Prelude.Maybe Prelude.Bool) replaceTransitGatewayRoute_blackhole = Lens.lens (\ReplaceTransitGatewayRoute' {blackhole} -> blackhole) (\s@ReplaceTransitGatewayRoute' {} a -> s {blackhole = a} :: ReplaceTransitGatewayRoute) -- | 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@. replaceTransitGatewayRoute_dryRun :: Lens.Lens' ReplaceTransitGatewayRoute (Prelude.Maybe Prelude.Bool) replaceTransitGatewayRoute_dryRun = Lens.lens (\ReplaceTransitGatewayRoute' {dryRun} -> dryRun) (\s@ReplaceTransitGatewayRoute' {} a -> s {dryRun = a} :: ReplaceTransitGatewayRoute) -- | The ID of the attachment. replaceTransitGatewayRoute_transitGatewayAttachmentId :: Lens.Lens' ReplaceTransitGatewayRoute (Prelude.Maybe Prelude.Text) replaceTransitGatewayRoute_transitGatewayAttachmentId = Lens.lens (\ReplaceTransitGatewayRoute' {transitGatewayAttachmentId} -> transitGatewayAttachmentId) (\s@ReplaceTransitGatewayRoute' {} a -> s {transitGatewayAttachmentId = a} :: ReplaceTransitGatewayRoute) -- | The CIDR range used for the destination match. Routing decisions are -- based on the most specific match. replaceTransitGatewayRoute_destinationCidrBlock :: Lens.Lens' ReplaceTransitGatewayRoute Prelude.Text replaceTransitGatewayRoute_destinationCidrBlock = Lens.lens (\ReplaceTransitGatewayRoute' {destinationCidrBlock} -> destinationCidrBlock) (\s@ReplaceTransitGatewayRoute' {} a -> s {destinationCidrBlock = a} :: ReplaceTransitGatewayRoute) -- | The ID of the route table. replaceTransitGatewayRoute_transitGatewayRouteTableId :: Lens.Lens' ReplaceTransitGatewayRoute Prelude.Text replaceTransitGatewayRoute_transitGatewayRouteTableId = Lens.lens (\ReplaceTransitGatewayRoute' {transitGatewayRouteTableId} -> transitGatewayRouteTableId) (\s@ReplaceTransitGatewayRoute' {} a -> s {transitGatewayRouteTableId = a} :: ReplaceTransitGatewayRoute) instance Core.AWSRequest ReplaceTransitGatewayRoute where type AWSResponse ReplaceTransitGatewayRoute = ReplaceTransitGatewayRouteResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXML ( \s h x -> ReplaceTransitGatewayRouteResponse' Prelude.<$> (x Data..@? "route") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ReplaceTransitGatewayRoute where hashWithSalt _salt ReplaceTransitGatewayRoute' {..} = _salt `Prelude.hashWithSalt` blackhole `Prelude.hashWithSalt` dryRun `Prelude.hashWithSalt` transitGatewayAttachmentId `Prelude.hashWithSalt` destinationCidrBlock `Prelude.hashWithSalt` transitGatewayRouteTableId instance Prelude.NFData ReplaceTransitGatewayRoute where rnf ReplaceTransitGatewayRoute' {..} = Prelude.rnf blackhole `Prelude.seq` Prelude.rnf dryRun `Prelude.seq` Prelude.rnf transitGatewayAttachmentId `Prelude.seq` Prelude.rnf destinationCidrBlock `Prelude.seq` Prelude.rnf transitGatewayRouteTableId instance Data.ToHeaders ReplaceTransitGatewayRoute where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath ReplaceTransitGatewayRoute where toPath = Prelude.const "/" instance Data.ToQuery ReplaceTransitGatewayRoute where toQuery ReplaceTransitGatewayRoute' {..} = Prelude.mconcat [ "Action" Data.=: ("ReplaceTransitGatewayRoute" :: Prelude.ByteString), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), "Blackhole" Data.=: blackhole, "DryRun" Data.=: dryRun, "TransitGatewayAttachmentId" Data.=: transitGatewayAttachmentId, "DestinationCidrBlock" Data.=: destinationCidrBlock, "TransitGatewayRouteTableId" Data.=: transitGatewayRouteTableId ] -- | /See:/ 'newReplaceTransitGatewayRouteResponse' smart constructor. data ReplaceTransitGatewayRouteResponse = ReplaceTransitGatewayRouteResponse' { -- | Information about the modified route. route :: Prelude.Maybe TransitGatewayRoute, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ReplaceTransitGatewayRouteResponse' 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: -- -- 'route', 'replaceTransitGatewayRouteResponse_route' - Information about the modified route. -- -- 'httpStatus', 'replaceTransitGatewayRouteResponse_httpStatus' - The response's http status code. newReplaceTransitGatewayRouteResponse :: -- | 'httpStatus' Prelude.Int -> ReplaceTransitGatewayRouteResponse newReplaceTransitGatewayRouteResponse pHttpStatus_ = ReplaceTransitGatewayRouteResponse' { route = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about the modified route. replaceTransitGatewayRouteResponse_route :: Lens.Lens' ReplaceTransitGatewayRouteResponse (Prelude.Maybe TransitGatewayRoute) replaceTransitGatewayRouteResponse_route = Lens.lens (\ReplaceTransitGatewayRouteResponse' {route} -> route) (\s@ReplaceTransitGatewayRouteResponse' {} a -> s {route = a} :: ReplaceTransitGatewayRouteResponse) -- | The response's http status code. replaceTransitGatewayRouteResponse_httpStatus :: Lens.Lens' ReplaceTransitGatewayRouteResponse Prelude.Int replaceTransitGatewayRouteResponse_httpStatus = Lens.lens (\ReplaceTransitGatewayRouteResponse' {httpStatus} -> httpStatus) (\s@ReplaceTransitGatewayRouteResponse' {} a -> s {httpStatus = a} :: ReplaceTransitGatewayRouteResponse) instance Prelude.NFData ReplaceTransitGatewayRouteResponse where rnf ReplaceTransitGatewayRouteResponse' {..} = Prelude.rnf route `Prelude.seq` Prelude.rnf httpStatus