Task 3

Task 3: Create a policy set and apply it to a FortiGate CNF Instance

    1. At this point, we are using the default allow_all policy set which allows all communication to be allowed without any restriction from a Layer 4 and Layer 7 perspective.

    1. To customize the actual L4 rules and L7 security profile groups applied, in the FortiGate CNF Console navigate to Configuration > Policy Sets to create your own policy set. Simply click Create New, select Policy Set, and give your policy set a name.

    1. Before adding in L4 rules within the policy set, create a few simple address objects. Navigate to Configuration > Addresses, click New, and Address. Then create each of the address objects below.
NameTypeIP/Netmask Value
ClassASubnet10.0.0.0/8
ClassBSubnet172.16.0.0/12
ClassCSubnet192.168.0.0/16
GooglePublicDNS1Subnet8.8.8.8/32
GooglePublicDNS2Subnet8.8.4.4/32
AppPublicSubnet1Subnet10.1.1.0/24
AppPublicSubnet2Subnet10.1.2.0/24

    1. Next, create an Address Group to include all the RFC 1918 class objects. On the same page, click New, and Address Group. Then create each the address object below.
NameMembers Value
RFC-1918ClassA, ClassB, ClassC

    1. In FortiGate CNF you can create different types of address objects to be more flexible and granular in your rules within your policy set. Create an FQDN based address object by clicking New, and Address. Select FQDN for Type, then create the address object below.
Tip

Note: This can be used for internal Application, Network, and even legacy Elastic Load Balancers (ie ALB, NLB, ELB) to dynamically resolve their private IPs.

NameTypeFQDN Value
ipinfo.ioFQDNipinfo.io

    1. Geography based address objects are available in FortiGate CNF. This allows controlling traffic based on public IPs assigned to countries around the globe. These objects can be used as a source or destination object within policies used in a policy set. Create a geo based address object by clicking New, and Address. Select Geography for Type, then create the address objects below.
Tip

Note: The IP for the country or region is automatically determined from the Geography IP database which is provided by FortiGuard Servers on a recurring basis. For more granular control to applications (especially external), it is recommended to use URL or DNS filtering and even Application Control for L7 inspection.

NameTypeCountry/Region Value
UnitedStatesGeographyUnited States
RussiaGeographyRussian Federation

    1. Dynamic metadata based address objects are available in FortiGate CNF. This allows controlling of traffic based on things such as VPC ID, Auto Scale Group, EKS Cluster or Pod, and even Tag Name + Value pairs for a given AWS account and region. Create a dynamic based address object by clicking New, and Address. Select Dynamic for Type, then create the address objects below.
Tip

Note: This is using AWS API calls behind the scenes such as ec2:DescribeInstances, eks:ListClusters, eks:DescribeCluster, etc. For instances, these must be running to have their IP address(es) (public and or private IPs) returned.

Note: For each object, you will use the same values for these settings:

TypeAWS Account IDAWS Region
DynamicWorkshop-AWS-Account-IDus-east-2

Here is the list of dynamic objects to create:

NameSDN Address TypeFilter Value
ProdAPIBackendPrivateTag.env=prod AND Tag.app-role=api AND Tag.app-tier=backend
ProdAuthBackendPrivateTag.env=prod AND Tag.app-role=auth AND Tag.app-tier=backend
SDNGroup1PrivateTag.sdn-group=group1
SDNGroup2PrivateTag.sdn-group=group2
SDNGroup3PrivateTag.sdn-group=group3

    1. Now you will create a policy set to enforce L4 rules using the address objects you just created in the previous steps. Navigate to Configuration > Policy Sets and click New, Policy Set. Give it a name and click Ok. You will be returned to the list of policy sets. Select your policy set and click Edit.

    1. Now you can create the policies listed below to control all directions of traffic within the example environment. Click New and create the policies listed below:
NameSourceDestinationServiceActionLog Allowed Traffic
BlockList-InboundRussiaallALLDENYAll Sessions
BlockList-OutboundallRussiaALLDENYAll Sessions
HTTPS-InboundUnitedStatesRFC-1918HTTPSACCEPTAll Sessions
ICMP-EastWestRFC-1918RFC-1918ALL_ICMPACCEPTAll Sessions
AuthSharedServices-EastWestProdAPIBackendProdAuthBackendHTTPS + RADIUSACCEPTAll Sessions
ICMP-EgressRFC-1918UnitedStatesALL_ICMPACCEPTAll Sessions
IPinfo-EgressSDNGroup1 + SDNGroup2 + AppPublicSubnet1 + AppPublicSubnet2ipinfo.ioHTTPSACCEPTAll Sessions

    1. In order to use this policy set, it must be applied to the deployed FortiGate CNF Instance. Navigate to CNF instances and select and edit the CNF Instance then click the Configure Policy Set bread crumb. In the Apply Policy Set, select your policy set then click Save then Exit.
Warning

Note: If you skip this step, your CNF Instance would still be using the allow_all policy set which means it basically just a cool FireRouter. 😜

    1. This concludes this section.