1package network
2
3// Copyright (c) Microsoft and contributors.  All rights reserved.
4//
5// Licensed under the Apache License, Version 2.0 (the "License");
6// you may not use this file except in compliance with the License.
7// You may obtain a copy of the License at
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13//
14// See the License for the specific language governing permissions and
15// limitations under the License.
16//
17// Code generated by Microsoft (R) AutoRest Code Generator.
18// Changes may cause incorrect behavior and will be lost if the code is regenerated.
19
20import (
21	"context"
22	"github.com/Azure/go-autorest/autorest"
23	"github.com/Azure/go-autorest/autorest/azure"
24	"net/http"
25)
26
27// InterfaceLoadBalancersClient is the network Client
28type InterfaceLoadBalancersClient struct {
29	BaseClient
30}
31
32// NewInterfaceLoadBalancersClient creates an instance of the InterfaceLoadBalancersClient client.
33func NewInterfaceLoadBalancersClient(subscriptionID string) InterfaceLoadBalancersClient {
34	return NewInterfaceLoadBalancersClientWithBaseURI(DefaultBaseURI, subscriptionID)
35}
36
37// NewInterfaceLoadBalancersClientWithBaseURI creates an instance of the InterfaceLoadBalancersClient client.
38func NewInterfaceLoadBalancersClientWithBaseURI(baseURI string, subscriptionID string) InterfaceLoadBalancersClient {
39	return InterfaceLoadBalancersClient{NewWithBaseURI(baseURI, subscriptionID)}
40}
41
42// List list all load balancers in a network interface.
43// Parameters:
44// resourceGroupName - the name of the resource group.
45// networkInterfaceName - the name of the network interface.
46func (client InterfaceLoadBalancersClient) List(ctx context.Context, resourceGroupName string, networkInterfaceName string) (result InterfaceLoadBalancerListResultPage, err error) {
47	result.fn = client.listNextResults
48	req, err := client.ListPreparer(ctx, resourceGroupName, networkInterfaceName)
49	if err != nil {
50		err = autorest.NewErrorWithError(err, "network.InterfaceLoadBalancersClient", "List", nil, "Failure preparing request")
51		return
52	}
53
54	resp, err := client.ListSender(req)
55	if err != nil {
56		result.ilblr.Response = autorest.Response{Response: resp}
57		err = autorest.NewErrorWithError(err, "network.InterfaceLoadBalancersClient", "List", resp, "Failure sending request")
58		return
59	}
60
61	result.ilblr, err = client.ListResponder(resp)
62	if err != nil {
63		err = autorest.NewErrorWithError(err, "network.InterfaceLoadBalancersClient", "List", resp, "Failure responding to request")
64	}
65
66	return
67}
68
69// ListPreparer prepares the List request.
70func (client InterfaceLoadBalancersClient) ListPreparer(ctx context.Context, resourceGroupName string, networkInterfaceName string) (*http.Request, error) {
71	pathParameters := map[string]interface{}{
72		"networkInterfaceName": autorest.Encode("path", networkInterfaceName),
73		"resourceGroupName":    autorest.Encode("path", resourceGroupName),
74		"subscriptionId":       autorest.Encode("path", client.SubscriptionID),
75	}
76
77	const APIVersion = "2017-09-01"
78	queryParameters := map[string]interface{}{
79		"api-version": APIVersion,
80	}
81
82	preparer := autorest.CreatePreparer(
83		autorest.AsGet(),
84		autorest.WithBaseURL(client.BaseURI),
85		autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/loadBalancers", pathParameters),
86		autorest.WithQueryParameters(queryParameters))
87	return preparer.Prepare((&http.Request{}).WithContext(ctx))
88}
89
90// ListSender sends the List request. The method will close the
91// http.Response Body if it receives an error.
92func (client InterfaceLoadBalancersClient) ListSender(req *http.Request) (*http.Response, error) {
93	return autorest.SendWithSender(client, req,
94		azure.DoRetryWithRegistration(client.Client))
95}
96
97// ListResponder handles the response to the List request. The method always
98// closes the http.Response Body.
99func (client InterfaceLoadBalancersClient) ListResponder(resp *http.Response) (result InterfaceLoadBalancerListResult, err error) {
100	err = autorest.Respond(
101		resp,
102		client.ByInspecting(),
103		azure.WithErrorUnlessStatusCode(http.StatusOK),
104		autorest.ByUnmarshallingJSON(&result),
105		autorest.ByClosing())
106	result.Response = autorest.Response{Response: resp}
107	return
108}
109
110// listNextResults retrieves the next set of results, if any.
111func (client InterfaceLoadBalancersClient) listNextResults(lastResults InterfaceLoadBalancerListResult) (result InterfaceLoadBalancerListResult, err error) {
112	req, err := lastResults.interfaceLoadBalancerListResultPreparer()
113	if err != nil {
114		return result, autorest.NewErrorWithError(err, "network.InterfaceLoadBalancersClient", "listNextResults", nil, "Failure preparing next results request")
115	}
116	if req == nil {
117		return
118	}
119	resp, err := client.ListSender(req)
120	if err != nil {
121		result.Response = autorest.Response{Response: resp}
122		return result, autorest.NewErrorWithError(err, "network.InterfaceLoadBalancersClient", "listNextResults", resp, "Failure sending next results request")
123	}
124	result, err = client.ListResponder(resp)
125	if err != nil {
126		err = autorest.NewErrorWithError(err, "network.InterfaceLoadBalancersClient", "listNextResults", resp, "Failure responding to next results request")
127	}
128	return
129}
130
131// ListComplete enumerates all values, automatically crossing page boundaries as required.
132func (client InterfaceLoadBalancersClient) ListComplete(ctx context.Context, resourceGroupName string, networkInterfaceName string) (result InterfaceLoadBalancerListResultIterator, err error) {
133	result.page, err = client.List(ctx, resourceGroupName, networkInterfaceName)
134	return
135}
136