/// <summary>
 /// Add new Network Security Rule to existing Network Security Group.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Network.INetworkSecurityGroupOperations.
 /// </param>
 /// <param name='networkSecurityGroupName'>
 /// Optional.
 /// </param>
 /// <param name='ruleName'>
 /// Optional.
 /// </param>
 /// <param name='parameters'>
 /// Required. Parameters supplied to the Set Network Security Rule
 /// operation.
 /// </param>
 /// <returns>
 /// The response body contains the status of the specified asynchronous
 /// operation, indicating whether it has succeeded, is inprogress, or
 /// has failed. Note that this status is distinct from the HTTP status
 /// code returned for the Get Operation Status operation itself. If
 /// the asynchronous operation succeeded, the response body includes
 /// the HTTP status code for the successful request. If the
 /// asynchronous operation failed, the response body includes the HTTP
 /// status code for the failed request, and also includes error
 /// information regarding the failure.
 /// </returns>
 public static OperationStatusResponse SetRule(this INetworkSecurityGroupOperations operations, string networkSecurityGroupName, string ruleName, NetworkSecuritySetRuleParameters parameters)
 {
     return Task.Factory.StartNew((object s) => 
     {
         return ((INetworkSecurityGroupOperations)s).SetRuleAsync(networkSecurityGroupName, ruleName, parameters);
     }
     , operations, CancellationToken.None, TaskCreationOptions.None, TaskScheduler.Default).Unwrap().GetAwaiter().GetResult();
 }
 /// <summary>
 /// Add new Network Security Rule to existing Network Security Group.
 /// </summary>
 /// <param name='operations'>
 /// Reference to the
 /// Microsoft.WindowsAzure.Management.Network.INetworkSecurityGroupOperations.
 /// </param>
 /// <param name='networkSecurityGroupName'>
 /// Optional.
 /// </param>
 /// <param name='ruleName'>
 /// Optional.
 /// </param>
 /// <param name='parameters'>
 /// Required. Parameters supplied to the Set Network Security Rule
 /// operation.
 /// </param>
 /// <returns>
 /// The response body contains the status of the specified asynchronous
 /// operation, indicating whether it has succeeded, is inprogress, or
 /// has failed. Note that this status is distinct from the HTTP status
 /// code returned for the Get Operation Status operation itself. If
 /// the asynchronous operation succeeded, the response body includes
 /// the HTTP status code for the successful request. If the
 /// asynchronous operation failed, the response body includes the HTTP
 /// status code for the failed request, and also includes error
 /// information regarding the failure.
 /// </returns>
 public static Task<OperationStatusResponse> SetRuleAsync(this INetworkSecurityGroupOperations operations, string networkSecurityGroupName, string ruleName, NetworkSecuritySetRuleParameters parameters)
 {
     return operations.SetRuleAsync(networkSecurityGroupName, ruleName, parameters, CancellationToken.None);
 }
        public void SetRuleToSecurityGroup(
            string securityGroupName,
            string ruleName,
            string action,
            string sourceAddressPrefix,
            string sourcePortRange,
            string destinationAddressPrefix,
            string destinationPortRange,
            int priority,
            string protocol,
            string type)
        {
            NetworkSecuritySetRuleParameters parameters = new NetworkSecuritySetRuleParameters()
            {
                Action = "Allow",
                SourceAddressPrefix = sourceAddressPrefix,
                SourcePortRange = sourcePortRange,
                DestinationAddressPrefix = destinationAddressPrefix,
                DestinationPortRange = destinationPortRange,
                Priority = priority,
                Protocol = protocol,
                Type = type
            };

            NetworkClient.NetworkSecurityGroups.SetRule(securityGroupName, ruleName, parameters);
        }