Hi there, in this post we’re going to see how to interact with Check Point Management API. We are going to run some API commands using GAIA CLI (clish), Windows CLI and SmartConsole CLI.
Before starting, be sure to enable to enable API on SmartConsole > Manage & Settings > Blades > Management API > Advanced Settings > Accept call from: All IP addresses.
data:image/s3,"s3://crabby-images/0350a/0350ae0e0bb8665d9dd5ebbb6e2c29aaa10ec5c4" alt="1.png 1.png"
This change requires us to restart the api service. Login into management server and restart the api service by running the command api restart
data:image/s3,"s3://crabby-images/080cf/080cf5b9e142fab5af19f1d61d7b1930bfe63921" alt="2.png 2.png"
After some minutes we can verify the api status service by running the command api status
data:image/s3,"s3://crabby-images/fc78f/fc78f56ccc236a587fdc917a43655b3559c6275a" alt="3.png 3.png"
As we are already at Gaia clish, we’ll begin performing some operations here.
First we have to log in as a management user by running the command mgmt login. Another variation for this command is to use mgmt login without the user argument, but for some reason the authentication failed.
data:image/s3,"s3://crabby-images/2d3fb/2d3fb5215845ffcfc0f4c574f2daa2e0b5b10bc1" alt="4.png 4.png"
To use api commands the syntax is mgmt + command + parameters. For example let’s list all the network objects by running the command mgmt show-networks
data:image/s3,"s3://crabby-images/69474/69474a01227cd9f72ddcf61197b249fe839bf155" alt="5.png 5.png"
The result is printed in json format. This means that we can leverage this output using python (I'll right more about this in the future).
Let’s change the DMZ network name, by running the command mgmt set network name DMZ new-name DMZ-API color “blue”
data:image/s3,"s3://crabby-images/36ced/36ced25acad36945dd75eb58cdce82a5a0b144f7" alt="6.png 6.png"
When we change an object value, the object will be locked for the current session until we publish the change.
data:image/s3,"s3://crabby-images/8a12e/8a12e8646e354aa707a3a6a8b865c37f0eb70f32" alt="7.png 7.png"
Let’s publish the change by running the command mgmt publish
data:image/s3,"s3://crabby-images/07adb/07adb50888d19d8cb93590456a3b31b4451b8ea4" alt="8.png 8.png"
And we have success. Let’s verify by running the command mgmt show network name DMZ-API
data:image/s3,"s3://crabby-images/00cef/00cef27cc43799e44871e2beba22e96daca924df" alt="9.png 9.png"
We can also verify by looking at SmartConsole
data:image/s3,"s3://crabby-images/20cfc/20cfce885488b99c5e85412f2d2eeef5c49daafa" alt="10.png 10.png"
Now let's install a policy by running the command mgmt install-policy policy-package MainSite access true threat-prevention true targets.1 A-GW-CLUSTER
data:image/s3,"s3://crabby-images/66393/663932c608d9e4ef66bf09cf4680fd82d34cdebb" alt="11.png 11.png"
We should get a successful result
data:image/s3,"s3://crabby-images/30886/3088602df3a82cf3349cc0230eb24c6350b30a43" alt="12.png 12.png"
data:image/s3,"s3://crabby-images/97030/97030310665b674ebe4d171aec062a8c22d25df0" alt="13.png 13.png"
Windows cli console
Now let’s run some commands using windows cli console. We’ll have to use the Check Point tool mgmt_cli.exe, located in C:\Program Files (x86)\CheckPoint\SmartConsole\R81\PROGRAM folder.
When using the mgmt_cli tool, in order for a command to run, it is mandatory to provide login credentials or use a session-id token that was obtained previously using the ‘login’ command.
Let’s login into mgmt_server by running the command mgmt_cli login –u silesio –p admin1234 –m 192.168.234.11
data:image/s3,"s3://crabby-images/82259/822591fe4bbde8ebaf624e6671c6c47da0387c05" alt="14.png 14.png"
Now let’s see all the hosts by running the command mgmt_cli show hosts –u silesio –p admin1234 –m 192.168.234.11
data:image/s3,"s3://crabby-images/6a10c/6a10ca4b3ca1f117afb000c2e3c0126637dac2af" alt="15.png 15.png"
Calling mgmt_cli with credentials (provided explicitly or entered by prompt) will result in performing four different operations:
- Log into the management server using the supplied credentials
- Execute the command
- Publish
- Logout
Let’s delete the host H_192.168.20.1 by running the command mgmt_cli delete host name H_192.168.20.1 –u silesio –p admin1234 –m 192.168.234.11
data:image/s3,"s3://crabby-images/9cc69/9cc69d6d2dec31378e2f4975b8eaa353544b6441" alt="16.png 16.png"
We can also run the commands without specifying the credentials all the time. Let’s create a file to store the session and use it whenever we want to run a command.
Open the windows prompt as administrator.
data:image/s3,"s3://crabby-images/af557/af557bfa8a31c1eb0cb28a7cca180906b4a3c413" alt="17.png 17.png"
Type the command mgmt_cli –u silesio –p admin1234 –m 192.168.234.11 > session.txt
data:image/s3,"s3://crabby-images/ce157/ce157395b1a8a61f3c1e8d8d079cf9c33e3bb032" alt="18.png 18.png"
Let’s add a new host by running the command mgmt_cli add host name "New Host API" ip-address 172.30.30.1 color green -s session.txt
data:image/s3,"s3://crabby-images/b6569/b6569eb1e585c3b929d72f6b755c059e0c82dc41" alt="19.png 19.png"
Notice that the change, wasn’t published. In the above example, the output from the login command is redirected to a file called "session.txt". By using the "-s" parameter, the rest of the commands read "session.txt" and automatically extract the session-id from this file.
data:image/s3,"s3://crabby-images/a7d0b/a7d0b6a777e7ec59bd8cc8e035e9623bd0d48379" alt="20.png 20.png"
We can confirm the new host was created successfully.
data:image/s3,"s3://crabby-images/0ebe0/0ebe006cceba9a1d265036945919209104dc42c7" alt="21.png 21.png"
SmartConsole CLI
Lastly, let’s use the SmartConsole CLI.
When typing commands inside the window they just work - There is no need to provide a username, password or the ip-address of the management server because this information was already provided in the GUI’s login dialog and the commands are executed in that context.
The syntax is identical to the commands used previously. The main difference, here we don’t have to add mgmt command.
data:image/s3,"s3://crabby-images/2ad87/2ad87caed89738f9300dbc5aa097a54b03710a74" alt="22.png 22.png"
Let’s add two groups, and a new network inside of one of the groups.
data:image/s3,"s3://crabby-images/9b2bc/9b2bcec3be227b403c64cb7819ee108b6520f51a" alt="23.png 23.png"
data:image/s3,"s3://crabby-images/f362c/f362ccb651153f90a0840cacc660be4e59330955" alt="24.png 24.png"
data:image/s3,"s3://crabby-images/e2363/e2363947e047c0555927bc8f064f657b5e8da1dc" alt="25.png 25.png"
To save the changes we have to publish.
data:image/s3,"s3://crabby-images/87312/873123ff6d522f1422a94e855ffd67fa61d6a9e2" alt="26.png 26.png"
It appears that the publish command isn’t supported inside SmartConsole CLI, so we have publish manually.
data:image/s3,"s3://crabby-images/4b596/4b596607f2c6cffc69343f10f1b1541715805d98" alt="27.png 27.png"
These are some of the commands that we can use to interact with Check Point Management API. They are more helpful for bulk operations like adding more than 100 objects, or even to automate some repetitive tasks.
I hope you enjoyed this post, leave your comments below and I'll see you on the next one.
Reference:
https:// sc1.checkpoint.com/documents/latest/APIs/index.html#cli/introduction~v1.7%20