github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v6@v6.2.0/serviceendpointpolicies_client.go (about) 1 //go:build go1.18 2 // +build go1.18 3 4 // Copyright (c) Microsoft Corporation. All rights reserved. 5 // Licensed under the MIT License. See License.txt in the project root for license information. 6 // Code generated by Microsoft (R) AutoRest Code Generator. DO NOT EDIT. 7 // Changes may cause incorrect behavior and will be lost if the code is regenerated. 8 9 package armnetwork 10 11 import ( 12 "context" 13 "errors" 14 "github.com/Azure/azure-sdk-for-go/sdk/azcore" 15 "github.com/Azure/azure-sdk-for-go/sdk/azcore/arm" 16 "github.com/Azure/azure-sdk-for-go/sdk/azcore/policy" 17 "github.com/Azure/azure-sdk-for-go/sdk/azcore/runtime" 18 "net/http" 19 "net/url" 20 "strings" 21 ) 22 23 // ServiceEndpointPoliciesClient contains the methods for the ServiceEndpointPolicies group. 24 // Don't use this type directly, use NewServiceEndpointPoliciesClient() instead. 25 type ServiceEndpointPoliciesClient struct { 26 internal *arm.Client 27 subscriptionID string 28 } 29 30 // NewServiceEndpointPoliciesClient creates a new instance of ServiceEndpointPoliciesClient with the specified values. 31 // - subscriptionID - The subscription credentials which uniquely identify the Microsoft Azure subscription. The subscription 32 // ID forms part of the URI for every service call. 33 // - credential - used to authorize requests. Usually a credential from azidentity. 34 // - options - pass nil to accept the default values. 35 func NewServiceEndpointPoliciesClient(subscriptionID string, credential azcore.TokenCredential, options *arm.ClientOptions) (*ServiceEndpointPoliciesClient, error) { 36 cl, err := arm.NewClient(moduleName, moduleVersion, credential, options) 37 if err != nil { 38 return nil, err 39 } 40 client := &ServiceEndpointPoliciesClient{ 41 subscriptionID: subscriptionID, 42 internal: cl, 43 } 44 return client, nil 45 } 46 47 // BeginCreateOrUpdate - Creates or updates a service Endpoint Policies. 48 // If the operation fails it returns an *azcore.ResponseError type. 49 // 50 // Generated from API version 2024-05-01 51 // - resourceGroupName - The name of the resource group. 52 // - serviceEndpointPolicyName - The name of the service endpoint policy. 53 // - parameters - Parameters supplied to the create or update service endpoint policy operation. 54 // - options - ServiceEndpointPoliciesClientBeginCreateOrUpdateOptions contains the optional parameters for the ServiceEndpointPoliciesClient.BeginCreateOrUpdate 55 // method. 56 func (client *ServiceEndpointPoliciesClient) BeginCreateOrUpdate(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, parameters ServiceEndpointPolicy, options *ServiceEndpointPoliciesClientBeginCreateOrUpdateOptions) (*runtime.Poller[ServiceEndpointPoliciesClientCreateOrUpdateResponse], error) { 57 if options == nil || options.ResumeToken == "" { 58 resp, err := client.createOrUpdate(ctx, resourceGroupName, serviceEndpointPolicyName, parameters, options) 59 if err != nil { 60 return nil, err 61 } 62 poller, err := runtime.NewPoller(resp, client.internal.Pipeline(), &runtime.NewPollerOptions[ServiceEndpointPoliciesClientCreateOrUpdateResponse]{ 63 FinalStateVia: runtime.FinalStateViaAzureAsyncOp, 64 Tracer: client.internal.Tracer(), 65 }) 66 return poller, err 67 } else { 68 return runtime.NewPollerFromResumeToken(options.ResumeToken, client.internal.Pipeline(), &runtime.NewPollerFromResumeTokenOptions[ServiceEndpointPoliciesClientCreateOrUpdateResponse]{ 69 Tracer: client.internal.Tracer(), 70 }) 71 } 72 } 73 74 // CreateOrUpdate - Creates or updates a service Endpoint Policies. 75 // If the operation fails it returns an *azcore.ResponseError type. 76 // 77 // Generated from API version 2024-05-01 78 func (client *ServiceEndpointPoliciesClient) createOrUpdate(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, parameters ServiceEndpointPolicy, options *ServiceEndpointPoliciesClientBeginCreateOrUpdateOptions) (*http.Response, error) { 79 var err error 80 const operationName = "ServiceEndpointPoliciesClient.BeginCreateOrUpdate" 81 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 82 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 83 defer func() { endSpan(err) }() 84 req, err := client.createOrUpdateCreateRequest(ctx, resourceGroupName, serviceEndpointPolicyName, parameters, options) 85 if err != nil { 86 return nil, err 87 } 88 httpResp, err := client.internal.Pipeline().Do(req) 89 if err != nil { 90 return nil, err 91 } 92 if !runtime.HasStatusCode(httpResp, http.StatusOK, http.StatusCreated) { 93 err = runtime.NewResponseError(httpResp) 94 return nil, err 95 } 96 return httpResp, nil 97 } 98 99 // createOrUpdateCreateRequest creates the CreateOrUpdate request. 100 func (client *ServiceEndpointPoliciesClient) createOrUpdateCreateRequest(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, parameters ServiceEndpointPolicy, options *ServiceEndpointPoliciesClientBeginCreateOrUpdateOptions) (*policy.Request, error) { 101 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}" 102 if resourceGroupName == "" { 103 return nil, errors.New("parameter resourceGroupName cannot be empty") 104 } 105 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 106 if serviceEndpointPolicyName == "" { 107 return nil, errors.New("parameter serviceEndpointPolicyName cannot be empty") 108 } 109 urlPath = strings.ReplaceAll(urlPath, "{serviceEndpointPolicyName}", url.PathEscape(serviceEndpointPolicyName)) 110 if client.subscriptionID == "" { 111 return nil, errors.New("parameter client.subscriptionID cannot be empty") 112 } 113 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 114 req, err := runtime.NewRequest(ctx, http.MethodPut, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 115 if err != nil { 116 return nil, err 117 } 118 reqQP := req.Raw().URL.Query() 119 reqQP.Set("api-version", "2024-05-01") 120 req.Raw().URL.RawQuery = reqQP.Encode() 121 req.Raw().Header["Accept"] = []string{"application/json"} 122 if err := runtime.MarshalAsJSON(req, parameters); err != nil { 123 return nil, err 124 } 125 return req, nil 126 } 127 128 // BeginDelete - Deletes the specified service endpoint policy. 129 // If the operation fails it returns an *azcore.ResponseError type. 130 // 131 // Generated from API version 2024-05-01 132 // - resourceGroupName - The name of the resource group. 133 // - serviceEndpointPolicyName - The name of the service endpoint policy. 134 // - options - ServiceEndpointPoliciesClientBeginDeleteOptions contains the optional parameters for the ServiceEndpointPoliciesClient.BeginDelete 135 // method. 136 func (client *ServiceEndpointPoliciesClient) BeginDelete(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, options *ServiceEndpointPoliciesClientBeginDeleteOptions) (*runtime.Poller[ServiceEndpointPoliciesClientDeleteResponse], error) { 137 if options == nil || options.ResumeToken == "" { 138 resp, err := client.deleteOperation(ctx, resourceGroupName, serviceEndpointPolicyName, options) 139 if err != nil { 140 return nil, err 141 } 142 poller, err := runtime.NewPoller(resp, client.internal.Pipeline(), &runtime.NewPollerOptions[ServiceEndpointPoliciesClientDeleteResponse]{ 143 FinalStateVia: runtime.FinalStateViaLocation, 144 Tracer: client.internal.Tracer(), 145 }) 146 return poller, err 147 } else { 148 return runtime.NewPollerFromResumeToken(options.ResumeToken, client.internal.Pipeline(), &runtime.NewPollerFromResumeTokenOptions[ServiceEndpointPoliciesClientDeleteResponse]{ 149 Tracer: client.internal.Tracer(), 150 }) 151 } 152 } 153 154 // Delete - Deletes the specified service endpoint policy. 155 // If the operation fails it returns an *azcore.ResponseError type. 156 // 157 // Generated from API version 2024-05-01 158 func (client *ServiceEndpointPoliciesClient) deleteOperation(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, options *ServiceEndpointPoliciesClientBeginDeleteOptions) (*http.Response, error) { 159 var err error 160 const operationName = "ServiceEndpointPoliciesClient.BeginDelete" 161 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 162 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 163 defer func() { endSpan(err) }() 164 req, err := client.deleteCreateRequest(ctx, resourceGroupName, serviceEndpointPolicyName, options) 165 if err != nil { 166 return nil, err 167 } 168 httpResp, err := client.internal.Pipeline().Do(req) 169 if err != nil { 170 return nil, err 171 } 172 if !runtime.HasStatusCode(httpResp, http.StatusOK, http.StatusAccepted, http.StatusNoContent) { 173 err = runtime.NewResponseError(httpResp) 174 return nil, err 175 } 176 return httpResp, nil 177 } 178 179 // deleteCreateRequest creates the Delete request. 180 func (client *ServiceEndpointPoliciesClient) deleteCreateRequest(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, options *ServiceEndpointPoliciesClientBeginDeleteOptions) (*policy.Request, error) { 181 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}" 182 if resourceGroupName == "" { 183 return nil, errors.New("parameter resourceGroupName cannot be empty") 184 } 185 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 186 if serviceEndpointPolicyName == "" { 187 return nil, errors.New("parameter serviceEndpointPolicyName cannot be empty") 188 } 189 urlPath = strings.ReplaceAll(urlPath, "{serviceEndpointPolicyName}", url.PathEscape(serviceEndpointPolicyName)) 190 if client.subscriptionID == "" { 191 return nil, errors.New("parameter client.subscriptionID cannot be empty") 192 } 193 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 194 req, err := runtime.NewRequest(ctx, http.MethodDelete, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 195 if err != nil { 196 return nil, err 197 } 198 reqQP := req.Raw().URL.Query() 199 reqQP.Set("api-version", "2024-05-01") 200 req.Raw().URL.RawQuery = reqQP.Encode() 201 req.Raw().Header["Accept"] = []string{"application/json"} 202 return req, nil 203 } 204 205 // Get - Gets the specified service Endpoint Policies in a specified resource group. 206 // If the operation fails it returns an *azcore.ResponseError type. 207 // 208 // Generated from API version 2024-05-01 209 // - resourceGroupName - The name of the resource group. 210 // - serviceEndpointPolicyName - The name of the service endpoint policy. 211 // - options - ServiceEndpointPoliciesClientGetOptions contains the optional parameters for the ServiceEndpointPoliciesClient.Get 212 // method. 213 func (client *ServiceEndpointPoliciesClient) Get(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, options *ServiceEndpointPoliciesClientGetOptions) (ServiceEndpointPoliciesClientGetResponse, error) { 214 var err error 215 const operationName = "ServiceEndpointPoliciesClient.Get" 216 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 217 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 218 defer func() { endSpan(err) }() 219 req, err := client.getCreateRequest(ctx, resourceGroupName, serviceEndpointPolicyName, options) 220 if err != nil { 221 return ServiceEndpointPoliciesClientGetResponse{}, err 222 } 223 httpResp, err := client.internal.Pipeline().Do(req) 224 if err != nil { 225 return ServiceEndpointPoliciesClientGetResponse{}, err 226 } 227 if !runtime.HasStatusCode(httpResp, http.StatusOK) { 228 err = runtime.NewResponseError(httpResp) 229 return ServiceEndpointPoliciesClientGetResponse{}, err 230 } 231 resp, err := client.getHandleResponse(httpResp) 232 return resp, err 233 } 234 235 // getCreateRequest creates the Get request. 236 func (client *ServiceEndpointPoliciesClient) getCreateRequest(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, options *ServiceEndpointPoliciesClientGetOptions) (*policy.Request, error) { 237 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}" 238 if resourceGroupName == "" { 239 return nil, errors.New("parameter resourceGroupName cannot be empty") 240 } 241 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 242 if serviceEndpointPolicyName == "" { 243 return nil, errors.New("parameter serviceEndpointPolicyName cannot be empty") 244 } 245 urlPath = strings.ReplaceAll(urlPath, "{serviceEndpointPolicyName}", url.PathEscape(serviceEndpointPolicyName)) 246 if client.subscriptionID == "" { 247 return nil, errors.New("parameter client.subscriptionID cannot be empty") 248 } 249 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 250 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 251 if err != nil { 252 return nil, err 253 } 254 reqQP := req.Raw().URL.Query() 255 if options != nil && options.Expand != nil { 256 reqQP.Set("$expand", *options.Expand) 257 } 258 reqQP.Set("api-version", "2024-05-01") 259 req.Raw().URL.RawQuery = reqQP.Encode() 260 req.Raw().Header["Accept"] = []string{"application/json"} 261 return req, nil 262 } 263 264 // getHandleResponse handles the Get response. 265 func (client *ServiceEndpointPoliciesClient) getHandleResponse(resp *http.Response) (ServiceEndpointPoliciesClientGetResponse, error) { 266 result := ServiceEndpointPoliciesClientGetResponse{} 267 if err := runtime.UnmarshalAsJSON(resp, &result.ServiceEndpointPolicy); err != nil { 268 return ServiceEndpointPoliciesClientGetResponse{}, err 269 } 270 return result, nil 271 } 272 273 // NewListPager - Gets all the service endpoint policies in a subscription. 274 // 275 // Generated from API version 2024-05-01 276 // - options - ServiceEndpointPoliciesClientListOptions contains the optional parameters for the ServiceEndpointPoliciesClient.NewListPager 277 // method. 278 func (client *ServiceEndpointPoliciesClient) NewListPager(options *ServiceEndpointPoliciesClientListOptions) *runtime.Pager[ServiceEndpointPoliciesClientListResponse] { 279 return runtime.NewPager(runtime.PagingHandler[ServiceEndpointPoliciesClientListResponse]{ 280 More: func(page ServiceEndpointPoliciesClientListResponse) bool { 281 return page.NextLink != nil && len(*page.NextLink) > 0 282 }, 283 Fetcher: func(ctx context.Context, page *ServiceEndpointPoliciesClientListResponse) (ServiceEndpointPoliciesClientListResponse, error) { 284 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, "ServiceEndpointPoliciesClient.NewListPager") 285 nextLink := "" 286 if page != nil { 287 nextLink = *page.NextLink 288 } 289 resp, err := runtime.FetcherForNextLink(ctx, client.internal.Pipeline(), nextLink, func(ctx context.Context) (*policy.Request, error) { 290 return client.listCreateRequest(ctx, options) 291 }, nil) 292 if err != nil { 293 return ServiceEndpointPoliciesClientListResponse{}, err 294 } 295 return client.listHandleResponse(resp) 296 }, 297 Tracer: client.internal.Tracer(), 298 }) 299 } 300 301 // listCreateRequest creates the List request. 302 func (client *ServiceEndpointPoliciesClient) listCreateRequest(ctx context.Context, options *ServiceEndpointPoliciesClientListOptions) (*policy.Request, error) { 303 urlPath := "/subscriptions/{subscriptionId}/providers/Microsoft.Network/ServiceEndpointPolicies" 304 if client.subscriptionID == "" { 305 return nil, errors.New("parameter client.subscriptionID cannot be empty") 306 } 307 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 308 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 309 if err != nil { 310 return nil, err 311 } 312 reqQP := req.Raw().URL.Query() 313 reqQP.Set("api-version", "2024-05-01") 314 req.Raw().URL.RawQuery = reqQP.Encode() 315 req.Raw().Header["Accept"] = []string{"application/json"} 316 return req, nil 317 } 318 319 // listHandleResponse handles the List response. 320 func (client *ServiceEndpointPoliciesClient) listHandleResponse(resp *http.Response) (ServiceEndpointPoliciesClientListResponse, error) { 321 result := ServiceEndpointPoliciesClientListResponse{} 322 if err := runtime.UnmarshalAsJSON(resp, &result.ServiceEndpointPolicyListResult); err != nil { 323 return ServiceEndpointPoliciesClientListResponse{}, err 324 } 325 return result, nil 326 } 327 328 // NewListByResourceGroupPager - Gets all service endpoint Policies in a resource group. 329 // 330 // Generated from API version 2024-05-01 331 // - resourceGroupName - The name of the resource group. 332 // - options - ServiceEndpointPoliciesClientListByResourceGroupOptions contains the optional parameters for the ServiceEndpointPoliciesClient.NewListByResourceGroupPager 333 // method. 334 func (client *ServiceEndpointPoliciesClient) NewListByResourceGroupPager(resourceGroupName string, options *ServiceEndpointPoliciesClientListByResourceGroupOptions) *runtime.Pager[ServiceEndpointPoliciesClientListByResourceGroupResponse] { 335 return runtime.NewPager(runtime.PagingHandler[ServiceEndpointPoliciesClientListByResourceGroupResponse]{ 336 More: func(page ServiceEndpointPoliciesClientListByResourceGroupResponse) bool { 337 return page.NextLink != nil && len(*page.NextLink) > 0 338 }, 339 Fetcher: func(ctx context.Context, page *ServiceEndpointPoliciesClientListByResourceGroupResponse) (ServiceEndpointPoliciesClientListByResourceGroupResponse, error) { 340 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, "ServiceEndpointPoliciesClient.NewListByResourceGroupPager") 341 nextLink := "" 342 if page != nil { 343 nextLink = *page.NextLink 344 } 345 resp, err := runtime.FetcherForNextLink(ctx, client.internal.Pipeline(), nextLink, func(ctx context.Context) (*policy.Request, error) { 346 return client.listByResourceGroupCreateRequest(ctx, resourceGroupName, options) 347 }, nil) 348 if err != nil { 349 return ServiceEndpointPoliciesClientListByResourceGroupResponse{}, err 350 } 351 return client.listByResourceGroupHandleResponse(resp) 352 }, 353 Tracer: client.internal.Tracer(), 354 }) 355 } 356 357 // listByResourceGroupCreateRequest creates the ListByResourceGroup request. 358 func (client *ServiceEndpointPoliciesClient) listByResourceGroupCreateRequest(ctx context.Context, resourceGroupName string, options *ServiceEndpointPoliciesClientListByResourceGroupOptions) (*policy.Request, error) { 359 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies" 360 if resourceGroupName == "" { 361 return nil, errors.New("parameter resourceGroupName cannot be empty") 362 } 363 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 364 if client.subscriptionID == "" { 365 return nil, errors.New("parameter client.subscriptionID cannot be empty") 366 } 367 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 368 req, err := runtime.NewRequest(ctx, http.MethodGet, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 369 if err != nil { 370 return nil, err 371 } 372 reqQP := req.Raw().URL.Query() 373 reqQP.Set("api-version", "2024-05-01") 374 req.Raw().URL.RawQuery = reqQP.Encode() 375 req.Raw().Header["Accept"] = []string{"application/json"} 376 return req, nil 377 } 378 379 // listByResourceGroupHandleResponse handles the ListByResourceGroup response. 380 func (client *ServiceEndpointPoliciesClient) listByResourceGroupHandleResponse(resp *http.Response) (ServiceEndpointPoliciesClientListByResourceGroupResponse, error) { 381 result := ServiceEndpointPoliciesClientListByResourceGroupResponse{} 382 if err := runtime.UnmarshalAsJSON(resp, &result.ServiceEndpointPolicyListResult); err != nil { 383 return ServiceEndpointPoliciesClientListByResourceGroupResponse{}, err 384 } 385 return result, nil 386 } 387 388 // UpdateTags - Updates tags of a service endpoint policy. 389 // If the operation fails it returns an *azcore.ResponseError type. 390 // 391 // Generated from API version 2024-05-01 392 // - resourceGroupName - The name of the resource group. 393 // - serviceEndpointPolicyName - The name of the service endpoint policy. 394 // - parameters - Parameters supplied to update service endpoint policy tags. 395 // - options - ServiceEndpointPoliciesClientUpdateTagsOptions contains the optional parameters for the ServiceEndpointPoliciesClient.UpdateTags 396 // method. 397 func (client *ServiceEndpointPoliciesClient) UpdateTags(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, parameters TagsObject, options *ServiceEndpointPoliciesClientUpdateTagsOptions) (ServiceEndpointPoliciesClientUpdateTagsResponse, error) { 398 var err error 399 const operationName = "ServiceEndpointPoliciesClient.UpdateTags" 400 ctx = context.WithValue(ctx, runtime.CtxAPINameKey{}, operationName) 401 ctx, endSpan := runtime.StartSpan(ctx, operationName, client.internal.Tracer(), nil) 402 defer func() { endSpan(err) }() 403 req, err := client.updateTagsCreateRequest(ctx, resourceGroupName, serviceEndpointPolicyName, parameters, options) 404 if err != nil { 405 return ServiceEndpointPoliciesClientUpdateTagsResponse{}, err 406 } 407 httpResp, err := client.internal.Pipeline().Do(req) 408 if err != nil { 409 return ServiceEndpointPoliciesClientUpdateTagsResponse{}, err 410 } 411 if !runtime.HasStatusCode(httpResp, http.StatusOK) { 412 err = runtime.NewResponseError(httpResp) 413 return ServiceEndpointPoliciesClientUpdateTagsResponse{}, err 414 } 415 resp, err := client.updateTagsHandleResponse(httpResp) 416 return resp, err 417 } 418 419 // updateTagsCreateRequest creates the UpdateTags request. 420 func (client *ServiceEndpointPoliciesClient) updateTagsCreateRequest(ctx context.Context, resourceGroupName string, serviceEndpointPolicyName string, parameters TagsObject, options *ServiceEndpointPoliciesClientUpdateTagsOptions) (*policy.Request, error) { 421 urlPath := "/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}" 422 if resourceGroupName == "" { 423 return nil, errors.New("parameter resourceGroupName cannot be empty") 424 } 425 urlPath = strings.ReplaceAll(urlPath, "{resourceGroupName}", url.PathEscape(resourceGroupName)) 426 if serviceEndpointPolicyName == "" { 427 return nil, errors.New("parameter serviceEndpointPolicyName cannot be empty") 428 } 429 urlPath = strings.ReplaceAll(urlPath, "{serviceEndpointPolicyName}", url.PathEscape(serviceEndpointPolicyName)) 430 if client.subscriptionID == "" { 431 return nil, errors.New("parameter client.subscriptionID cannot be empty") 432 } 433 urlPath = strings.ReplaceAll(urlPath, "{subscriptionId}", url.PathEscape(client.subscriptionID)) 434 req, err := runtime.NewRequest(ctx, http.MethodPatch, runtime.JoinPaths(client.internal.Endpoint(), urlPath)) 435 if err != nil { 436 return nil, err 437 } 438 reqQP := req.Raw().URL.Query() 439 reqQP.Set("api-version", "2024-05-01") 440 req.Raw().URL.RawQuery = reqQP.Encode() 441 req.Raw().Header["Accept"] = []string{"application/json"} 442 if err := runtime.MarshalAsJSON(req, parameters); err != nil { 443 return nil, err 444 } 445 return req, nil 446 } 447 448 // updateTagsHandleResponse handles the UpdateTags response. 449 func (client *ServiceEndpointPoliciesClient) updateTagsHandleResponse(resp *http.Response) (ServiceEndpointPoliciesClientUpdateTagsResponse, error) { 450 result := ServiceEndpointPoliciesClientUpdateTagsResponse{} 451 if err := runtime.UnmarshalAsJSON(resp, &result.ServiceEndpointPolicy); err != nil { 452 return ServiceEndpointPoliciesClientUpdateTagsResponse{}, err 453 } 454 return result, nil 455 }