/// <summary> /// Initializes a new instance of the <see cref="ResourceGroupBuilder"/> class. /// </summary> /// <param name="container"> The container object to create the resource in. </param> /// <param name="resource"> The resource to create. </param> public ResourceGroupBuilder(ResourceGroupContainer container, ResourceGroupData resource) { Resource = resource; Container = container; }
/// <summary> /// Initializes a new instance of the <see cref="ResourceGroupBuilder"/> class. /// </summary> /// <param name="collection"> The collection object to create the resource in. </param> /// <param name="resource"> The resource to create. </param> public ResourceGroupBuilder(ResourceGroupCollection collection, ResourceGroupData resource) { Resource = resource; Collection = collection; }
public async Task <Response <ResourceGroupData> > CreateOrUpdateAsync(string subscriptionId, string resourceGroupName, ResourceGroupData parameters, CancellationToken cancellationToken = default) { if (subscriptionId == null) { throw new ArgumentNullException(nameof(subscriptionId)); } if (resourceGroupName == null) { throw new ArgumentNullException(nameof(resourceGroupName)); } if (parameters == null) { throw new ArgumentNullException(nameof(parameters)); } using var message = CreateCreateOrUpdateRequest(subscriptionId, resourceGroupName, parameters); await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); switch (message.Response.Status) { case 200: case 201: { ResourceGroupData value = default; using var document = await JsonDocument.ParseAsync(message.Response.ContentStream, default, cancellationToken).ConfigureAwait(false); value = ResourceGroupData.DeserializeResourceGroupData(document.RootElement); return(Response.FromValue(value, message.Response)); }
/// <summary> /// The operation to create or update a resource group. Please note some properties can be set only during creation. /// </summary> /// <param name="name"> The name of the resource group. </param> /// <param name="resourceDetails"> The desired resource group configuration. </param> /// <param name="cancellationToken"> A token to allow the caller to cancel the call to the service. The default value is <see cref="CancellationToken.None" />. </param> /// <returns> A <see cref="Task"/> that on completion returns an <see cref="Operation{ResourceGroup}"/> that allows polling for completion of the operation. </returns> /// <remarks> /// <see href="https://azure.github.io/azure-sdk/dotnet_introduction.html#dotnet-longrunning">Details on long running operation object.</see> /// </remarks> /// <exception cref="ArgumentException"> Name of the resource group cannot be null or a whitespace. </exception> /// <exception cref="ArgumentNullException"> resourceDetails cannot be null. </exception> public virtual async Task <ResourceGroupCreateOrUpdateOperation> StartCreateOrUpdateAsync(string name, ResourceGroupData resourceDetails, CancellationToken cancellationToken = default) { if (string.IsNullOrWhiteSpace(name)) { throw new ArgumentException("name cannot be null or a whitespace.", nameof(name)); } if (resourceDetails is null) { throw new ArgumentNullException(nameof(resourceDetails)); } using var scope = Diagnostics.CreateScope("ResourceGroupContainer.StartCreateOrUpdate"); scope.Start(); try { var originalResponse = await RestClient.CreateOrUpdateAsync(name, resourceDetails, cancellationToken).ConfigureAwait(false); return(new ResourceGroupCreateOrUpdateOperation(Parent, originalResponse)); } catch (Exception e) { scope.Failed(e); throw; } }
internal ResourceGroupResource(ArmClient client, ResourceGroupData data) : this(client, data.Id) { HasData = true; _data = data; }
internal HttpMessage CreateCreateOrUpdateRequest(string subscriptionId, string resourceGroupName, ResourceGroupData parameters) { var message = _pipeline.CreateMessage(); var request = message.Request; request.Method = RequestMethod.Put; var uri = new RawRequestUriBuilder(); uri.Reset(_endpoint); uri.AppendPath("/subscriptions/", false); uri.AppendPath(subscriptionId, true); uri.AppendPath("/resourcegroups/", false); uri.AppendPath(resourceGroupName, true); uri.AppendQuery("api-version", _apiVersion, true); request.Uri = uri; request.Headers.Add("Accept", "application/json"); request.Headers.Add("Content-Type", "application/json"); var content = new Utf8JsonRequestContent(); content.JsonWriter.WriteObjectValue(parameters); request.Content = content; message.SetProperty("SDKUserAgent", _userAgent); return(message); }
public virtual async Task <ArmOperation <ResourceGroupResource> > CreateOrUpdateAsync(WaitUntil waitUntil, string resourceGroupName, ResourceGroupData data, CancellationToken cancellationToken = default) { Argument.AssertNotNullOrEmpty(resourceGroupName, nameof(resourceGroupName)); Argument.AssertNotNull(data, nameof(data)); using var scope = _resourceGroupClientDiagnostics.CreateScope("ResourceGroupCollection.CreateOrUpdate"); scope.Start(); try { var response = await _resourceGroupRestClient.CreateOrUpdateAsync(Id.SubscriptionId, resourceGroupName, data, cancellationToken).ConfigureAwait(false); var operation = new ResourcesArmOperation <ResourceGroupResource>(Response.FromValue(new ResourceGroupResource(Client, response), response.GetRawResponse())); if (waitUntil == WaitUntil.Completed) { await operation.WaitForCompletionAsync(cancellationToken).ConfigureAwait(false); } return(operation); } catch (Exception e) { scope.Failed(e); throw; } }
public async Task <Response <ResourceGroupData> > CreateOrUpdateAsync(string subscriptionId, string resourceGroupName, ResourceGroupData data, CancellationToken cancellationToken = default) { Argument.AssertNotNullOrEmpty(subscriptionId, nameof(subscriptionId)); Argument.AssertNotNullOrEmpty(resourceGroupName, nameof(resourceGroupName)); Argument.AssertNotNull(data, nameof(data)); using var message = CreateCreateOrUpdateRequest(subscriptionId, resourceGroupName, data); await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); switch (message.Response.Status) { case 200: case 201: { ResourceGroupData value = default; using var document = await JsonDocument.ParseAsync(message.Response.ContentStream, default, cancellationToken).ConfigureAwait(false); value = ResourceGroupData.DeserializeResourceGroupData(document.RootElement); return(Response.FromValue(value, message.Response)); }
/// <summary> /// Initializes a new instance of the <see cref="ResourceGroup"/> class. /// </summary> /// <param name="operations"> The operations to copy the client options from. </param> /// <param name="resource"> The ResourceGroupData to use in these operations. </param> internal ResourceGroup(ResourceOperations operations, ResourceGroupData resource) : base(operations, resource.Id) { Data = resource; }
public virtual ArmOperation <ResourceGroup> CreateOrUpdate(WaitUntil waitUntil, string resourceGroupName, ResourceGroupData parameters, CancellationToken cancellationToken = default) { Argument.AssertNotNullOrEmpty(resourceGroupName, nameof(resourceGroupName)); Argument.AssertNotNull(parameters, nameof(parameters)); using var scope = _resourceGroupClientDiagnostics.CreateScope("ResourceGroupCollection.CreateOrUpdate"); scope.Start(); try { var response = _resourceGroupRestClient.CreateOrUpdate(Id.SubscriptionId, resourceGroupName, parameters, cancellationToken); var operation = new ResourcesArmOperation <ResourceGroup>(Response.FromValue(new ResourceGroup(Client, response), response.GetRawResponse())); if (waitUntil == WaitUntil.Completed) { operation.WaitForCompletion(cancellationToken); } return(operation); } catch (Exception e) { scope.Failed(e); throw; } }
public virtual ResourceGroupCreateOrUpdateOperation CreateOrUpdate(bool waitForCompletion, string resourceGroupName, ResourceGroupData parameters, CancellationToken cancellationToken = default) { Argument.AssertNotNullOrEmpty(resourceGroupName, nameof(resourceGroupName)); if (parameters == null) { throw new ArgumentNullException(nameof(parameters)); } using var scope = _resourceGroupClientDiagnostics.CreateScope("ResourceGroupCollection.CreateOrUpdate"); scope.Start(); try { var response = _resourceGroupRestClient.CreateOrUpdate(Id.SubscriptionId, resourceGroupName, parameters, cancellationToken); var operation = new ResourceGroupCreateOrUpdateOperation(ArmClient, response); if (waitForCompletion) { operation.WaitForCompletion(cancellationToken); } return(operation); } catch (Exception e) { scope.Failed(e); throw; } }