public async Task <Response <FirewallRule> > CreateOrUpdateAsync(string resourceGroupName, string serverName, string firewallRuleName, FirewallRule parameters, CancellationToken cancellationToken = default) { if (resourceGroupName == null) { throw new ArgumentNullException(nameof(resourceGroupName)); } if (serverName == null) { throw new ArgumentNullException(nameof(serverName)); } if (firewallRuleName == null) { throw new ArgumentNullException(nameof(firewallRuleName)); } if (parameters == null) { throw new ArgumentNullException(nameof(parameters)); } using var message = CreateCreateOrUpdateRequest(resourceGroupName, serverName, firewallRuleName, parameters); await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); switch (message.Response.Status) { case 200: case 201: { FirewallRule value = default; using var document = await JsonDocument.ParseAsync(message.Response.ContentStream, default, cancellationToken).ConfigureAwait(false); value = FirewallRule.DeserializeFirewallRule(document.RootElement); return(Response.FromValue(value, message.Response)); }
internal HttpMessage CreateCreateOrUpdateRequest(string resourceGroupName, string serverName, string firewallRuleName, FirewallRule 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.AppendPath("/providers/Microsoft.Sql/servers/", false); uri.AppendPath(serverName, true); uri.AppendPath("/firewallRules/", false); uri.AppendPath(firewallRuleName, true); uri.AppendQuery("api-version", "2014-04-01", 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; return(message); }
public virtual Response <FirewallRule> CreateOrUpdate(string resourceGroupName, string serverName, string firewallRuleName, FirewallRule parameters, CancellationToken cancellationToken = default) { using var scope = _clientDiagnostics.CreateScope("FirewallRulesOperations.CreateOrUpdate"); scope.Start(); try { return(RestClient.CreateOrUpdate(resourceGroupName, serverName, firewallRuleName, parameters, cancellationToken)); } catch (Exception e) { scope.Failed(e); throw; } }