Hi All,
I’m happy to share a small PowerShell script that will save you a ton of time when you decide to switch from Azure Firewall to Check Point CloudGuard Network Security.
The script will export your firewall policies on Azure, including all of its objects, to multiple CSV files.
Then, import the CSV files to your Check Point management machine.
At the end of the process, you will get all the objects and policies created on the Check Point management machine.
Depending on your policy size on Azure, the entire process, end to end, should not take more than 10 minutes.
The PowerShell script is attached to the end of the post.
Here is a quick how-to guide (At the end of this guide, you will also find a tutorial video)
On the Azure Firewall, I have a firewall policy with five collection groups.
Each collection group consists of one or more rule sets (network rule collection and Application Rule collection)
data:image/s3,"s3://crabby-images/ebd71/ebd7125dd54f15b8dfd7cae05f488c0ef8985321" alt="collection groups.jpg collection groups.jpg"
data:image/s3,"s3://crabby-images/27b4a/27b4a32a7018c9d2e901e0cb790adb2993c2aa6f" alt="2.png 2.png"
When you run the PowerShell script, run it against all the collection groups at once.
First, download the attached zip file, and export its content to a temp directory.
Open the PowerShell script in Notepad++ and replace the values in rows 2, 3, and 4
The $fpname value should be replaced with the policy name.
The $fprg value should be replaced with the policy resource group.
The $fprcgname should be replaced with the collection group names.
data:image/s3,"s3://crabby-images/0a7a4/0a7a493f52716846f4f8d848bf1e40793f131387" alt="coll.jpg coll.jpg"
data:image/s3,"s3://crabby-images/46b6a/46b6ac0b8634b21ec5516e9062e7139ca501dd53" alt="Shay_Levin_5-1704380597101.png Shay_Levin_5-1704380597101.png"
data:image/s3,"s3://crabby-images/47a43/47a43941fff93a2faa288999d2073ca452dccb02" alt="Shay_Levin_6-1704380597103.png Shay_Levin_6-1704380597103.png"
Set your Check Point management username and password on rows 6 & 7.
data:image/s3,"s3://crabby-images/e0f98/e0f989727904815bf8d9a464341e8a06e12f19c7" alt="use.jpg use.jpg"
Create a folder C:\temp\export
Save the file fwexport.txt to the new Folder, and ensure the extension is ps1.
data:image/s3,"s3://crabby-images/2c3b3/2c3b3bf657332382a31e17b747f83b1c4e9920a7" alt="Shay_Levin_7-1704380597104.png Shay_Levin_7-1704380597104.png"
Open PowerShell and log in to your Azure Tenet ( Connect-AzAccount –Tenant ‘tenant-id’ )
data:image/s3,"s3://crabby-images/0cd61/0cd61ad99918d3f76869852ee0591bae3e9d50e7" alt="Shay_Levin_8-1704380597105.png Shay_Levin_8-1704380597105.png"
data:image/s3,"s3://crabby-images/05267/05267b96a7f1a2520743107684b70d05e66aacfe" alt="Shay_Levin_9-1704380597106.png Shay_Levin_9-1704380597106.png"
Switch the directory to C:\temp\export
data:image/s3,"s3://crabby-images/db186/db186d5ebe168771efbb8c14b2401d5e19f0a373" alt="Shay_Levin_10-1704380597106.png Shay_Levin_10-1704380597106.png"
Run the PowerShell script
The script will export the policy and create a tar file with multiple CSV files that include all the required objects. (Be patient; it might take a few minutes ….)
data:image/s3,"s3://crabby-images/2e260/2e260fb52151ea8ea1092cbebda5da51f38051b0" alt="Shay_Levin_11-1704380597107.png Shay_Levin_11-1704380597107.png"
data:image/s3,"s3://crabby-images/64ede/64edeaffbb89f2cb4f87a56c1bbfc3d4041b0bb7" alt="export.jpg export.jpg"
Two files will be created, *.tar & *.sh
data:image/s3,"s3://crabby-images/d3d88/d3d88a503b9f62848f4849610d05f06919bfa22e" alt="files.jpg files.jpg"
Copy the two files to the home folder of the Check Point management machine.
Copy the two files to the home folder on the Check Point management.
data:image/s3,"s3://crabby-images/868a0/868a0cbbeb5938e81e8c590b09c2dbb51a8b6524" alt="mng.jpg mng.jpg"
Open SSH to the Check Point management machine ( switch to expert mode ) and run the command: bash import_rules.sh
data:image/s3,"s3://crabby-images/181b9/181b91fb88e9ff5501c96b294678adb7169612d7" alt="bas.jpg bas.jpg"
The script will extract the tar file and import each one of the CSV files.
data:image/s3,"s3://crabby-images/614b7/614b7c9e054e619b95494356a8fc1f181c4cbf01" alt="imp.jpg imp.jpg"
** If you prefer to import each file manually, you can extract the tar file and run the command below in the following order:
mgmt_cli add host --batch hosts-migrate.csv
mgmt_cli add network --batch subnets-migrate.csv
mgmt_cli add address-range --batch ipranges-migrate.csv
mgmt_cli add dns-domain --batch fqdn-migrate.csv
mgmt_cli add group --batch ipgroups-migrate.csv
mgmt_cli add access-layer --batch layernames-migrate.csv
mgmt_cli set host --batch hosts-with-groups-migrate.csv
mgmt_cli set network --batch subnets-with-groups-migrate.csv
mgmt_cli set address-range --batch ipranges-with-groups-migrate.csv
mgmt_cli add service-tcp --batch services-tcp-migrate.csv
mgmt_cli add service-udp --batch services-udp-migrate.csv
mgmt_cli add access-rule --batch all_rules-transformed.csv
data:image/s3,"s3://crabby-images/6d164/6d164f1a6a581bb6b37737e5c2df07dc5d4f2d99" alt="Shay_Levin_15-1704380597113.png Shay_Levin_15-1704380597113.png"
data:image/s3,"s3://crabby-images/46749/467497c0350117387e678353c4e9e4c042179ae3" alt="Shay_Levin_16-1704380597114.png Shay_Levin_16-1704380597114.png"
Once all the CSV files have been imported, Open SmartConsole and open Policies & Layers with ‘Ctrl+o’
Click on the Layers tab, and you will see on the right pane the two new layers that have been imported (test1 and appcollection1)
data:image/s3,"s3://crabby-images/c12ac/c12ac698af878e704d4b1d087f95ab59ad35881b" alt="Shay_Levin_17-1704380597115.png Shay_Levin_17-1704380597115.png"
Right-click on each layer and open it in a new tab.
data:image/s3,"s3://crabby-images/d1f46/d1f466c9a65da92b9a10716b4d5bbfd57aafb0a5" alt="Shay_Levin_18-1704380597117.png Shay_Levin_18-1704380597117.png"
Now, you can use this layer or just copy multiple rules from one layer to a different policy or different layer.
data:image/s3,"s3://crabby-images/d9547/d9547e2f78ac7e0890bba042dd3e07a00c4bcdc6" alt="3.png 3.png"
Limitations:
Feel free to edit the script and adjust this list per your needs.
1. On Azure Policy, The Destination Type: ‘Service Tag’ in the Network Rule Collection will not be translated; in this case, the destination in the Check Point policy will be ‘none’
- On Azure Policy, Destination Type: ‘FQDN Tag’ and ‘Web Categories’ in the Application Rule Collection will not be translated; in this case, the destination in the Check Point policy will be ‘none.’
- On Azure Policy, DNAT Rules – Export is not supported at this stage.