1package sql 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 "github.com/Azure/go-autorest/tracing" 25 "net/http" 26) 27 28// SyncAgentsClient is the the Azure SQL Database management API provides a RESTful set of web services that interact 29// with Azure SQL Database services to manage your databases. The API enables you to create, retrieve, update, and 30// delete databases. 31type SyncAgentsClient struct { 32 BaseClient 33} 34 35// NewSyncAgentsClient creates an instance of the SyncAgentsClient client. 36func NewSyncAgentsClient(subscriptionID string) SyncAgentsClient { 37 return NewSyncAgentsClientWithBaseURI(DefaultBaseURI, subscriptionID) 38} 39 40// NewSyncAgentsClientWithBaseURI creates an instance of the SyncAgentsClient client using a custom endpoint. Use this 41// when interacting with an Azure cloud that uses a non-standard base URI (sovereign clouds, Azure stack). 42func NewSyncAgentsClientWithBaseURI(baseURI string, subscriptionID string) SyncAgentsClient { 43 return SyncAgentsClient{NewWithBaseURI(baseURI, subscriptionID)} 44} 45 46// CreateOrUpdate creates or updates a sync agent. 47// Parameters: 48// resourceGroupName - the name of the resource group that contains the resource. You can obtain this value 49// from the Azure Resource Manager API or the portal. 50// serverName - the name of the server on which the sync agent is hosted. 51// syncAgentName - the name of the sync agent. 52// parameters - the requested sync agent resource state. 53func (client SyncAgentsClient) CreateOrUpdate(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string, parameters SyncAgent) (result SyncAgentsCreateOrUpdateFuture, err error) { 54 if tracing.IsEnabled() { 55 ctx = tracing.StartSpan(ctx, fqdn+"/SyncAgentsClient.CreateOrUpdate") 56 defer func() { 57 sc := -1 58 if result.Response() != nil { 59 sc = result.Response().StatusCode 60 } 61 tracing.EndSpan(ctx, sc, err) 62 }() 63 } 64 req, err := client.CreateOrUpdatePreparer(ctx, resourceGroupName, serverName, syncAgentName, parameters) 65 if err != nil { 66 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "CreateOrUpdate", nil, "Failure preparing request") 67 return 68 } 69 70 result, err = client.CreateOrUpdateSender(req) 71 if err != nil { 72 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "CreateOrUpdate", result.Response(), "Failure sending request") 73 return 74 } 75 76 return 77} 78 79// CreateOrUpdatePreparer prepares the CreateOrUpdate request. 80func (client SyncAgentsClient) CreateOrUpdatePreparer(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string, parameters SyncAgent) (*http.Request, error) { 81 pathParameters := map[string]interface{}{ 82 "resourceGroupName": autorest.Encode("path", resourceGroupName), 83 "serverName": autorest.Encode("path", serverName), 84 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 85 "syncAgentName": autorest.Encode("path", syncAgentName), 86 } 87 88 const APIVersion = "2015-05-01-preview" 89 queryParameters := map[string]interface{}{ 90 "api-version": APIVersion, 91 } 92 93 preparer := autorest.CreatePreparer( 94 autorest.AsContentType("application/json; charset=utf-8"), 95 autorest.AsPut(), 96 autorest.WithBaseURL(client.BaseURI), 97 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/syncAgents/{syncAgentName}", pathParameters), 98 autorest.WithJSON(parameters), 99 autorest.WithQueryParameters(queryParameters)) 100 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 101} 102 103// CreateOrUpdateSender sends the CreateOrUpdate request. The method will close the 104// http.Response Body if it receives an error. 105func (client SyncAgentsClient) CreateOrUpdateSender(req *http.Request) (future SyncAgentsCreateOrUpdateFuture, err error) { 106 var resp *http.Response 107 resp, err = client.Send(req, azure.DoRetryWithRegistration(client.Client)) 108 if err != nil { 109 return 110 } 111 future.Future, err = azure.NewFutureFromResponse(resp) 112 return 113} 114 115// CreateOrUpdateResponder handles the response to the CreateOrUpdate request. The method always 116// closes the http.Response Body. 117func (client SyncAgentsClient) CreateOrUpdateResponder(resp *http.Response) (result SyncAgent, err error) { 118 err = autorest.Respond( 119 resp, 120 client.ByInspecting(), 121 azure.WithErrorUnlessStatusCode(http.StatusOK, http.StatusCreated, http.StatusAccepted), 122 autorest.ByUnmarshallingJSON(&result), 123 autorest.ByClosing()) 124 result.Response = autorest.Response{Response: resp} 125 return 126} 127 128// Delete deletes a sync agent. 129// Parameters: 130// resourceGroupName - the name of the resource group that contains the resource. You can obtain this value 131// from the Azure Resource Manager API or the portal. 132// serverName - the name of the server on which the sync agent is hosted. 133// syncAgentName - the name of the sync agent. 134func (client SyncAgentsClient) Delete(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (result SyncAgentsDeleteFuture, err error) { 135 if tracing.IsEnabled() { 136 ctx = tracing.StartSpan(ctx, fqdn+"/SyncAgentsClient.Delete") 137 defer func() { 138 sc := -1 139 if result.Response() != nil { 140 sc = result.Response().StatusCode 141 } 142 tracing.EndSpan(ctx, sc, err) 143 }() 144 } 145 req, err := client.DeletePreparer(ctx, resourceGroupName, serverName, syncAgentName) 146 if err != nil { 147 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "Delete", nil, "Failure preparing request") 148 return 149 } 150 151 result, err = client.DeleteSender(req) 152 if err != nil { 153 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "Delete", result.Response(), "Failure sending request") 154 return 155 } 156 157 return 158} 159 160// DeletePreparer prepares the Delete request. 161func (client SyncAgentsClient) DeletePreparer(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (*http.Request, error) { 162 pathParameters := map[string]interface{}{ 163 "resourceGroupName": autorest.Encode("path", resourceGroupName), 164 "serverName": autorest.Encode("path", serverName), 165 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 166 "syncAgentName": autorest.Encode("path", syncAgentName), 167 } 168 169 const APIVersion = "2015-05-01-preview" 170 queryParameters := map[string]interface{}{ 171 "api-version": APIVersion, 172 } 173 174 preparer := autorest.CreatePreparer( 175 autorest.AsDelete(), 176 autorest.WithBaseURL(client.BaseURI), 177 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/syncAgents/{syncAgentName}", pathParameters), 178 autorest.WithQueryParameters(queryParameters)) 179 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 180} 181 182// DeleteSender sends the Delete request. The method will close the 183// http.Response Body if it receives an error. 184func (client SyncAgentsClient) DeleteSender(req *http.Request) (future SyncAgentsDeleteFuture, err error) { 185 var resp *http.Response 186 resp, err = client.Send(req, azure.DoRetryWithRegistration(client.Client)) 187 if err != nil { 188 return 189 } 190 future.Future, err = azure.NewFutureFromResponse(resp) 191 return 192} 193 194// DeleteResponder handles the response to the Delete request. The method always 195// closes the http.Response Body. 196func (client SyncAgentsClient) DeleteResponder(resp *http.Response) (result autorest.Response, err error) { 197 err = autorest.Respond( 198 resp, 199 client.ByInspecting(), 200 azure.WithErrorUnlessStatusCode(http.StatusOK, http.StatusAccepted, http.StatusNoContent), 201 autorest.ByClosing()) 202 result.Response = resp 203 return 204} 205 206// GenerateKey generates a sync agent key. 207// Parameters: 208// resourceGroupName - the name of the resource group that contains the resource. You can obtain this value 209// from the Azure Resource Manager API or the portal. 210// serverName - the name of the server on which the sync agent is hosted. 211// syncAgentName - the name of the sync agent. 212func (client SyncAgentsClient) GenerateKey(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (result SyncAgentKeyProperties, err error) { 213 if tracing.IsEnabled() { 214 ctx = tracing.StartSpan(ctx, fqdn+"/SyncAgentsClient.GenerateKey") 215 defer func() { 216 sc := -1 217 if result.Response.Response != nil { 218 sc = result.Response.Response.StatusCode 219 } 220 tracing.EndSpan(ctx, sc, err) 221 }() 222 } 223 req, err := client.GenerateKeyPreparer(ctx, resourceGroupName, serverName, syncAgentName) 224 if err != nil { 225 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "GenerateKey", nil, "Failure preparing request") 226 return 227 } 228 229 resp, err := client.GenerateKeySender(req) 230 if err != nil { 231 result.Response = autorest.Response{Response: resp} 232 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "GenerateKey", resp, "Failure sending request") 233 return 234 } 235 236 result, err = client.GenerateKeyResponder(resp) 237 if err != nil { 238 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "GenerateKey", resp, "Failure responding to request") 239 } 240 241 return 242} 243 244// GenerateKeyPreparer prepares the GenerateKey request. 245func (client SyncAgentsClient) GenerateKeyPreparer(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (*http.Request, error) { 246 pathParameters := map[string]interface{}{ 247 "resourceGroupName": autorest.Encode("path", resourceGroupName), 248 "serverName": autorest.Encode("path", serverName), 249 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 250 "syncAgentName": autorest.Encode("path", syncAgentName), 251 } 252 253 const APIVersion = "2015-05-01-preview" 254 queryParameters := map[string]interface{}{ 255 "api-version": APIVersion, 256 } 257 258 preparer := autorest.CreatePreparer( 259 autorest.AsPost(), 260 autorest.WithBaseURL(client.BaseURI), 261 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/syncAgents/{syncAgentName}/generateKey", pathParameters), 262 autorest.WithQueryParameters(queryParameters)) 263 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 264} 265 266// GenerateKeySender sends the GenerateKey request. The method will close the 267// http.Response Body if it receives an error. 268func (client SyncAgentsClient) GenerateKeySender(req *http.Request) (*http.Response, error) { 269 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 270} 271 272// GenerateKeyResponder handles the response to the GenerateKey request. The method always 273// closes the http.Response Body. 274func (client SyncAgentsClient) GenerateKeyResponder(resp *http.Response) (result SyncAgentKeyProperties, err error) { 275 err = autorest.Respond( 276 resp, 277 client.ByInspecting(), 278 azure.WithErrorUnlessStatusCode(http.StatusOK), 279 autorest.ByUnmarshallingJSON(&result), 280 autorest.ByClosing()) 281 result.Response = autorest.Response{Response: resp} 282 return 283} 284 285// Get gets a sync agent. 286// Parameters: 287// resourceGroupName - the name of the resource group that contains the resource. You can obtain this value 288// from the Azure Resource Manager API or the portal. 289// serverName - the name of the server on which the sync agent is hosted. 290// syncAgentName - the name of the sync agent. 291func (client SyncAgentsClient) Get(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (result SyncAgent, err error) { 292 if tracing.IsEnabled() { 293 ctx = tracing.StartSpan(ctx, fqdn+"/SyncAgentsClient.Get") 294 defer func() { 295 sc := -1 296 if result.Response.Response != nil { 297 sc = result.Response.Response.StatusCode 298 } 299 tracing.EndSpan(ctx, sc, err) 300 }() 301 } 302 req, err := client.GetPreparer(ctx, resourceGroupName, serverName, syncAgentName) 303 if err != nil { 304 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "Get", nil, "Failure preparing request") 305 return 306 } 307 308 resp, err := client.GetSender(req) 309 if err != nil { 310 result.Response = autorest.Response{Response: resp} 311 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "Get", resp, "Failure sending request") 312 return 313 } 314 315 result, err = client.GetResponder(resp) 316 if err != nil { 317 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "Get", resp, "Failure responding to request") 318 } 319 320 return 321} 322 323// GetPreparer prepares the Get request. 324func (client SyncAgentsClient) GetPreparer(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (*http.Request, error) { 325 pathParameters := map[string]interface{}{ 326 "resourceGroupName": autorest.Encode("path", resourceGroupName), 327 "serverName": autorest.Encode("path", serverName), 328 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 329 "syncAgentName": autorest.Encode("path", syncAgentName), 330 } 331 332 const APIVersion = "2015-05-01-preview" 333 queryParameters := map[string]interface{}{ 334 "api-version": APIVersion, 335 } 336 337 preparer := autorest.CreatePreparer( 338 autorest.AsGet(), 339 autorest.WithBaseURL(client.BaseURI), 340 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/syncAgents/{syncAgentName}", pathParameters), 341 autorest.WithQueryParameters(queryParameters)) 342 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 343} 344 345// GetSender sends the Get request. The method will close the 346// http.Response Body if it receives an error. 347func (client SyncAgentsClient) GetSender(req *http.Request) (*http.Response, error) { 348 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 349} 350 351// GetResponder handles the response to the Get request. The method always 352// closes the http.Response Body. 353func (client SyncAgentsClient) GetResponder(resp *http.Response) (result SyncAgent, err error) { 354 err = autorest.Respond( 355 resp, 356 client.ByInspecting(), 357 azure.WithErrorUnlessStatusCode(http.StatusOK), 358 autorest.ByUnmarshallingJSON(&result), 359 autorest.ByClosing()) 360 result.Response = autorest.Response{Response: resp} 361 return 362} 363 364// ListByServer lists sync agents in a server. 365// Parameters: 366// resourceGroupName - the name of the resource group that contains the resource. You can obtain this value 367// from the Azure Resource Manager API or the portal. 368// serverName - the name of the server on which the sync agent is hosted. 369func (client SyncAgentsClient) ListByServer(ctx context.Context, resourceGroupName string, serverName string) (result SyncAgentListResultPage, err error) { 370 if tracing.IsEnabled() { 371 ctx = tracing.StartSpan(ctx, fqdn+"/SyncAgentsClient.ListByServer") 372 defer func() { 373 sc := -1 374 if result.salr.Response.Response != nil { 375 sc = result.salr.Response.Response.StatusCode 376 } 377 tracing.EndSpan(ctx, sc, err) 378 }() 379 } 380 result.fn = client.listByServerNextResults 381 req, err := client.ListByServerPreparer(ctx, resourceGroupName, serverName) 382 if err != nil { 383 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "ListByServer", nil, "Failure preparing request") 384 return 385 } 386 387 resp, err := client.ListByServerSender(req) 388 if err != nil { 389 result.salr.Response = autorest.Response{Response: resp} 390 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "ListByServer", resp, "Failure sending request") 391 return 392 } 393 394 result.salr, err = client.ListByServerResponder(resp) 395 if err != nil { 396 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "ListByServer", resp, "Failure responding to request") 397 } 398 399 return 400} 401 402// ListByServerPreparer prepares the ListByServer request. 403func (client SyncAgentsClient) ListByServerPreparer(ctx context.Context, resourceGroupName string, serverName string) (*http.Request, error) { 404 pathParameters := map[string]interface{}{ 405 "resourceGroupName": autorest.Encode("path", resourceGroupName), 406 "serverName": autorest.Encode("path", serverName), 407 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 408 } 409 410 const APIVersion = "2015-05-01-preview" 411 queryParameters := map[string]interface{}{ 412 "api-version": APIVersion, 413 } 414 415 preparer := autorest.CreatePreparer( 416 autorest.AsGet(), 417 autorest.WithBaseURL(client.BaseURI), 418 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/syncAgents", pathParameters), 419 autorest.WithQueryParameters(queryParameters)) 420 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 421} 422 423// ListByServerSender sends the ListByServer request. The method will close the 424// http.Response Body if it receives an error. 425func (client SyncAgentsClient) ListByServerSender(req *http.Request) (*http.Response, error) { 426 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 427} 428 429// ListByServerResponder handles the response to the ListByServer request. The method always 430// closes the http.Response Body. 431func (client SyncAgentsClient) ListByServerResponder(resp *http.Response) (result SyncAgentListResult, err error) { 432 err = autorest.Respond( 433 resp, 434 client.ByInspecting(), 435 azure.WithErrorUnlessStatusCode(http.StatusOK), 436 autorest.ByUnmarshallingJSON(&result), 437 autorest.ByClosing()) 438 result.Response = autorest.Response{Response: resp} 439 return 440} 441 442// listByServerNextResults retrieves the next set of results, if any. 443func (client SyncAgentsClient) listByServerNextResults(ctx context.Context, lastResults SyncAgentListResult) (result SyncAgentListResult, err error) { 444 req, err := lastResults.syncAgentListResultPreparer(ctx) 445 if err != nil { 446 return result, autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "listByServerNextResults", nil, "Failure preparing next results request") 447 } 448 if req == nil { 449 return 450 } 451 resp, err := client.ListByServerSender(req) 452 if err != nil { 453 result.Response = autorest.Response{Response: resp} 454 return result, autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "listByServerNextResults", resp, "Failure sending next results request") 455 } 456 result, err = client.ListByServerResponder(resp) 457 if err != nil { 458 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "listByServerNextResults", resp, "Failure responding to next results request") 459 } 460 return 461} 462 463// ListByServerComplete enumerates all values, automatically crossing page boundaries as required. 464func (client SyncAgentsClient) ListByServerComplete(ctx context.Context, resourceGroupName string, serverName string) (result SyncAgentListResultIterator, err error) { 465 if tracing.IsEnabled() { 466 ctx = tracing.StartSpan(ctx, fqdn+"/SyncAgentsClient.ListByServer") 467 defer func() { 468 sc := -1 469 if result.Response().Response.Response != nil { 470 sc = result.page.Response().Response.Response.StatusCode 471 } 472 tracing.EndSpan(ctx, sc, err) 473 }() 474 } 475 result.page, err = client.ListByServer(ctx, resourceGroupName, serverName) 476 return 477} 478 479// ListLinkedDatabases lists databases linked to a sync agent. 480// Parameters: 481// resourceGroupName - the name of the resource group that contains the resource. You can obtain this value 482// from the Azure Resource Manager API or the portal. 483// serverName - the name of the server on which the sync agent is hosted. 484// syncAgentName - the name of the sync agent. 485func (client SyncAgentsClient) ListLinkedDatabases(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (result SyncAgentLinkedDatabaseListResultPage, err error) { 486 if tracing.IsEnabled() { 487 ctx = tracing.StartSpan(ctx, fqdn+"/SyncAgentsClient.ListLinkedDatabases") 488 defer func() { 489 sc := -1 490 if result.saldlr.Response.Response != nil { 491 sc = result.saldlr.Response.Response.StatusCode 492 } 493 tracing.EndSpan(ctx, sc, err) 494 }() 495 } 496 result.fn = client.listLinkedDatabasesNextResults 497 req, err := client.ListLinkedDatabasesPreparer(ctx, resourceGroupName, serverName, syncAgentName) 498 if err != nil { 499 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "ListLinkedDatabases", nil, "Failure preparing request") 500 return 501 } 502 503 resp, err := client.ListLinkedDatabasesSender(req) 504 if err != nil { 505 result.saldlr.Response = autorest.Response{Response: resp} 506 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "ListLinkedDatabases", resp, "Failure sending request") 507 return 508 } 509 510 result.saldlr, err = client.ListLinkedDatabasesResponder(resp) 511 if err != nil { 512 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "ListLinkedDatabases", resp, "Failure responding to request") 513 } 514 515 return 516} 517 518// ListLinkedDatabasesPreparer prepares the ListLinkedDatabases request. 519func (client SyncAgentsClient) ListLinkedDatabasesPreparer(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (*http.Request, error) { 520 pathParameters := map[string]interface{}{ 521 "resourceGroupName": autorest.Encode("path", resourceGroupName), 522 "serverName": autorest.Encode("path", serverName), 523 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 524 "syncAgentName": autorest.Encode("path", syncAgentName), 525 } 526 527 const APIVersion = "2015-05-01-preview" 528 queryParameters := map[string]interface{}{ 529 "api-version": APIVersion, 530 } 531 532 preparer := autorest.CreatePreparer( 533 autorest.AsGet(), 534 autorest.WithBaseURL(client.BaseURI), 535 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}/syncAgents/{syncAgentName}/linkedDatabases", pathParameters), 536 autorest.WithQueryParameters(queryParameters)) 537 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 538} 539 540// ListLinkedDatabasesSender sends the ListLinkedDatabases request. The method will close the 541// http.Response Body if it receives an error. 542func (client SyncAgentsClient) ListLinkedDatabasesSender(req *http.Request) (*http.Response, error) { 543 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 544} 545 546// ListLinkedDatabasesResponder handles the response to the ListLinkedDatabases request. The method always 547// closes the http.Response Body. 548func (client SyncAgentsClient) ListLinkedDatabasesResponder(resp *http.Response) (result SyncAgentLinkedDatabaseListResult, err error) { 549 err = autorest.Respond( 550 resp, 551 client.ByInspecting(), 552 azure.WithErrorUnlessStatusCode(http.StatusOK), 553 autorest.ByUnmarshallingJSON(&result), 554 autorest.ByClosing()) 555 result.Response = autorest.Response{Response: resp} 556 return 557} 558 559// listLinkedDatabasesNextResults retrieves the next set of results, if any. 560func (client SyncAgentsClient) listLinkedDatabasesNextResults(ctx context.Context, lastResults SyncAgentLinkedDatabaseListResult) (result SyncAgentLinkedDatabaseListResult, err error) { 561 req, err := lastResults.syncAgentLinkedDatabaseListResultPreparer(ctx) 562 if err != nil { 563 return result, autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "listLinkedDatabasesNextResults", nil, "Failure preparing next results request") 564 } 565 if req == nil { 566 return 567 } 568 resp, err := client.ListLinkedDatabasesSender(req) 569 if err != nil { 570 result.Response = autorest.Response{Response: resp} 571 return result, autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "listLinkedDatabasesNextResults", resp, "Failure sending next results request") 572 } 573 result, err = client.ListLinkedDatabasesResponder(resp) 574 if err != nil { 575 err = autorest.NewErrorWithError(err, "sql.SyncAgentsClient", "listLinkedDatabasesNextResults", resp, "Failure responding to next results request") 576 } 577 return 578} 579 580// ListLinkedDatabasesComplete enumerates all values, automatically crossing page boundaries as required. 581func (client SyncAgentsClient) ListLinkedDatabasesComplete(ctx context.Context, resourceGroupName string, serverName string, syncAgentName string) (result SyncAgentLinkedDatabaseListResultIterator, err error) { 582 if tracing.IsEnabled() { 583 ctx = tracing.StartSpan(ctx, fqdn+"/SyncAgentsClient.ListLinkedDatabases") 584 defer func() { 585 sc := -1 586 if result.Response().Response.Response != nil { 587 sc = result.page.Response().Response.Response.StatusCode 588 } 589 tracing.EndSpan(ctx, sc, err) 590 }() 591 } 592 result.page, err = client.ListLinkedDatabases(ctx, resourceGroupName, serverName, syncAgentName) 593 return 594} 595