1package automation 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/autorest/validation" 25 "github.com/Azure/go-autorest/tracing" 26 "net/http" 27) 28 29// ActivityClient is the automation Client 30type ActivityClient struct { 31 BaseClient 32} 33 34// NewActivityClient creates an instance of the ActivityClient client. 35func NewActivityClient(subscriptionID string) ActivityClient { 36 return NewActivityClientWithBaseURI(DefaultBaseURI, subscriptionID) 37} 38 39// NewActivityClientWithBaseURI creates an instance of the ActivityClient client using a custom endpoint. Use this 40// when interacting with an Azure cloud that uses a non-standard base URI (sovereign clouds, Azure stack). 41func NewActivityClientWithBaseURI(baseURI string, subscriptionID string) ActivityClient { 42 return ActivityClient{NewWithBaseURI(baseURI, subscriptionID)} 43} 44 45// Get retrieve the activity in the module identified by module name and activity name. 46// Parameters: 47// resourceGroupName - name of an Azure Resource group. 48// automationAccountName - the name of the automation account. 49// moduleName - the name of module. 50// activityName - the name of activity. 51func (client ActivityClient) Get(ctx context.Context, resourceGroupName string, automationAccountName string, moduleName string, activityName string) (result Activity, err error) { 52 if tracing.IsEnabled() { 53 ctx = tracing.StartSpan(ctx, fqdn+"/ActivityClient.Get") 54 defer func() { 55 sc := -1 56 if result.Response.Response != nil { 57 sc = result.Response.Response.StatusCode 58 } 59 tracing.EndSpan(ctx, sc, err) 60 }() 61 } 62 if err := validation.Validate([]validation.Validation{ 63 {TargetValue: resourceGroupName, 64 Constraints: []validation.Constraint{{Target: "resourceGroupName", Name: validation.MaxLength, Rule: 90, Chain: nil}, 65 {Target: "resourceGroupName", Name: validation.MinLength, Rule: 1, Chain: nil}, 66 {Target: "resourceGroupName", Name: validation.Pattern, Rule: `^[-\w\._]+$`, Chain: nil}}}}); err != nil { 67 return result, validation.NewError("automation.ActivityClient", "Get", err.Error()) 68 } 69 70 req, err := client.GetPreparer(ctx, resourceGroupName, automationAccountName, moduleName, activityName) 71 if err != nil { 72 err = autorest.NewErrorWithError(err, "automation.ActivityClient", "Get", nil, "Failure preparing request") 73 return 74 } 75 76 resp, err := client.GetSender(req) 77 if err != nil { 78 result.Response = autorest.Response{Response: resp} 79 err = autorest.NewErrorWithError(err, "automation.ActivityClient", "Get", resp, "Failure sending request") 80 return 81 } 82 83 result, err = client.GetResponder(resp) 84 if err != nil { 85 err = autorest.NewErrorWithError(err, "automation.ActivityClient", "Get", resp, "Failure responding to request") 86 } 87 88 return 89} 90 91// GetPreparer prepares the Get request. 92func (client ActivityClient) GetPreparer(ctx context.Context, resourceGroupName string, automationAccountName string, moduleName string, activityName string) (*http.Request, error) { 93 pathParameters := map[string]interface{}{ 94 "activityName": autorest.Encode("path", activityName), 95 "automationAccountName": autorest.Encode("path", automationAccountName), 96 "moduleName": autorest.Encode("path", moduleName), 97 "resourceGroupName": autorest.Encode("path", resourceGroupName), 98 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 99 } 100 101 const APIVersion = "2015-10-31" 102 queryParameters := map[string]interface{}{ 103 "api-version": APIVersion, 104 } 105 106 preparer := autorest.CreatePreparer( 107 autorest.AsGet(), 108 autorest.WithBaseURL(client.BaseURI), 109 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Automation/automationAccounts/{automationAccountName}/modules/{moduleName}/activities/{activityName}", pathParameters), 110 autorest.WithQueryParameters(queryParameters)) 111 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 112} 113 114// GetSender sends the Get request. The method will close the 115// http.Response Body if it receives an error. 116func (client ActivityClient) GetSender(req *http.Request) (*http.Response, error) { 117 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 118} 119 120// GetResponder handles the response to the Get request. The method always 121// closes the http.Response Body. 122func (client ActivityClient) GetResponder(resp *http.Response) (result Activity, err error) { 123 err = autorest.Respond( 124 resp, 125 client.ByInspecting(), 126 azure.WithErrorUnlessStatusCode(http.StatusOK), 127 autorest.ByUnmarshallingJSON(&result), 128 autorest.ByClosing()) 129 result.Response = autorest.Response{Response: resp} 130 return 131} 132 133// ListByModule retrieve a list of activities in the module identified by module name. 134// Parameters: 135// resourceGroupName - name of an Azure Resource group. 136// automationAccountName - the name of the automation account. 137// moduleName - the name of module. 138func (client ActivityClient) ListByModule(ctx context.Context, resourceGroupName string, automationAccountName string, moduleName string) (result ActivityListResultPage, err error) { 139 if tracing.IsEnabled() { 140 ctx = tracing.StartSpan(ctx, fqdn+"/ActivityClient.ListByModule") 141 defer func() { 142 sc := -1 143 if result.alr.Response.Response != nil { 144 sc = result.alr.Response.Response.StatusCode 145 } 146 tracing.EndSpan(ctx, sc, err) 147 }() 148 } 149 if err := validation.Validate([]validation.Validation{ 150 {TargetValue: resourceGroupName, 151 Constraints: []validation.Constraint{{Target: "resourceGroupName", Name: validation.MaxLength, Rule: 90, Chain: nil}, 152 {Target: "resourceGroupName", Name: validation.MinLength, Rule: 1, Chain: nil}, 153 {Target: "resourceGroupName", Name: validation.Pattern, Rule: `^[-\w\._]+$`, Chain: nil}}}}); err != nil { 154 return result, validation.NewError("automation.ActivityClient", "ListByModule", err.Error()) 155 } 156 157 result.fn = client.listByModuleNextResults 158 req, err := client.ListByModulePreparer(ctx, resourceGroupName, automationAccountName, moduleName) 159 if err != nil { 160 err = autorest.NewErrorWithError(err, "automation.ActivityClient", "ListByModule", nil, "Failure preparing request") 161 return 162 } 163 164 resp, err := client.ListByModuleSender(req) 165 if err != nil { 166 result.alr.Response = autorest.Response{Response: resp} 167 err = autorest.NewErrorWithError(err, "automation.ActivityClient", "ListByModule", resp, "Failure sending request") 168 return 169 } 170 171 result.alr, err = client.ListByModuleResponder(resp) 172 if err != nil { 173 err = autorest.NewErrorWithError(err, "automation.ActivityClient", "ListByModule", resp, "Failure responding to request") 174 } 175 176 return 177} 178 179// ListByModulePreparer prepares the ListByModule request. 180func (client ActivityClient) ListByModulePreparer(ctx context.Context, resourceGroupName string, automationAccountName string, moduleName string) (*http.Request, error) { 181 pathParameters := map[string]interface{}{ 182 "automationAccountName": autorest.Encode("path", automationAccountName), 183 "moduleName": autorest.Encode("path", moduleName), 184 "resourceGroupName": autorest.Encode("path", resourceGroupName), 185 "subscriptionId": autorest.Encode("path", client.SubscriptionID), 186 } 187 188 const APIVersion = "2015-10-31" 189 queryParameters := map[string]interface{}{ 190 "api-version": APIVersion, 191 } 192 193 preparer := autorest.CreatePreparer( 194 autorest.AsGet(), 195 autorest.WithBaseURL(client.BaseURI), 196 autorest.WithPathParameters("/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Automation/automationAccounts/{automationAccountName}/modules/{moduleName}/activities", pathParameters), 197 autorest.WithQueryParameters(queryParameters)) 198 return preparer.Prepare((&http.Request{}).WithContext(ctx)) 199} 200 201// ListByModuleSender sends the ListByModule request. The method will close the 202// http.Response Body if it receives an error. 203func (client ActivityClient) ListByModuleSender(req *http.Request) (*http.Response, error) { 204 return client.Send(req, azure.DoRetryWithRegistration(client.Client)) 205} 206 207// ListByModuleResponder handles the response to the ListByModule request. The method always 208// closes the http.Response Body. 209func (client ActivityClient) ListByModuleResponder(resp *http.Response) (result ActivityListResult, err error) { 210 err = autorest.Respond( 211 resp, 212 client.ByInspecting(), 213 azure.WithErrorUnlessStatusCode(http.StatusOK), 214 autorest.ByUnmarshallingJSON(&result), 215 autorest.ByClosing()) 216 result.Response = autorest.Response{Response: resp} 217 return 218} 219 220// listByModuleNextResults retrieves the next set of results, if any. 221func (client ActivityClient) listByModuleNextResults(ctx context.Context, lastResults ActivityListResult) (result ActivityListResult, err error) { 222 req, err := lastResults.activityListResultPreparer(ctx) 223 if err != nil { 224 return result, autorest.NewErrorWithError(err, "automation.ActivityClient", "listByModuleNextResults", nil, "Failure preparing next results request") 225 } 226 if req == nil { 227 return 228 } 229 resp, err := client.ListByModuleSender(req) 230 if err != nil { 231 result.Response = autorest.Response{Response: resp} 232 return result, autorest.NewErrorWithError(err, "automation.ActivityClient", "listByModuleNextResults", resp, "Failure sending next results request") 233 } 234 result, err = client.ListByModuleResponder(resp) 235 if err != nil { 236 err = autorest.NewErrorWithError(err, "automation.ActivityClient", "listByModuleNextResults", resp, "Failure responding to next results request") 237 } 238 return 239} 240 241// ListByModuleComplete enumerates all values, automatically crossing page boundaries as required. 242func (client ActivityClient) ListByModuleComplete(ctx context.Context, resourceGroupName string, automationAccountName string, moduleName string) (result ActivityListResultIterator, err error) { 243 if tracing.IsEnabled() { 244 ctx = tracing.StartSpan(ctx, fqdn+"/ActivityClient.ListByModule") 245 defer func() { 246 sc := -1 247 if result.Response().Response.Response != nil { 248 sc = result.page.Response().Response.Response.StatusCode 249 } 250 tracing.EndSpan(ctx, sc, err) 251 }() 252 } 253 result.page, err = client.ListByModule(ctx, resourceGroupName, automationAccountName, moduleName) 254 return 255} 256