1package dtl 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// FormulaClient is the azure DevTest Labs REST API version 2015-05-21-preview. 18type FormulaClient struct { 19 BaseClient 20} 21 22// NewFormulaClient creates an instance of the FormulaClient client. 23func NewFormulaClient(subscriptionID string) FormulaClient { 24 return NewFormulaClientWithBaseURI(DefaultBaseURI, subscriptionID) 25} 26 27// NewFormulaClientWithBaseURI creates an instance of the FormulaClient client using a custom endpoint. Use this when 28// interacting with an Azure cloud that uses a non-standard base URI (sovereign clouds, Azure stack). 29func NewFormulaClientWithBaseURI(baseURI string, subscriptionID string) FormulaClient { 30 return FormulaClient{NewWithBaseURI(baseURI, subscriptionID)} 31} 32 33// CreateOrUpdateResource create or replace an existing Formula. This operation can take a while to complete. 34// Parameters: 35// resourceGroupName - the name of the resource group. 36// labName - the name of the lab. 37// name - the name of the formula. 38func (client FormulaClient) CreateOrUpdateResource(ctx context.Context, resourceGroupName string, labName string, name string, formula Formula) (result FormulaCreateOrUpdateResourceFuture, err error) { 39 if tracing.IsEnabled() { 40 ctx = tracing.StartSpan(ctx, fqdn+"/FormulaClient.CreateOrUpdateResource") 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.CreateOrUpdateResourcePreparer(ctx, resourceGroupName, labName, name, formula) 50 if err != nil { 51 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "CreateOrUpdateResource", nil, "Failure preparing request") 52 return 53 } 54 55 result, err = client.CreateOrUpdateResourceSender(req) 56 if err != nil { 57 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "CreateOrUpdateResource", nil, "Failure sending request") 58 return 59 } 60 61 return 62} 63 64// CreateOrUpdateResourcePreparer prepares the CreateOrUpdateResource request. 65func (client FormulaClient) CreateOrUpdateResourcePreparer(ctx context.Context, resourceGroupName string, labName string, name string, formula Formula) (*http.Request, error) { 66 pathParameters := map[string]interface{}{ 67 "labName": autorest.Encode("path", labName), 68 "name": autorest.Encode("path", name), 69 "resourceGroupName": autorest.Encode("path", resourceGroupName), 70 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 71 } 72 73 const APIVersion = "2015-05-21-preview" 74 queryParameters := map[string]interface{}{ 75 "api-version": APIVersion, 76 } 77 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.DevTestLab/labs/{labName}/formulas/{name}", pathParameters), 83 autorest.WithJSON(formula), 84 autorest.WithQueryParameters(queryParameters)) 85 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 86} 87 88// CreateOrUpdateResourceSender sends the CreateOrUpdateResource request. The method will close the 89// http.Response Body if it receives an error. 90func (client FormulaClient) CreateOrUpdateResourceSender(req *http.Request) (future FormulaCreateOrUpdateResourceFuture, 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// CreateOrUpdateResourceResponder handles the response to the CreateOrUpdateResource request. The method always 104// closes the http.Response Body. 105func (client FormulaClient) CreateOrUpdateResourceResponder(resp *http.Response) (result Formula, 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// DeleteResource delete formula. 116// Parameters: 117// resourceGroupName - the name of the resource group. 118// labName - the name of the lab. 119// name - the name of the formula. 120func (client FormulaClient) DeleteResource(ctx context.Context, resourceGroupName string, labName string, name string) (result autorest.Response, err error) { 121 if tracing.IsEnabled() { 122 ctx = tracing.StartSpan(ctx, fqdn+"/FormulaClient.DeleteResource") 123 defer func() { 124 sc := -1 125 if result.Response != nil { 126 sc = result.Response.StatusCode 127 } 128 tracing.EndSpan(ctx, sc, err) 129 }() 130 } 131 req, err := client.DeleteResourcePreparer(ctx, resourceGroupName, labName, name) 132 if err != nil { 133 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "DeleteResource", nil, "Failure preparing request") 134 return 135 } 136 137 resp, err := client.DeleteResourceSender(req) 138 if err != nil { 139 result.Response = resp 140 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "DeleteResource", resp, "Failure sending request") 141 return 142 } 143 144 result, err = client.DeleteResourceResponder(resp) 145 if err != nil { 146 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "DeleteResource", resp, "Failure responding to request") 147 return 148 } 149 150 return 151} 152 153// DeleteResourcePreparer prepares the DeleteResource request. 154func (client FormulaClient) DeleteResourcePreparer(ctx context.Context, resourceGroupName string, labName string, name string) (*http.Request, error) { 155 pathParameters := map[string]interface{}{ 156 "labName": autorest.Encode("path", labName), 157 "name": autorest.Encode("path", name), 158 "resourceGroupName": autorest.Encode("path", resourceGroupName), 159 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 160 } 161 162 const APIVersion = "2015-05-21-preview" 163 queryParameters := map[string]interface{}{ 164 "api-version": APIVersion, 165 } 166 167 preparer := autorest.CreatePreparer( 168 autorest.AsDelete(), 169 autorest.WithBaseURL(client.BaseURI), 170 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DevTestLab/labs/{labName}/formulas/{name}", pathParameters), 171 autorest.WithQueryParameters(queryParameters)) 172 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 173} 174 175// DeleteResourceSender sends the DeleteResource request. The method will close the 176// http.Response Body if it receives an error. 177func (client FormulaClient) DeleteResourceSender(req *http.Request) (*http.Response, error) { 178 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 179} 180 181// DeleteResourceResponder handles the response to the DeleteResource request. The method always 182// closes the http.Response Body. 183func (client FormulaClient) DeleteResourceResponder(resp *http.Response) (result autorest.Response, err error) { 184 err = autorest.Respond( 185 resp, 186 azure.WithErrorUnlessStatusCode(http.StatusOK, http.StatusNoContent), 187 autorest.ByClosing()) 188 result.Response = resp 189 return 190} 191 192// GetResource get formula. 193// Parameters: 194// resourceGroupName - the name of the resource group. 195// labName - the name of the lab. 196// name - the name of the formula. 197func (client FormulaClient) GetResource(ctx context.Context, resourceGroupName string, labName string, name string) (result Formula, err error) { 198 if tracing.IsEnabled() { 199 ctx = tracing.StartSpan(ctx, fqdn+"/FormulaClient.GetResource") 200 defer func() { 201 sc := -1 202 if result.Response.Response != nil { 203 sc = result.Response.Response.StatusCode 204 } 205 tracing.EndSpan(ctx, sc, err) 206 }() 207 } 208 req, err := client.GetResourcePreparer(ctx, resourceGroupName, labName, name) 209 if err != nil { 210 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "GetResource", nil, "Failure preparing request") 211 return 212 } 213 214 resp, err := client.GetResourceSender(req) 215 if err != nil { 216 result.Response = autorest.Response{Response: resp} 217 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "GetResource", resp, "Failure sending request") 218 return 219 } 220 221 result, err = client.GetResourceResponder(resp) 222 if err != nil { 223 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "GetResource", resp, "Failure responding to request") 224 return 225 } 226 227 return 228} 229 230// GetResourcePreparer prepares the GetResource request. 231func (client FormulaClient) GetResourcePreparer(ctx context.Context, resourceGroupName string, labName string, name string) (*http.Request, error) { 232 pathParameters := map[string]interface{}{ 233 "labName": autorest.Encode("path", labName), 234 "name": autorest.Encode("path", name), 235 "resourceGroupName": autorest.Encode("path", resourceGroupName), 236 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 237 } 238 239 const APIVersion = "2015-05-21-preview" 240 queryParameters := map[string]interface{}{ 241 "api-version": APIVersion, 242 } 243 244 preparer := autorest.CreatePreparer( 245 autorest.AsGet(), 246 autorest.WithBaseURL(client.BaseURI), 247 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DevTestLab/labs/{labName}/formulas/{name}", pathParameters), 248 autorest.WithQueryParameters(queryParameters)) 249 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 250} 251 252// GetResourceSender sends the GetResource request. The method will close the 253// http.Response Body if it receives an error. 254func (client FormulaClient) GetResourceSender(req *http.Request) (*http.Response, error) { 255 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 256} 257 258// GetResourceResponder handles the response to the GetResource request. The method always 259// closes the http.Response Body. 260func (client FormulaClient) GetResourceResponder(resp *http.Response) (result Formula, err error) { 261 err = autorest.Respond( 262 resp, 263 azure.WithErrorUnlessStatusCode(http.StatusOK), 264 autorest.ByUnmarshallingJSON(&result), 265 autorest.ByClosing()) 266 result.Response = autorest.Response{Response: resp} 267 return 268} 269 270// List list formulas. 271// Parameters: 272// resourceGroupName - the name of the resource group. 273// labName - the name of the lab. 274// filter - the filter to apply on the operation. 275func (client FormulaClient) List(ctx context.Context, resourceGroupName string, labName string, filter string, top *int32, orderBy string) (result ResponseWithContinuationFormulaPage, err error) { 276 if tracing.IsEnabled() { 277 ctx = tracing.StartSpan(ctx, fqdn+"/FormulaClient.List") 278 defer func() { 279 sc := -1 280 if result.rwcf.Response.Response != nil { 281 sc = result.rwcf.Response.Response.StatusCode 282 } 283 tracing.EndSpan(ctx, sc, err) 284 }() 285 } 286 result.fn = client.listNextResults 287 req, err := client.ListPreparer(ctx, resourceGroupName, labName, filter, top, orderBy) 288 if err != nil { 289 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "List", nil, "Failure preparing request") 290 return 291 } 292 293 resp, err := client.ListSender(req) 294 if err != nil { 295 result.rwcf.Response = autorest.Response{Response: resp} 296 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "List", resp, "Failure sending request") 297 return 298 } 299 300 result.rwcf, err = client.ListResponder(resp) 301 if err != nil { 302 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "List", resp, "Failure responding to request") 303 return 304 } 305 if result.rwcf.hasNextLink() && result.rwcf.IsEmpty() { 306 err = result.NextWithContext(ctx) 307 return 308 } 309 310 return 311} 312 313// ListPreparer prepares the List request. 314func (client FormulaClient) ListPreparer(ctx context.Context, resourceGroupName string, labName string, filter string, top *int32, orderBy string) (*http.Request, error) { 315 pathParameters := map[string]interface{}{ 316 "labName": autorest.Encode("path", labName), 317 "resourceGroupName": autorest.Encode("path", resourceGroupName), 318 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 319 } 320 321 const APIVersion = "2015-05-21-preview" 322 queryParameters := map[string]interface{}{ 323 "api-version": APIVersion, 324 } 325 if len(filter) > 0 { 326 queryParameters["$filter"] = autorest.Encode("query", filter) 327 } 328 if top != nil { 329 queryParameters["$top"] = autorest.Encode("query", *top) 330 } 331 if len(orderBy) > 0 { 332 queryParameters["$orderBy"] = autorest.Encode("query", orderBy) 333 } 334 335 preparer := autorest.CreatePreparer( 336 autorest.AsGet(), 337 autorest.WithBaseURL(client.BaseURI), 338 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DevTestLab/labs/{labName}/formulas", pathParameters), 339 autorest.WithQueryParameters(queryParameters)) 340 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 341} 342 343// ListSender sends the List request. The method will close the 344// http.Response Body if it receives an error. 345func (client FormulaClient) ListSender(req *http.Request) (*http.Response, error) { 346 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 347} 348 349// ListResponder handles the response to the List request. The method always 350// closes the http.Response Body. 351func (client FormulaClient) ListResponder(resp *http.Response) (result ResponseWithContinuationFormula, err error) { 352 err = autorest.Respond( 353 resp, 354 azure.WithErrorUnlessStatusCode(http.StatusOK), 355 autorest.ByUnmarshallingJSON(&result), 356 autorest.ByClosing()) 357 result.Response = autorest.Response{Response: resp} 358 return 359} 360 361// listNextResults retrieves the next set of results, if any. 362func (client FormulaClient) listNextResults(ctx context.Context, lastResults ResponseWithContinuationFormula) (result ResponseWithContinuationFormula, err error) { 363 req, err := lastResults.responseWithContinuationFormulaPreparer(ctx) 364 if err != nil { 365 return result, autorest.NewErrorWithError(err, "dtl.FormulaClient", "listNextResults", nil, "Failure preparing next results request") 366 } 367 if req == nil { 368 return 369 } 370 resp, err := client.ListSender(req) 371 if err != nil { 372 result.Response = autorest.Response{Response: resp} 373 return result, autorest.NewErrorWithError(err, "dtl.FormulaClient", "listNextResults", resp, "Failure sending next results request") 374 } 375 result, err = client.ListResponder(resp) 376 if err != nil { 377 err = autorest.NewErrorWithError(err, "dtl.FormulaClient", "listNextResults", resp, "Failure responding to next results request") 378 } 379 return 380} 381 382// ListComplete enumerates all values, automatically crossing page boundaries as required. 383func (client FormulaClient) ListComplete(ctx context.Context, resourceGroupName string, labName string, filter string, top *int32, orderBy string) (result ResponseWithContinuationFormulaIterator, err error) { 384 if tracing.IsEnabled() { 385 ctx = tracing.StartSpan(ctx, fqdn+"/FormulaClient.List") 386 defer func() { 387 sc := -1 388 if result.Response().Response.Response != nil { 389 sc = result.page.Response().Response.Response.StatusCode 390 } 391 tracing.EndSpan(ctx, sc, err) 392 }() 393 } 394 result.page, err = client.List(ctx, resourceGroupName, labName, filter, top, orderBy) 395 return 396} 397