api_op_GetLoadBalancers.go raw
1 // Code generated by smithy-go-codegen DO NOT EDIT.
2
3 package lightsail
4
5 import (
6 "context"
7 "fmt"
8 awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
9 "github.com/aws/aws-sdk-go-v2/service/lightsail/types"
10 "github.com/aws/smithy-go/middleware"
11 smithyhttp "github.com/aws/smithy-go/transport/http"
12 )
13
14 // Returns information about all load balancers in an account.
15 func (c *Client) GetLoadBalancers(ctx context.Context, params *GetLoadBalancersInput, optFns ...func(*Options)) (*GetLoadBalancersOutput, error) {
16 if params == nil {
17 params = &GetLoadBalancersInput{}
18 }
19
20 result, metadata, err := c.invokeOperation(ctx, "GetLoadBalancers", params, optFns, c.addOperationGetLoadBalancersMiddlewares)
21 if err != nil {
22 return nil, err
23 }
24
25 out := result.(*GetLoadBalancersOutput)
26 out.ResultMetadata = metadata
27 return out, nil
28 }
29
30 type GetLoadBalancersInput struct {
31
32 // The token to advance to the next page of results from your request.
33 //
34 // To get a page token, perform an initial GetLoadBalancers request. If your
35 // results are paginated, the response will return a next page token that you can
36 // specify as the page token in a subsequent request.
37 PageToken *string
38
39 noSmithyDocumentSerde
40 }
41
42 type GetLoadBalancersOutput struct {
43
44 // An array of LoadBalancer objects describing your load balancers.
45 LoadBalancers []types.LoadBalancer
46
47 // The token to advance to the next page of results from your request.
48 //
49 // A next page token is not returned if there are no more results to display.
50 //
51 // To get the next page of results, perform another GetLoadBalancers request and
52 // specify the next page token using the pageToken parameter.
53 NextPageToken *string
54
55 // Metadata pertaining to the operation's result.
56 ResultMetadata middleware.Metadata
57
58 noSmithyDocumentSerde
59 }
60
61 func (c *Client) addOperationGetLoadBalancersMiddlewares(stack *middleware.Stack, options Options) (err error) {
62 if err := stack.Serialize.Add(&setOperationInputMiddleware{}, middleware.After); err != nil {
63 return err
64 }
65 err = stack.Serialize.Add(&awsAwsjson11_serializeOpGetLoadBalancers{}, middleware.After)
66 if err != nil {
67 return err
68 }
69 err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpGetLoadBalancers{}, middleware.After)
70 if err != nil {
71 return err
72 }
73 if err := addProtocolFinalizerMiddlewares(stack, options, "GetLoadBalancers"); err != nil {
74 return fmt.Errorf("add protocol finalizers: %v", err)
75 }
76
77 if err = addlegacyEndpointContextSetter(stack, options); err != nil {
78 return err
79 }
80 if err = addSetLoggerMiddleware(stack, options); err != nil {
81 return err
82 }
83 if err = addClientRequestID(stack); err != nil {
84 return err
85 }
86 if err = addComputeContentLength(stack); err != nil {
87 return err
88 }
89 if err = addResolveEndpointMiddleware(stack, options); err != nil {
90 return err
91 }
92 if err = addComputePayloadSHA256(stack); err != nil {
93 return err
94 }
95 if err = addRetry(stack, options); err != nil {
96 return err
97 }
98 if err = addRawResponseToMetadata(stack); err != nil {
99 return err
100 }
101 if err = addRecordResponseTiming(stack); err != nil {
102 return err
103 }
104 if err = addSpanRetryLoop(stack, options); err != nil {
105 return err
106 }
107 if err = addClientUserAgent(stack, options); err != nil {
108 return err
109 }
110 if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
111 return err
112 }
113 if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
114 return err
115 }
116 if err = addSetLegacyContextSigningOptionsMiddleware(stack); err != nil {
117 return err
118 }
119 if err = addTimeOffsetBuild(stack, c); err != nil {
120 return err
121 }
122 if err = addUserAgentRetryMode(stack, options); err != nil {
123 return err
124 }
125 if err = addCredentialSource(stack, options); err != nil {
126 return err
127 }
128 if err = stack.Initialize.Add(newServiceMetadataMiddleware_opGetLoadBalancers(options.Region), middleware.Before); err != nil {
129 return err
130 }
131 if err = addRecursionDetection(stack); err != nil {
132 return err
133 }
134 if err = addRequestIDRetrieverMiddleware(stack); err != nil {
135 return err
136 }
137 if err = addResponseErrorMiddleware(stack); err != nil {
138 return err
139 }
140 if err = addRequestResponseLogging(stack, options); err != nil {
141 return err
142 }
143 if err = addDisableHTTPSMiddleware(stack, options); err != nil {
144 return err
145 }
146 if err = addInterceptBeforeRetryLoop(stack, options); err != nil {
147 return err
148 }
149 if err = addInterceptAttempt(stack, options); err != nil {
150 return err
151 }
152 if err = addInterceptors(stack, options); err != nil {
153 return err
154 }
155 return nil
156 }
157
158 func newServiceMetadataMiddleware_opGetLoadBalancers(region string) *awsmiddleware.RegisterServiceMetadata {
159 return &awsmiddleware.RegisterServiceMetadata{
160 Region: region,
161 ServiceID: ServiceID,
162 OperationName: "GetLoadBalancers",
163 }
164 }
165