2019-01-12 04:58:27 +00:00
|
|
|
package hcn
|
|
|
|
|
2019-09-30 23:25:17 +00:00
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
)
|
2019-01-12 04:58:27 +00:00
|
|
|
|
|
|
|
// EndpointPolicyType are the potential Policies that apply to Endpoints.
|
|
|
|
type EndpointPolicyType string
|
|
|
|
|
|
|
|
// EndpointPolicyType const
|
|
|
|
const (
|
|
|
|
PortMapping EndpointPolicyType = "PortMapping"
|
|
|
|
ACL EndpointPolicyType = "ACL"
|
|
|
|
QOS EndpointPolicyType = "QOS"
|
|
|
|
L2Driver EndpointPolicyType = "L2Driver"
|
|
|
|
OutBoundNAT EndpointPolicyType = "OutBoundNAT"
|
|
|
|
SDNRoute EndpointPolicyType = "SDNRoute"
|
|
|
|
L4Proxy EndpointPolicyType = "L4Proxy"
|
2020-08-10 17:43:49 +00:00
|
|
|
L4WFPPROXY EndpointPolicyType = "L4WFPPROXY"
|
2019-01-12 04:58:27 +00:00
|
|
|
PortName EndpointPolicyType = "PortName"
|
|
|
|
EncapOverhead EndpointPolicyType = "EncapOverhead"
|
|
|
|
// Endpoint and Network have InterfaceConstraint and ProviderAddress
|
|
|
|
NetworkProviderAddress EndpointPolicyType = "ProviderAddress"
|
|
|
|
NetworkInterfaceConstraint EndpointPolicyType = "InterfaceConstraint"
|
|
|
|
)
|
|
|
|
|
|
|
|
// EndpointPolicy is a collection of Policy settings for an Endpoint.
|
|
|
|
type EndpointPolicy struct {
|
|
|
|
Type EndpointPolicyType `json:""`
|
|
|
|
Settings json.RawMessage `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// NetworkPolicyType are the potential Policies that apply to Networks.
|
|
|
|
type NetworkPolicyType string
|
|
|
|
|
|
|
|
// NetworkPolicyType const
|
|
|
|
const (
|
|
|
|
SourceMacAddress NetworkPolicyType = "SourceMacAddress"
|
|
|
|
NetAdapterName NetworkPolicyType = "NetAdapterName"
|
|
|
|
VSwitchExtension NetworkPolicyType = "VSwitchExtension"
|
|
|
|
DrMacAddress NetworkPolicyType = "DrMacAddress"
|
|
|
|
AutomaticDNS NetworkPolicyType = "AutomaticDNS"
|
|
|
|
InterfaceConstraint NetworkPolicyType = "InterfaceConstraint"
|
|
|
|
ProviderAddress NetworkPolicyType = "ProviderAddress"
|
|
|
|
RemoteSubnetRoute NetworkPolicyType = "RemoteSubnetRoute"
|
2021-06-10 19:27:00 +00:00
|
|
|
VxlanPort NetworkPolicyType = "VxlanPort"
|
2019-07-10 00:29:38 +00:00
|
|
|
HostRoute NetworkPolicyType = "HostRoute"
|
2021-06-10 19:27:00 +00:00
|
|
|
SetPolicy NetworkPolicyType = "SetPolicy"
|
|
|
|
NetworkL4Proxy NetworkPolicyType = "L4Proxy"
|
2019-01-12 04:58:27 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// NetworkPolicy is a collection of Policy settings for a Network.
|
|
|
|
type NetworkPolicy struct {
|
|
|
|
Type NetworkPolicyType `json:""`
|
|
|
|
Settings json.RawMessage `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// SubnetPolicyType are the potential Policies that apply to Subnets.
|
|
|
|
type SubnetPolicyType string
|
|
|
|
|
|
|
|
// SubnetPolicyType const
|
|
|
|
const (
|
|
|
|
VLAN SubnetPolicyType = "VLAN"
|
|
|
|
VSID SubnetPolicyType = "VSID"
|
|
|
|
)
|
|
|
|
|
|
|
|
// SubnetPolicy is a collection of Policy settings for a Subnet.
|
|
|
|
type SubnetPolicy struct {
|
|
|
|
Type SubnetPolicyType `json:""`
|
|
|
|
Settings json.RawMessage `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
2019-09-30 23:25:17 +00:00
|
|
|
// NatFlags are flags for portmappings.
|
|
|
|
type NatFlags uint32
|
|
|
|
|
2019-01-12 04:58:27 +00:00
|
|
|
/// Endpoint Policy objects
|
|
|
|
|
|
|
|
// PortMappingPolicySetting defines Port Mapping (NAT)
|
|
|
|
type PortMappingPolicySetting struct {
|
2019-09-30 23:25:17 +00:00
|
|
|
Protocol uint32 `json:",omitempty"` // EX: TCP = 6, UDP = 17
|
|
|
|
InternalPort uint16 `json:",omitempty"`
|
|
|
|
ExternalPort uint16 `json:",omitempty"`
|
|
|
|
VIP string `json:",omitempty"`
|
|
|
|
Flags NatFlags `json:",omitempty"`
|
2019-01-12 04:58:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ActionType associated with ACLs. Value is either Allow or Block.
|
|
|
|
type ActionType string
|
|
|
|
|
|
|
|
// DirectionType associated with ACLs. Value is either In or Out.
|
|
|
|
type DirectionType string
|
|
|
|
|
|
|
|
// RuleType associated with ACLs. Value is either Host (WFP) or Switch (VFP).
|
|
|
|
type RuleType string
|
|
|
|
|
|
|
|
const (
|
|
|
|
// Allow traffic
|
|
|
|
ActionTypeAllow ActionType = "Allow"
|
|
|
|
// Block traffic
|
|
|
|
ActionTypeBlock ActionType = "Block"
|
|
|
|
|
|
|
|
// In is traffic coming to the Endpoint
|
|
|
|
DirectionTypeIn DirectionType = "In"
|
|
|
|
// Out is traffic leaving the Endpoint
|
|
|
|
DirectionTypeOut DirectionType = "Out"
|
|
|
|
|
|
|
|
// Host creates WFP (Windows Firewall) rules
|
|
|
|
RuleTypeHost RuleType = "Host"
|
|
|
|
// Switch creates VFP (Virtual Filter Platform) rules
|
|
|
|
RuleTypeSwitch RuleType = "Switch"
|
|
|
|
)
|
|
|
|
|
|
|
|
// AclPolicySetting creates firewall rules on an endpoint
|
|
|
|
type AclPolicySetting struct {
|
|
|
|
Protocols string `json:",omitempty"` // EX: 6 (TCP), 17 (UDP), 1 (ICMPv4), 58 (ICMPv6), 2 (IGMP)
|
|
|
|
Action ActionType `json:","`
|
|
|
|
Direction DirectionType `json:","`
|
|
|
|
LocalAddresses string `json:",omitempty"`
|
|
|
|
RemoteAddresses string `json:",omitempty"`
|
|
|
|
LocalPorts string `json:",omitempty"`
|
|
|
|
RemotePorts string `json:",omitempty"`
|
|
|
|
RuleType RuleType `json:",omitempty"`
|
|
|
|
Priority uint16 `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// QosPolicySetting sets Quality of Service bandwidth caps on an Endpoint.
|
|
|
|
type QosPolicySetting struct {
|
|
|
|
MaximumOutgoingBandwidthInBytes uint64
|
|
|
|
}
|
|
|
|
|
|
|
|
// OutboundNatPolicySetting sets outbound Network Address Translation on an Endpoint.
|
|
|
|
type OutboundNatPolicySetting struct {
|
2020-08-10 17:43:49 +00:00
|
|
|
VirtualIP string `json:",omitempty"`
|
|
|
|
Exceptions []string `json:",omitempty"`
|
|
|
|
Destinations []string `json:",omitempty"`
|
2019-01-12 04:58:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// SDNRoutePolicySetting sets SDN Route on an Endpoint.
|
|
|
|
type SDNRoutePolicySetting struct {
|
|
|
|
DestinationPrefix string `json:",omitempty"`
|
|
|
|
NextHop string `json:",omitempty"`
|
|
|
|
NeedEncap bool `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
2021-06-10 19:27:00 +00:00
|
|
|
// FiveTuple is nested in L4ProxyPolicySetting for WFP support.
|
2019-09-30 23:25:17 +00:00
|
|
|
type FiveTuple struct {
|
|
|
|
Protocols string `json:",omitempty"`
|
|
|
|
LocalAddresses string `json:",omitempty"`
|
|
|
|
RemoteAddresses string `json:",omitempty"`
|
|
|
|
LocalPorts string `json:",omitempty"`
|
|
|
|
RemotePorts string `json:",omitempty"`
|
|
|
|
Priority uint16 `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
2020-08-10 17:43:49 +00:00
|
|
|
// L4WfpProxyPolicySetting sets Layer-4 Proxy on an endpoint.
|
|
|
|
type L4WfpProxyPolicySetting struct {
|
|
|
|
Port string `json:",omitempty"`
|
|
|
|
FilterTuple FiveTuple `json:",omitempty"`
|
|
|
|
UserSID string `json:",omitempty"`
|
2019-01-12 04:58:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// PortnameEndpointPolicySetting sets the port name for an endpoint.
|
|
|
|
type PortnameEndpointPolicySetting struct {
|
|
|
|
Name string `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// EncapOverheadEndpointPolicySetting sets the encap overhead for an endpoint.
|
|
|
|
type EncapOverheadEndpointPolicySetting struct {
|
|
|
|
Overhead uint16 `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Endpoint and Network Policy objects
|
|
|
|
|
|
|
|
// ProviderAddressEndpointPolicySetting sets the PA for an endpoint.
|
|
|
|
type ProviderAddressEndpointPolicySetting struct {
|
|
|
|
ProviderAddress string `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// InterfaceConstraintPolicySetting limits an Endpoint or Network to a specific Nic.
|
|
|
|
type InterfaceConstraintPolicySetting struct {
|
|
|
|
InterfaceGuid string `json:",omitempty"`
|
|
|
|
InterfaceLuid uint64 `json:",omitempty"`
|
|
|
|
InterfaceIndex uint32 `json:",omitempty"`
|
|
|
|
InterfaceMediaType uint32 `json:",omitempty"`
|
|
|
|
InterfaceAlias string `json:",omitempty"`
|
|
|
|
InterfaceDescription string `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Network Policy objects
|
|
|
|
|
|
|
|
// SourceMacAddressNetworkPolicySetting sets source MAC for a network.
|
|
|
|
type SourceMacAddressNetworkPolicySetting struct {
|
|
|
|
SourceMacAddress string `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// NetAdapterNameNetworkPolicySetting sets network adapter of a network.
|
|
|
|
type NetAdapterNameNetworkPolicySetting struct {
|
|
|
|
NetworkAdapterName string `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// VSwitchExtensionNetworkPolicySetting enables/disabled VSwitch extensions for a network.
|
|
|
|
type VSwitchExtensionNetworkPolicySetting struct {
|
|
|
|
ExtensionID string `json:",omitempty"`
|
|
|
|
Enable bool `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// DrMacAddressNetworkPolicySetting sets the DR MAC for a network.
|
|
|
|
type DrMacAddressNetworkPolicySetting struct {
|
|
|
|
Address string `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// AutomaticDNSNetworkPolicySetting enables/disables automatic DNS on a network.
|
|
|
|
type AutomaticDNSNetworkPolicySetting struct {
|
|
|
|
Enable bool `json:",omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Subnet Policy objects
|
|
|
|
|
|
|
|
// VlanPolicySetting isolates a subnet with VLAN tagging.
|
|
|
|
type VlanPolicySetting struct {
|
|
|
|
IsolationId uint32 `json:","`
|
|
|
|
}
|
|
|
|
|
|
|
|
// VsidPolicySetting isolates a subnet with VSID tagging.
|
|
|
|
type VsidPolicySetting struct {
|
|
|
|
IsolationId uint32 `json:","`
|
|
|
|
}
|
|
|
|
|
|
|
|
// RemoteSubnetRoutePolicySetting creates remote subnet route rules on a network
|
|
|
|
type RemoteSubnetRoutePolicySetting struct {
|
|
|
|
DestinationPrefix string
|
|
|
|
IsolationId uint16
|
|
|
|
ProviderAddress string
|
|
|
|
DistributedRouterMacAddress string
|
|
|
|
}
|
2021-06-10 19:27:00 +00:00
|
|
|
|
|
|
|
// SetPolicyTypes associated with SetPolicy. Value is IPSET.
|
|
|
|
type SetPolicyType string
|
|
|
|
|
|
|
|
const (
|
|
|
|
SetPolicyTypeIpSet SetPolicyType = "IPSET"
|
|
|
|
)
|
|
|
|
|
|
|
|
// SetPolicySetting creates IPSets on network
|
|
|
|
type SetPolicySetting struct {
|
|
|
|
Id string
|
|
|
|
Name string
|
|
|
|
Type SetPolicyType
|
|
|
|
Values string
|
|
|
|
}
|
|
|
|
|
|
|
|
// VxlanPortPolicySetting allows configuring the VXLAN TCP port
|
|
|
|
type VxlanPortPolicySetting struct {
|
|
|
|
Port uint16
|
|
|
|
}
|
|
|
|
|
|
|
|
// ProtocolType associated with L4ProxyPolicy
|
|
|
|
type ProtocolType uint32
|
|
|
|
|
|
|
|
const (
|
|
|
|
ProtocolTypeUnknown ProtocolType = 0
|
|
|
|
ProtocolTypeICMPv4 ProtocolType = 1
|
|
|
|
ProtocolTypeIGMP ProtocolType = 2
|
|
|
|
ProtocolTypeTCP ProtocolType = 6
|
|
|
|
ProtocolTypeUDP ProtocolType = 17
|
|
|
|
ProtocolTypeICMPv6 ProtocolType = 58
|
|
|
|
)
|
|
|
|
|
|
|
|
//L4ProxyPolicySetting applies proxy policy on network/endpoint
|
|
|
|
type L4ProxyPolicySetting struct {
|
|
|
|
IP string `json:",omitempty"`
|
|
|
|
Port string `json:",omitempty"`
|
|
|
|
Protocol ProtocolType `json:",omitempty"`
|
|
|
|
Exceptions []string `json:",omitempty"`
|
|
|
|
Destination string
|
|
|
|
OutboundNAT bool `json:",omitempty"`
|
|
|
|
}
|