1// Code generated by smithy-go-codegen DO NOT EDIT.
2
3package ec2
4
5import (
6	"context"
7	awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
8	"github.com/aws/aws-sdk-go-v2/aws/signer/v4"
9	"github.com/aws/smithy-go/middleware"
10	smithyhttp "github.com/aws/smithy-go/transport/http"
11)
12
13// Deletes the specified route from the specified route table.
14func (c *Client) DeleteRoute(ctx context.Context, params *DeleteRouteInput, optFns ...func(*Options)) (*DeleteRouteOutput, error) {
15	if params == nil {
16		params = &DeleteRouteInput{}
17	}
18
19	result, metadata, err := c.invokeOperation(ctx, "DeleteRoute", params, optFns, addOperationDeleteRouteMiddlewares)
20	if err != nil {
21		return nil, err
22	}
23
24	out := result.(*DeleteRouteOutput)
25	out.ResultMetadata = metadata
26	return out, nil
27}
28
29type DeleteRouteInput struct {
30
31	// The ID of the route table.
32	//
33	// This member is required.
34	RouteTableId *string
35
36	// The IPv4 CIDR range for the route. The value you specify must match the CIDR for
37	// the route exactly.
38	DestinationCidrBlock *string
39
40	// The IPv6 CIDR range for the route. The value you specify must match the CIDR for
41	// the route exactly.
42	DestinationIpv6CidrBlock *string
43
44	// The ID of the prefix list for the route.
45	DestinationPrefixListId *string
46
47	// Checks whether you have the required permissions for the action, without
48	// actually making the request, and provides an error response. If you have the
49	// required permissions, the error response is DryRunOperation. Otherwise, it is
50	// UnauthorizedOperation.
51	DryRun bool
52}
53
54type DeleteRouteOutput struct {
55	// Metadata pertaining to the operation's result.
56	ResultMetadata middleware.Metadata
57}
58
59func addOperationDeleteRouteMiddlewares(stack *middleware.Stack, options Options) (err error) {
60	err = stack.Serialize.Add(&awsEc2query_serializeOpDeleteRoute{}, middleware.After)
61	if err != nil {
62		return err
63	}
64	err = stack.Deserialize.Add(&awsEc2query_deserializeOpDeleteRoute{}, middleware.After)
65	if err != nil {
66		return err
67	}
68	if err = addSetLoggerMiddleware(stack, options); err != nil {
69		return err
70	}
71	if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
72		return err
73	}
74	if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
75		return err
76	}
77	if err = addResolveEndpointMiddleware(stack, options); err != nil {
78		return err
79	}
80	if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
81		return err
82	}
83	if err = addRetryMiddlewares(stack, options); err != nil {
84		return err
85	}
86	if err = addHTTPSignerV4Middleware(stack, options); err != nil {
87		return err
88	}
89	if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
90		return err
91	}
92	if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
93		return err
94	}
95	if err = addClientUserAgent(stack); err != nil {
96		return err
97	}
98	if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
99		return err
100	}
101	if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
102		return err
103	}
104	if err = addOpDeleteRouteValidationMiddleware(stack); err != nil {
105		return err
106	}
107	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opDeleteRoute(options.Region), middleware.Before); err != nil {
108		return err
109	}
110	if err = addRequestIDRetrieverMiddleware(stack); err != nil {
111		return err
112	}
113	if err = addResponseErrorMiddleware(stack); err != nil {
114		return err
115	}
116	if err = addRequestResponseLogging(stack, options); err != nil {
117		return err
118	}
119	return nil
120}
121
122func newServiceMetadataMiddleware_opDeleteRoute(region string) *awsmiddleware.RegisterServiceMetadata {
123	return &awsmiddleware.RegisterServiceMetadata{
124		Region:        region,
125		ServiceID:     ServiceID,
126		SigningName:   "ec2",
127		OperationName: "DeleteRoute",
128	}
129}
130