1package network
2
3// Copyright (c) Microsoft Corporation. All rights reserved.
4// Licensed under the MIT License. See License.txt in the project root for license information.
5//
6// Code generated by Microsoft (R) AutoRest Code Generator.
7// Changes may cause incorrect behavior and will be lost if the code is regenerated.
8
9import (
10	"context"
11	"github.com/Azure/go-autorest/autorest"
12	"github.com/Azure/go-autorest/autorest/azure"
13	"github.com/Azure/go-autorest/tracing"
14	"net/http"
15)
16
17// AzureFirewallsClient is the network Client
18type AzureFirewallsClient struct {
19	BaseClient
20}
21
22// NewAzureFirewallsClient creates an instance of the AzureFirewallsClient client.
23func NewAzureFirewallsClient(subscriptionID string) AzureFirewallsClient {
24	return NewAzureFirewallsClientWithBaseURI(DefaultBaseURI, subscriptionID)
25}
26
27// NewAzureFirewallsClientWithBaseURI creates an instance of the AzureFirewallsClient client using a custom endpoint.
28// Use this when interacting with an Azure cloud that uses a non-standard base URI (sovereign clouds, Azure stack).
29func NewAzureFirewallsClientWithBaseURI(baseURI string, subscriptionID string) AzureFirewallsClient {
30	return AzureFirewallsClient{NewWithBaseURI(baseURI, subscriptionID)}
31}
32
33// CreateOrUpdate creates or updates the specified Azure Firewall.
34// Parameters:
35// resourceGroupName - the name of the resource group.
36// azureFirewallName - the name of the Azure Firewall.
37// parameters - parameters supplied to the create or update Azure Firewall operation.
38func (client AzureFirewallsClient) CreateOrUpdate(ctx context.Context, resourceGroupName string, azureFirewallName string, parameters AzureFirewall) (result AzureFirewallsCreateOrUpdateFuture, err error) {
39	if tracing.IsEnabled() {
40		ctx = tracing.StartSpan(ctx, fqdn+"/AzureFirewallsClient.CreateOrUpdate")
41		defer func() {
42			sc := -1
43			if result.FutureAPI != nil && result.FutureAPI.Response() != nil {
44				sc = result.FutureAPI.Response().StatusCode
45			}
46			tracing.EndSpan(ctx, sc, err)
47		}()
48	}
49	req, err := client.CreateOrUpdatePreparer(ctx, resourceGroupName, azureFirewallName, parameters)
50	if err != nil {
51		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "CreateOrUpdate", nil, "Failure preparing request")
52		return
53	}
54
55	result, err = client.CreateOrUpdateSender(req)
56	if err != nil {
57		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "CreateOrUpdate", nil, "Failure sending request")
58		return
59	}
60
61	return
62}
63
64// CreateOrUpdatePreparer prepares the CreateOrUpdate request.
65func (client AzureFirewallsClient) CreateOrUpdatePreparer(ctx context.Context, resourceGroupName string, azureFirewallName string, parameters AzureFirewall) (*http.Request, error) {
66	pathParameters := map[string]interface{}{
67		"azureFirewallName": autorest.Encode("path", azureFirewallName),
68		"resourceGroupName": autorest.Encode("path", resourceGroupName),
69		"subscriptionId":    autorest.Encode("path", client.SubscriptionID),
70	}
71
72	const APIVersion = "2019-09-01"
73	queryParameters := map[string]interface{}{
74		"api-version": APIVersion,
75	}
76
77	parameters.Etag = nil
78	preparer := autorest.CreatePreparer(
79		autorest.AsContentType("application/json; charset=utf-8"),
80		autorest.AsPut(),
81		autorest.WithBaseURL(client.BaseURI),
82		autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}", pathParameters),
83		autorest.WithJSON(parameters),
84		autorest.WithQueryParameters(queryParameters))
85	return preparer.Prepare((&http.Request{}).WithContext(ctx))
86}
87
88// CreateOrUpdateSender sends the CreateOrUpdate request. The method will close the
89// http.Response Body if it receives an error.
90func (client AzureFirewallsClient) CreateOrUpdateSender(req *http.Request) (future AzureFirewallsCreateOrUpdateFuture, err error) {
91	var resp *http.Response
92	resp, err = client.Send(req, azure.DoRetryWithRegistration(client.Client))
93	if err != nil {
94		return
95	}
96	var azf azure.Future
97	azf, err = azure.NewFutureFromResponse(resp)
98	future.FutureAPI = &azf
99	future.Result = future.result
100	return
101}
102
103// CreateOrUpdateResponder handles the response to the CreateOrUpdate request. The method always
104// closes the http.Response Body.
105func (client AzureFirewallsClient) CreateOrUpdateResponder(resp *http.Response) (result AzureFirewall, err error) {
106	err = autorest.Respond(
107		resp,
108		azure.WithErrorUnlessStatusCode(http.StatusOK, http.StatusCreated),
109		autorest.ByUnmarshallingJSON(&result),
110		autorest.ByClosing())
111	result.Response = autorest.Response{Response: resp}
112	return
113}
114
115// Delete deletes the specified Azure Firewall.
116// Parameters:
117// resourceGroupName - the name of the resource group.
118// azureFirewallName - the name of the Azure Firewall.
119func (client AzureFirewallsClient) Delete(ctx context.Context, resourceGroupName string, azureFirewallName string) (result AzureFirewallsDeleteFuture, err error) {
120	if tracing.IsEnabled() {
121		ctx = tracing.StartSpan(ctx, fqdn+"/AzureFirewallsClient.Delete")
122		defer func() {
123			sc := -1
124			if result.FutureAPI != nil && result.FutureAPI.Response() != nil {
125				sc = result.FutureAPI.Response().StatusCode
126			}
127			tracing.EndSpan(ctx, sc, err)
128		}()
129	}
130	req, err := client.DeletePreparer(ctx, resourceGroupName, azureFirewallName)
131	if err != nil {
132		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "Delete", nil, "Failure preparing request")
133		return
134	}
135
136	result, err = client.DeleteSender(req)
137	if err != nil {
138		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "Delete", nil, "Failure sending request")
139		return
140	}
141
142	return
143}
144
145// DeletePreparer prepares the Delete request.
146func (client AzureFirewallsClient) DeletePreparer(ctx context.Context, resourceGroupName string, azureFirewallName string) (*http.Request, error) {
147	pathParameters := map[string]interface{}{
148		"azureFirewallName": autorest.Encode("path", azureFirewallName),
149		"resourceGroupName": autorest.Encode("path", resourceGroupName),
150		"subscriptionId":    autorest.Encode("path", client.SubscriptionID),
151	}
152
153	const APIVersion = "2019-09-01"
154	queryParameters := map[string]interface{}{
155		"api-version": APIVersion,
156	}
157
158	preparer := autorest.CreatePreparer(
159		autorest.AsDelete(),
160		autorest.WithBaseURL(client.BaseURI),
161		autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}", pathParameters),
162		autorest.WithQueryParameters(queryParameters))
163	return preparer.Prepare((&http.Request{}).WithContext(ctx))
164}
165
166// DeleteSender sends the Delete request. The method will close the
167// http.Response Body if it receives an error.
168func (client AzureFirewallsClient) DeleteSender(req *http.Request) (future AzureFirewallsDeleteFuture, err error) {
169	var resp *http.Response
170	resp, err = client.Send(req, azure.DoRetryWithRegistration(client.Client))
171	if err != nil {
172		return
173	}
174	var azf azure.Future
175	azf, err = azure.NewFutureFromResponse(resp)
176	future.FutureAPI = &azf
177	future.Result = future.result
178	return
179}
180
181// DeleteResponder handles the response to the Delete request. The method always
182// closes the http.Response Body.
183func (client AzureFirewallsClient) DeleteResponder(resp *http.Response) (result autorest.Response, err error) {
184	err = autorest.Respond(
185		resp,
186		azure.WithErrorUnlessStatusCode(http.StatusOK, http.StatusAccepted, http.StatusNoContent),
187		autorest.ByClosing())
188	result.Response = resp
189	return
190}
191
192// Get gets the specified Azure Firewall.
193// Parameters:
194// resourceGroupName - the name of the resource group.
195// azureFirewallName - the name of the Azure Firewall.
196func (client AzureFirewallsClient) Get(ctx context.Context, resourceGroupName string, azureFirewallName string) (result AzureFirewall, err error) {
197	if tracing.IsEnabled() {
198		ctx = tracing.StartSpan(ctx, fqdn+"/AzureFirewallsClient.Get")
199		defer func() {
200			sc := -1
201			if result.Response.Response != nil {
202				sc = result.Response.Response.StatusCode
203			}
204			tracing.EndSpan(ctx, sc, err)
205		}()
206	}
207	req, err := client.GetPreparer(ctx, resourceGroupName, azureFirewallName)
208	if err != nil {
209		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "Get", nil, "Failure preparing request")
210		return
211	}
212
213	resp, err := client.GetSender(req)
214	if err != nil {
215		result.Response = autorest.Response{Response: resp}
216		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "Get", resp, "Failure sending request")
217		return
218	}
219
220	result, err = client.GetResponder(resp)
221	if err != nil {
222		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "Get", resp, "Failure responding to request")
223		return
224	}
225
226	return
227}
228
229// GetPreparer prepares the Get request.
230func (client AzureFirewallsClient) GetPreparer(ctx context.Context, resourceGroupName string, azureFirewallName string) (*http.Request, error) {
231	pathParameters := map[string]interface{}{
232		"azureFirewallName": autorest.Encode("path", azureFirewallName),
233		"resourceGroupName": autorest.Encode("path", resourceGroupName),
234		"subscriptionId":    autorest.Encode("path", client.SubscriptionID),
235	}
236
237	const APIVersion = "2019-09-01"
238	queryParameters := map[string]interface{}{
239		"api-version": APIVersion,
240	}
241
242	preparer := autorest.CreatePreparer(
243		autorest.AsGet(),
244		autorest.WithBaseURL(client.BaseURI),
245		autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}", pathParameters),
246		autorest.WithQueryParameters(queryParameters))
247	return preparer.Prepare((&http.Request{}).WithContext(ctx))
248}
249
250// GetSender sends the Get request. The method will close the
251// http.Response Body if it receives an error.
252func (client AzureFirewallsClient) GetSender(req *http.Request) (*http.Response, error) {
253	return client.Send(req, azure.DoRetryWithRegistration(client.Client))
254}
255
256// GetResponder handles the response to the Get request. The method always
257// closes the http.Response Body.
258func (client AzureFirewallsClient) GetResponder(resp *http.Response) (result AzureFirewall, err error) {
259	err = autorest.Respond(
260		resp,
261		azure.WithErrorUnlessStatusCode(http.StatusOK),
262		autorest.ByUnmarshallingJSON(&result),
263		autorest.ByClosing())
264	result.Response = autorest.Response{Response: resp}
265	return
266}
267
268// List lists all Azure Firewalls in a resource group.
269// Parameters:
270// resourceGroupName - the name of the resource group.
271func (client AzureFirewallsClient) List(ctx context.Context, resourceGroupName string) (result AzureFirewallListResultPage, err error) {
272	if tracing.IsEnabled() {
273		ctx = tracing.StartSpan(ctx, fqdn+"/AzureFirewallsClient.List")
274		defer func() {
275			sc := -1
276			if result.aflr.Response.Response != nil {
277				sc = result.aflr.Response.Response.StatusCode
278			}
279			tracing.EndSpan(ctx, sc, err)
280		}()
281	}
282	result.fn = client.listNextResults
283	req, err := client.ListPreparer(ctx, resourceGroupName)
284	if err != nil {
285		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "List", nil, "Failure preparing request")
286		return
287	}
288
289	resp, err := client.ListSender(req)
290	if err != nil {
291		result.aflr.Response = autorest.Response{Response: resp}
292		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "List", resp, "Failure sending request")
293		return
294	}
295
296	result.aflr, err = client.ListResponder(resp)
297	if err != nil {
298		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "List", resp, "Failure responding to request")
299		return
300	}
301	if result.aflr.hasNextLink() && result.aflr.IsEmpty() {
302		err = result.NextWithContext(ctx)
303		return
304	}
305
306	return
307}
308
309// ListPreparer prepares the List request.
310func (client AzureFirewallsClient) ListPreparer(ctx context.Context, resourceGroupName string) (*http.Request, error) {
311	pathParameters := map[string]interface{}{
312		"resourceGroupName": autorest.Encode("path", resourceGroupName),
313		"subscriptionId":    autorest.Encode("path", client.SubscriptionID),
314	}
315
316	const APIVersion = "2019-09-01"
317	queryParameters := map[string]interface{}{
318		"api-version": APIVersion,
319	}
320
321	preparer := autorest.CreatePreparer(
322		autorest.AsGet(),
323		autorest.WithBaseURL(client.BaseURI),
324		autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls", pathParameters),
325		autorest.WithQueryParameters(queryParameters))
326	return preparer.Prepare((&http.Request{}).WithContext(ctx))
327}
328
329// ListSender sends the List request. The method will close the
330// http.Response Body if it receives an error.
331func (client AzureFirewallsClient) ListSender(req *http.Request) (*http.Response, error) {
332	return client.Send(req, azure.DoRetryWithRegistration(client.Client))
333}
334
335// ListResponder handles the response to the List request. The method always
336// closes the http.Response Body.
337func (client AzureFirewallsClient) ListResponder(resp *http.Response) (result AzureFirewallListResult, err error) {
338	err = autorest.Respond(
339		resp,
340		azure.WithErrorUnlessStatusCode(http.StatusOK),
341		autorest.ByUnmarshallingJSON(&result),
342		autorest.ByClosing())
343	result.Response = autorest.Response{Response: resp}
344	return
345}
346
347// listNextResults retrieves the next set of results, if any.
348func (client AzureFirewallsClient) listNextResults(ctx context.Context, lastResults AzureFirewallListResult) (result AzureFirewallListResult, err error) {
349	req, err := lastResults.azureFirewallListResultPreparer(ctx)
350	if err != nil {
351		return result, autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "listNextResults", nil, "Failure preparing next results request")
352	}
353	if req == nil {
354		return
355	}
356	resp, err := client.ListSender(req)
357	if err != nil {
358		result.Response = autorest.Response{Response: resp}
359		return result, autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "listNextResults", resp, "Failure sending next results request")
360	}
361	result, err = client.ListResponder(resp)
362	if err != nil {
363		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "listNextResults", resp, "Failure responding to next results request")
364	}
365	return
366}
367
368// ListComplete enumerates all values, automatically crossing page boundaries as required.
369func (client AzureFirewallsClient) ListComplete(ctx context.Context, resourceGroupName string) (result AzureFirewallListResultIterator, err error) {
370	if tracing.IsEnabled() {
371		ctx = tracing.StartSpan(ctx, fqdn+"/AzureFirewallsClient.List")
372		defer func() {
373			sc := -1
374			if result.Response().Response.Response != nil {
375				sc = result.page.Response().Response.Response.StatusCode
376			}
377			tracing.EndSpan(ctx, sc, err)
378		}()
379	}
380	result.page, err = client.List(ctx, resourceGroupName)
381	return
382}
383
384// ListAll gets all the Azure Firewalls in a subscription.
385func (client AzureFirewallsClient) ListAll(ctx context.Context) (result AzureFirewallListResultPage, err error) {
386	if tracing.IsEnabled() {
387		ctx = tracing.StartSpan(ctx, fqdn+"/AzureFirewallsClient.ListAll")
388		defer func() {
389			sc := -1
390			if result.aflr.Response.Response != nil {
391				sc = result.aflr.Response.Response.StatusCode
392			}
393			tracing.EndSpan(ctx, sc, err)
394		}()
395	}
396	result.fn = client.listAllNextResults
397	req, err := client.ListAllPreparer(ctx)
398	if err != nil {
399		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "ListAll", nil, "Failure preparing request")
400		return
401	}
402
403	resp, err := client.ListAllSender(req)
404	if err != nil {
405		result.aflr.Response = autorest.Response{Response: resp}
406		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "ListAll", resp, "Failure sending request")
407		return
408	}
409
410	result.aflr, err = client.ListAllResponder(resp)
411	if err != nil {
412		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "ListAll", resp, "Failure responding to request")
413		return
414	}
415	if result.aflr.hasNextLink() && result.aflr.IsEmpty() {
416		err = result.NextWithContext(ctx)
417		return
418	}
419
420	return
421}
422
423// ListAllPreparer prepares the ListAll request.
424func (client AzureFirewallsClient) ListAllPreparer(ctx context.Context) (*http.Request, error) {
425	pathParameters := map[string]interface{}{
426		"subscriptionId": autorest.Encode("path", client.SubscriptionID),
427	}
428
429	const APIVersion = "2019-09-01"
430	queryParameters := map[string]interface{}{
431		"api-version": APIVersion,
432	}
433
434	preparer := autorest.CreatePreparer(
435		autorest.AsGet(),
436		autorest.WithBaseURL(client.BaseURI),
437		autorest.WithPathParameters("/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureFirewalls", pathParameters),
438		autorest.WithQueryParameters(queryParameters))
439	return preparer.Prepare((&http.Request{}).WithContext(ctx))
440}
441
442// ListAllSender sends the ListAll request. The method will close the
443// http.Response Body if it receives an error.
444func (client AzureFirewallsClient) ListAllSender(req *http.Request) (*http.Response, error) {
445	return client.Send(req, azure.DoRetryWithRegistration(client.Client))
446}
447
448// ListAllResponder handles the response to the ListAll request. The method always
449// closes the http.Response Body.
450func (client AzureFirewallsClient) ListAllResponder(resp *http.Response) (result AzureFirewallListResult, err error) {
451	err = autorest.Respond(
452		resp,
453		azure.WithErrorUnlessStatusCode(http.StatusOK),
454		autorest.ByUnmarshallingJSON(&result),
455		autorest.ByClosing())
456	result.Response = autorest.Response{Response: resp}
457	return
458}
459
460// listAllNextResults retrieves the next set of results, if any.
461func (client AzureFirewallsClient) listAllNextResults(ctx context.Context, lastResults AzureFirewallListResult) (result AzureFirewallListResult, err error) {
462	req, err := lastResults.azureFirewallListResultPreparer(ctx)
463	if err != nil {
464		return result, autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "listAllNextResults", nil, "Failure preparing next results request")
465	}
466	if req == nil {
467		return
468	}
469	resp, err := client.ListAllSender(req)
470	if err != nil {
471		result.Response = autorest.Response{Response: resp}
472		return result, autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "listAllNextResults", resp, "Failure sending next results request")
473	}
474	result, err = client.ListAllResponder(resp)
475	if err != nil {
476		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "listAllNextResults", resp, "Failure responding to next results request")
477	}
478	return
479}
480
481// ListAllComplete enumerates all values, automatically crossing page boundaries as required.
482func (client AzureFirewallsClient) ListAllComplete(ctx context.Context) (result AzureFirewallListResultIterator, err error) {
483	if tracing.IsEnabled() {
484		ctx = tracing.StartSpan(ctx, fqdn+"/AzureFirewallsClient.ListAll")
485		defer func() {
486			sc := -1
487			if result.Response().Response.Response != nil {
488				sc = result.page.Response().Response.Response.StatusCode
489			}
490			tracing.EndSpan(ctx, sc, err)
491		}()
492	}
493	result.page, err = client.ListAll(ctx)
494	return
495}
496
497// UpdateTags updates tags of an Azure Firewall resource.
498// Parameters:
499// resourceGroupName - the name of the resource group.
500// azureFirewallName - the name of the Azure Firewall.
501// parameters - parameters supplied to update azure firewall tags.
502func (client AzureFirewallsClient) UpdateTags(ctx context.Context, resourceGroupName string, azureFirewallName string, parameters TagsObject) (result AzureFirewallsUpdateTagsFuture, err error) {
503	if tracing.IsEnabled() {
504		ctx = tracing.StartSpan(ctx, fqdn+"/AzureFirewallsClient.UpdateTags")
505		defer func() {
506			sc := -1
507			if result.FutureAPI != nil && result.FutureAPI.Response() != nil {
508				sc = result.FutureAPI.Response().StatusCode
509			}
510			tracing.EndSpan(ctx, sc, err)
511		}()
512	}
513	req, err := client.UpdateTagsPreparer(ctx, resourceGroupName, azureFirewallName, parameters)
514	if err != nil {
515		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "UpdateTags", nil, "Failure preparing request")
516		return
517	}
518
519	result, err = client.UpdateTagsSender(req)
520	if err != nil {
521		err = autorest.NewErrorWithError(err, "network.AzureFirewallsClient", "UpdateTags", nil, "Failure sending request")
522		return
523	}
524
525	return
526}
527
528// UpdateTagsPreparer prepares the UpdateTags request.
529func (client AzureFirewallsClient) UpdateTagsPreparer(ctx context.Context, resourceGroupName string, azureFirewallName string, parameters TagsObject) (*http.Request, error) {
530	pathParameters := map[string]interface{}{
531		"azureFirewallName": autorest.Encode("path", azureFirewallName),
532		"resourceGroupName": autorest.Encode("path", resourceGroupName),
533		"subscriptionId":    autorest.Encode("path", client.SubscriptionID),
534	}
535
536	const APIVersion = "2019-09-01"
537	queryParameters := map[string]interface{}{
538		"api-version": APIVersion,
539	}
540
541	preparer := autorest.CreatePreparer(
542		autorest.AsContentType("application/json; charset=utf-8"),
543		autorest.AsPatch(),
544		autorest.WithBaseURL(client.BaseURI),
545		autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}", pathParameters),
546		autorest.WithJSON(parameters),
547		autorest.WithQueryParameters(queryParameters))
548	return preparer.Prepare((&http.Request{}).WithContext(ctx))
549}
550
551// UpdateTagsSender sends the UpdateTags request. The method will close the
552// http.Response Body if it receives an error.
553func (client AzureFirewallsClient) UpdateTagsSender(req *http.Request) (future AzureFirewallsUpdateTagsFuture, err error) {
554	var resp *http.Response
555	resp, err = client.Send(req, azure.DoRetryWithRegistration(client.Client))
556	if err != nil {
557		return
558	}
559	var azf azure.Future
560	azf, err = azure.NewFutureFromResponse(resp)
561	future.FutureAPI = &azf
562	future.Result = future.result
563	return
564}
565
566// UpdateTagsResponder handles the response to the UpdateTags request. The method always
567// closes the http.Response Body.
568func (client AzureFirewallsClient) UpdateTagsResponder(resp *http.Response) (result AzureFirewall, err error) {
569	err = autorest.Respond(
570		resp,
571		azure.WithErrorUnlessStatusCode(http.StatusOK, http.StatusAccepted),
572		autorest.ByUnmarshallingJSON(&result),
573		autorest.ByClosing())
574	result.Response = autorest.Response{Response: resp}
575	return
576}
577