Access Control List Args
The Access Control List resource definition. Uses Azure REST API version 2023-06-15. In version 2.x of the Azure Native provider, it used API version 2023-02-01-preview. Other available API versions: 2023-02-01-preview. These can be accessed by generating a local SDK package using the CLI command pulumi package add azure-native managednetworkfabric [ApiVersion]
. See the ../../../version-guide/#accessing-any-api-version-via-local-packages for details.
Example Usage
AccessControlLists_Create_MaximumSet_Gen
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using AzureNative = Pulumi.AzureNative;
return await Deployment.RunAsync(() =>
{
var accessControlList = new AzureNative.ManagedNetworkFabric.AccessControlList("accessControlList", new()
{
AccessControlListName = "example-acl",
AclsUrl = "https://ACL-Storage-URL",
Annotation = "annotation",
ConfigurationType = AzureNative.ManagedNetworkFabric.ConfigurationType.File,
DefaultAction = AzureNative.ManagedNetworkFabric.CommunityActionTypes.Permit,
DynamicMatchConfigurations = new[]
{
new AzureNative.ManagedNetworkFabric.Inputs.CommonDynamicMatchConfigurationArgs
{
IpGroups = new[]
{
new AzureNative.ManagedNetworkFabric.Inputs.IpGroupPropertiesArgs
{
IpAddressType = AzureNative.ManagedNetworkFabric.IPAddressType.IPv4,
IpPrefixes = new[]
{
"10.20.3.1/20",
},
Name = "example-ipGroup",
},
},
PortGroups = new[]
{
new AzureNative.ManagedNetworkFabric.Inputs.PortGroupPropertiesArgs
{
Name = "example-portGroup",
Ports = new[]
{
"100-200",
},
},
},
VlanGroups = new[]
{
new AzureNative.ManagedNetworkFabric.Inputs.VlanGroupPropertiesArgs
{
Name = "example-vlanGroup",
Vlans = new[]
{
"20-30",
},
},
},
},
},
Location = "eastUs",
MatchConfigurations = new[]
{
new AzureNative.ManagedNetworkFabric.Inputs.AccessControlListMatchConfigurationArgs
{
Actions = new[]
{
new AzureNative.ManagedNetworkFabric.Inputs.AccessControlListActionArgs
{
CounterName = "example-counter",
Type = AzureNative.ManagedNetworkFabric.AclActionType.Count,
},
},
IpAddressType = AzureNative.ManagedNetworkFabric.IPAddressType.IPv4,
MatchConditions = new[]
{
new AzureNative.ManagedNetworkFabric.Inputs.AccessControlListMatchConditionArgs
{
DscpMarkings = new[]
{
"32",
},
EtherTypes = new[]
{
"0x1",
},
Fragments = new[]
{
"0xff00-0xffff",
},
IpCondition = new AzureNative.ManagedNetworkFabric.Inputs.IpMatchConditionArgs
{
IpGroupNames = new[]
{
"example-ipGroup",
},
IpPrefixValues = new[]
{
"10.20.20.20/12",
},
PrefixType = AzureNative.ManagedNetworkFabric.PrefixType.Prefix,
Type = AzureNative.ManagedNetworkFabric.SourceDestinationType.SourceIP,
},
IpLengths = new[]
{
"4094-9214",
},
PortCondition = new AzureNative.ManagedNetworkFabric.Inputs.AccessControlListPortConditionArgs
{
Flags = new[]
{
"established",
},
Layer4Protocol = AzureNative.ManagedNetworkFabric.Layer4Protocol.TCP,
PortGroupNames = new[]
{
"example-portGroup",
},
PortType = AzureNative.ManagedNetworkFabric.PortType.SourcePort,
Ports = new[]
{
"1-20",
},
},
ProtocolTypes = new[]
{
"TCP",
},
TtlValues = new[]
{
"23",
},
VlanMatchCondition = new AzureNative.ManagedNetworkFabric.Inputs.VlanMatchConditionArgs
{
InnerVlans = new[]
{
"30",
},
VlanGroupNames = new[]
{
"example-vlanGroup",
},
Vlans = new[]
{
"20-30",
},
},
},
},
MatchConfigurationName = "example-match",
SequenceNumber = 123,
},
},
ResourceGroupName = "example-rg",
Tags =
{
{ "keyID", "KeyValue" },
},
});
});
package main
import (
managednetworkfabric "github.com/pulumi/pulumi-azure-native-sdk/managednetworkfabric/v3"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := managednetworkfabric.NewAccessControlList(ctx, "accessControlList", &managednetworkfabric.AccessControlListArgs{
AccessControlListName: pulumi.String("example-acl"),
AclsUrl: pulumi.String("https://ACL-Storage-URL"),
Annotation: pulumi.String("annotation"),
ConfigurationType: pulumi.String(managednetworkfabric.ConfigurationTypeFile),
DefaultAction: pulumi.String(managednetworkfabric.CommunityActionTypesPermit),
DynamicMatchConfigurations: managednetworkfabric.CommonDynamicMatchConfigurationArray{
&managednetworkfabric.CommonDynamicMatchConfigurationArgs{
IpGroups: managednetworkfabric.IpGroupPropertiesArray{
&managednetworkfabric.IpGroupPropertiesArgs{
IpAddressType: pulumi.String(managednetworkfabric.IPAddressTypeIPv4),
IpPrefixes: pulumi.StringArray{
pulumi.String("10.20.3.1/20"),
},
Name: pulumi.String("example-ipGroup"),
},
},
PortGroups: managednetworkfabric.PortGroupPropertiesArray{
&managednetworkfabric.PortGroupPropertiesArgs{
Name: pulumi.String("example-portGroup"),
Ports: pulumi.StringArray{
pulumi.String("100-200"),
},
},
},
VlanGroups: managednetworkfabric.VlanGroupPropertiesArray{
&managednetworkfabric.VlanGroupPropertiesArgs{
Name: pulumi.String("example-vlanGroup"),
Vlans: pulumi.StringArray{
pulumi.String("20-30"),
},
},
},
},
},
Location: pulumi.String("eastUs"),
MatchConfigurations: managednetworkfabric.AccessControlListMatchConfigurationArray{
&managednetworkfabric.AccessControlListMatchConfigurationArgs{
Actions: managednetworkfabric.AccessControlListActionArray{
&managednetworkfabric.AccessControlListActionArgs{
CounterName: pulumi.String("example-counter"),
Type: pulumi.String(managednetworkfabric.AclActionTypeCount),
},
},
IpAddressType: pulumi.String(managednetworkfabric.IPAddressTypeIPv4),
MatchConditions: managednetworkfabric.AccessControlListMatchConditionArray{
&managednetworkfabric.AccessControlListMatchConditionArgs{
DscpMarkings: pulumi.StringArray{
pulumi.String("32"),
},
EtherTypes: pulumi.StringArray{
pulumi.String("0x1"),
},
Fragments: pulumi.StringArray{
pulumi.String("0xff00-0xffff"),
},
IpCondition: &managednetworkfabric.IpMatchConditionArgs{
IpGroupNames: pulumi.StringArray{
pulumi.String("example-ipGroup"),
},
IpPrefixValues: pulumi.StringArray{
pulumi.String("10.20.20.20/12"),
},
PrefixType: pulumi.String(managednetworkfabric.PrefixTypePrefix),
Type: pulumi.String(managednetworkfabric.SourceDestinationTypeSourceIP),
},
IpLengths: pulumi.StringArray{
pulumi.String("4094-9214"),
},
PortCondition: &managednetworkfabric.AccessControlListPortConditionArgs{
Flags: pulumi.StringArray{
pulumi.String("established"),
},
Layer4Protocol: pulumi.String(managednetworkfabric.Layer4ProtocolTCP),
PortGroupNames: pulumi.StringArray{
pulumi.String("example-portGroup"),
},
PortType: pulumi.String(managednetworkfabric.PortTypeSourcePort),
Ports: pulumi.StringArray{
pulumi.String("1-20"),
},
},
ProtocolTypes: pulumi.StringArray{
pulumi.String("TCP"),
},
TtlValues: pulumi.StringArray{
pulumi.String("23"),
},
VlanMatchCondition: &managednetworkfabric.VlanMatchConditionArgs{
InnerVlans: pulumi.StringArray{
pulumi.String("30"),
},
VlanGroupNames: pulumi.StringArray{
pulumi.String("example-vlanGroup"),
},
Vlans: pulumi.StringArray{
pulumi.String("20-30"),
},
},
},
},
MatchConfigurationName: pulumi.String("example-match"),
SequenceNumber: pulumi.Float64(123),
},
},
ResourceGroupName: pulumi.String("example-rg"),
Tags: pulumi.StringMap{
"keyID": pulumi.String("KeyValue"),
},
})
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.azurenative.managednetworkfabric.AccessControlList;
import com.pulumi.azurenative.managednetworkfabric.AccessControlListArgs;
import com.pulumi.azurenative.managednetworkfabric.inputs.CommonDynamicMatchConfigurationArgs;
import com.pulumi.azurenative.managednetworkfabric.inputs.AccessControlListMatchConfigurationArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
var accessControlList = new AccessControlList("accessControlList", AccessControlListArgs.builder()
.accessControlListName("example-acl")
.aclsUrl("https://ACL-Storage-URL")
.annotation("annotation")
.configurationType("File")
.defaultAction("Permit")
.dynamicMatchConfigurations(CommonDynamicMatchConfigurationArgs.builder()
.ipGroups(IpGroupPropertiesArgs.builder()
.ipAddressType("IPv4")
.ipPrefixes("10.20.3.1/20")
.name("example-ipGroup")
.build())
.portGroups(PortGroupPropertiesArgs.builder()
.name("example-portGroup")
.ports("100-200")
.build())
.vlanGroups(VlanGroupPropertiesArgs.builder()
.name("example-vlanGroup")
.vlans("20-30")
.build())
.build())
.location("eastUs")
.matchConfigurations(AccessControlListMatchConfigurationArgs.builder()
.actions(AccessControlListActionArgs.builder()
.counterName("example-counter")
.type("Count")
.build())
.ipAddressType("IPv4")
.matchConditions(AccessControlListMatchConditionArgs.builder()
.dscpMarkings("32")
.etherTypes("0x1")
.fragments("0xff00-0xffff")
.ipCondition(IpMatchConditionArgs.builder()
.ipGroupNames("example-ipGroup")
.ipPrefixValues("10.20.20.20/12")
.prefixType("Prefix")
.type("SourceIP")
.build())
.ipLengths("4094-9214")
.portCondition(AccessControlListPortConditionArgs.builder()
.flags("established")
.layer4Protocol("TCP")
.portGroupNames("example-portGroup")
.portType("SourcePort")
.ports("1-20")
.build())
.protocolTypes("TCP")
.ttlValues("23")
.vlanMatchCondition(VlanMatchConditionArgs.builder()
.innerVlans("30")
.vlanGroupNames("example-vlanGroup")
.vlans("20-30")
.build())
.build())
.matchConfigurationName("example-match")
.sequenceNumber(123.0)
.build())
.resourceGroupName("example-rg")
.tags(Map.of("keyID", "KeyValue"))
.build());
}
}
Import
An existing resource can be imported using its type token, name, and identifier, e.g.
$ pulumi import azure-native:managednetworkfabric:AccessControlList example-acl /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedNetworkFabric/accessControlLists/{accessControlListName}
Constructors
Properties
Name of the Access Control List.
Switch configuration description.
Input method to configure Access Control List.
Default action that needs to be applied when no condition is matched. Example: Permit | Deny.
List of dynamic match configurations.
List of match configurations.
The name of the resource group. The name is case insensitive.