public async Task <Response <SecurityRuleData> > GetAsync(string subscriptionId, string resourceGroupName, string networkSecurityGroupName, string securityRuleName, CancellationToken cancellationToken = default) { if (subscriptionId == null) { throw new ArgumentNullException(nameof(subscriptionId)); } if (resourceGroupName == null) { throw new ArgumentNullException(nameof(resourceGroupName)); } if (networkSecurityGroupName == null) { throw new ArgumentNullException(nameof(networkSecurityGroupName)); } if (securityRuleName == null) { throw new ArgumentNullException(nameof(securityRuleName)); } using var message = CreateGetRequest(subscriptionId, resourceGroupName, networkSecurityGroupName, securityRuleName); await _pipeline.SendAsync(message, cancellationToken).ConfigureAwait(false); switch (message.Response.Status) { case 200: { SecurityRuleData value = default; using var document = await JsonDocument.ParseAsync(message.Response.ContentStream, default, cancellationToken).ConfigureAwait(false); value = SecurityRuleData.DeserializeSecurityRuleData(document.RootElement); return(Response.FromValue(value, message.Response)); }
SecurityRuleResource IOperationSource <SecurityRuleResource> .CreateResult(Response response, CancellationToken cancellationToken) { using var document = JsonDocument.Parse(response.ContentStream); var data = SecurityRuleData.DeserializeSecurityRuleData(document.RootElement); return(new SecurityRuleResource(_client, data)); }
internal SecurityRule(ArmResource options, SecurityRuleData resource) : base(options, new ResourceIdentifier(resource.Id)) { HasData = true; _data = resource; _clientDiagnostics = new ClientDiagnostics(ClientOptions); _securityRulesRestClient = new SecurityRulesRestOperations(_clientDiagnostics, Pipeline, ClientOptions, BaseUri); }
internal SecurityRule(ArmResource options, SecurityRuleData resource) : base(options, resource.Id) { HasData = true; _data = resource; _clientDiagnostics = new ClientDiagnostics(ClientOptions); _restClient = new SecurityRulesRestOperations(_clientDiagnostics, Pipeline, ClientOptions, Id.SubscriptionId, BaseUri); }
public async virtual Task <SecurityRuleCreateOrUpdateOperation> CreateOrUpdateAsync(string securityRuleName, SecurityRuleData securityRuleParameters, bool waitForCompletion = true, CancellationToken cancellationToken = default) { if (securityRuleName == null) { throw new ArgumentNullException(nameof(securityRuleName)); } if (securityRuleParameters == null) { throw new ArgumentNullException(nameof(securityRuleParameters)); } using var scope = _clientDiagnostics.CreateScope("SecurityRuleContainer.CreateOrUpdate"); scope.Start(); try { var response = await _restClient.CreateOrUpdateAsync(Id.ResourceGroupName, Id.Name, securityRuleName, securityRuleParameters, cancellationToken).ConfigureAwait(false); var operation = new SecurityRuleCreateOrUpdateOperation(Parent, _clientDiagnostics, Pipeline, _restClient.CreateCreateOrUpdateRequest(Id.ResourceGroupName, Id.Name, securityRuleName, securityRuleParameters).Request, response); if (waitForCompletion) { await operation.WaitForCompletionAsync(cancellationToken).ConfigureAwait(false); } return(operation); } catch (Exception e) { scope.Failed(e); throw; } }
internal SecurityRuleResource(ArmClient client, SecurityRuleData data) : this(client, new ResourceIdentifier(data.Id)) { HasData = true; _data = data; }
public virtual SecurityRuleCreateOrUpdateOperation CreateOrUpdate(string securityRuleName, SecurityRuleData securityRuleParameters, bool waitForCompletion = true, CancellationToken cancellationToken = default) { if (securityRuleName == null) { throw new ArgumentNullException(nameof(securityRuleName)); } if (securityRuleParameters == null) { throw new ArgumentNullException(nameof(securityRuleParameters)); } using var scope = _clientDiagnostics.CreateScope("SecurityRuleCollection.CreateOrUpdate"); scope.Start(); try { var response = _securityRulesRestClient.CreateOrUpdate(Id.SubscriptionId, Id.ResourceGroupName, Id.Name, securityRuleName, securityRuleParameters, cancellationToken); var operation = new SecurityRuleCreateOrUpdateOperation(Parent, _clientDiagnostics, Pipeline, _securityRulesRestClient.CreateCreateOrUpdateRequest(Id.SubscriptionId, Id.ResourceGroupName, Id.Name, securityRuleName, securityRuleParameters).Request, response); if (waitForCompletion) { operation.WaitForCompletion(cancellationToken); } return(operation); } catch (Exception e) { scope.Failed(e); throw; } }
public virtual async Task <ArmOperation <SecurityRule> > CreateOrUpdateAsync(WaitUntil waitUntil, string securityRuleName, SecurityRuleData securityRuleParameters, CancellationToken cancellationToken = default) { Argument.AssertNotNullOrEmpty(securityRuleName, nameof(securityRuleName)); Argument.AssertNotNull(securityRuleParameters, nameof(securityRuleParameters)); using var scope = _securityRuleClientDiagnostics.CreateScope("SecurityRuleCollection.CreateOrUpdate"); scope.Start(); try { var response = await _securityRuleRestClient.CreateOrUpdateAsync(Id.SubscriptionId, Id.ResourceGroupName, Id.Name, securityRuleName, securityRuleParameters, cancellationToken).ConfigureAwait(false); var operation = new NetworkArmOperation <SecurityRule>(new SecurityRuleOperationSource(Client), _securityRuleClientDiagnostics, Pipeline, _securityRuleRestClient.CreateCreateOrUpdateRequest(Id.SubscriptionId, Id.ResourceGroupName, Id.Name, securityRuleName, securityRuleParameters).Request, response, OperationFinalStateVia.AzureAsyncOperation); if (waitUntil == WaitUntil.Completed) { await operation.WaitForCompletionAsync(cancellationToken).ConfigureAwait(false); } return(operation); } catch (Exception e) { scope.Failed(e); throw; } }
internal static NetworkSecurityGroupData DeserializeNetworkSecurityGroupData(JsonElement element) { Optional <string> etag = default; Optional <string> id = default; Optional <string> name = default; Optional <string> type = default; Optional <string> location = default; Optional <IDictionary <string, string> > tags = default; Optional <IList <SecurityRuleData> > securityRules = default; Optional <IReadOnlyList <SecurityRuleData> > defaultSecurityRules = default; Optional <IReadOnlyList <NetworkInterfaceData> > networkInterfaces = default; Optional <IReadOnlyList <SubnetData> > subnets = default; Optional <IReadOnlyList <FlowLogData> > flowLogs = default; Optional <string> resourceGuid = default; Optional <ProvisioningState> provisioningState = default; foreach (var property in element.EnumerateObject()) { if (property.NameEquals("etag")) { etag = property.Value.GetString(); continue; } if (property.NameEquals("id")) { id = property.Value.GetString(); continue; } if (property.NameEquals("name")) { name = property.Value.GetString(); continue; } if (property.NameEquals("type")) { type = property.Value.GetString(); continue; } if (property.NameEquals("location")) { location = property.Value.GetString(); continue; } if (property.NameEquals("tags")) { if (property.Value.ValueKind == JsonValueKind.Null) { property.ThrowNonNullablePropertyIsNull(); continue; } Dictionary <string, string> dictionary = new Dictionary <string, string>(); foreach (var property0 in property.Value.EnumerateObject()) { dictionary.Add(property0.Name, property0.Value.GetString()); } tags = dictionary; continue; } if (property.NameEquals("properties")) { if (property.Value.ValueKind == JsonValueKind.Null) { property.ThrowNonNullablePropertyIsNull(); continue; } foreach (var property0 in property.Value.EnumerateObject()) { if (property0.NameEquals("securityRules")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } List <SecurityRuleData> array = new List <SecurityRuleData>(); foreach (var item in property0.Value.EnumerateArray()) { array.Add(SecurityRuleData.DeserializeSecurityRuleData(item)); } securityRules = array; continue; } if (property0.NameEquals("defaultSecurityRules")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } List <SecurityRuleData> array = new List <SecurityRuleData>(); foreach (var item in property0.Value.EnumerateArray()) { array.Add(SecurityRuleData.DeserializeSecurityRuleData(item)); } defaultSecurityRules = array; continue; } if (property0.NameEquals("networkInterfaces")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } List <NetworkInterfaceData> array = new List <NetworkInterfaceData>(); foreach (var item in property0.Value.EnumerateArray()) { array.Add(NetworkInterfaceData.DeserializeNetworkInterfaceData(item)); } networkInterfaces = array; continue; } if (property0.NameEquals("subnets")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } List <SubnetData> array = new List <SubnetData>(); foreach (var item in property0.Value.EnumerateArray()) { array.Add(SubnetData.DeserializeSubnetData(item)); } subnets = array; continue; } if (property0.NameEquals("flowLogs")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } List <FlowLogData> array = new List <FlowLogData>(); foreach (var item in property0.Value.EnumerateArray()) { array.Add(FlowLogData.DeserializeFlowLogData(item)); } flowLogs = array; continue; } if (property0.NameEquals("resourceGuid")) { resourceGuid = property0.Value.GetString(); continue; } if (property0.NameEquals("provisioningState")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } provisioningState = new ProvisioningState(property0.Value.GetString()); continue; } } continue; } } return(new NetworkSecurityGroupData(id.Value, name.Value, type.Value, location.Value, Optional.ToDictionary(tags), etag.Value, Optional.ToList(securityRules), Optional.ToList(defaultSecurityRules), Optional.ToList(networkInterfaces), Optional.ToList(subnets), Optional.ToList(flowLogs), resourceGuid.Value, Optional.ToNullable(provisioningState))); }
internal DefaultSecurityRule(ArmClient armClient, SecurityRuleData data) : this(armClient, new ResourceIdentifier(data.Id)) { HasData = true; _data = data; }
internal SecurityRuleResource(ArmClient client, SecurityRuleData data) : this(client, data.Id) { HasData = true; _data = data; }
public virtual ArmOperation <SecurityRuleResource> Update(WaitUntil waitUntil, SecurityRuleData data, CancellationToken cancellationToken = default) { Argument.AssertNotNull(data, nameof(data)); using var scope = _securityRuleClientDiagnostics.CreateScope("SecurityRuleResource.Update"); scope.Start(); try { var response = _securityRuleRestClient.CreateOrUpdate(Id.SubscriptionId, Id.ResourceGroupName, Id.Parent.Name, Id.Name, data, cancellationToken); var operation = new NetworkArmOperation <SecurityRuleResource>(new SecurityRuleOperationSource(Client), _securityRuleClientDiagnostics, Pipeline, _securityRuleRestClient.CreateCreateOrUpdateRequest(Id.SubscriptionId, Id.ResourceGroupName, Id.Parent.Name, Id.Name, data).Request, response, OperationFinalStateVia.AzureAsyncOperation); if (waitUntil == WaitUntil.Completed) { operation.WaitForCompletion(cancellationToken); } return(operation); } catch (Exception e) { scope.Failed(e); throw; } }