Docker images often contain vulnerabilities that can allow an attacker to leverage when the application is at runtime - in UAT/Test and production environments. It's crucial for DevOps teams to ensure that the security is integrated into CICD Pipeline as early as possible when building your cloud native applications. Check Point's CloudGuard SHIFTLEFT is a security tool that can integrate into your CICD pipeline, and scan your containers for vulnerabilities. SHIFTLEFT can also scan application source codes and IaC such as Terraform for vulnerabilities and misconfigurations.
In this tutorial, I'll do a step-by-step walk-through of integrating CloudGuard SHIFTLEFT into your CICD Pipeline on AWS. The integration will happen at the build stage.
NOTE: This tutorial is not complete yet and it is work in progress.
You need the following tools on your computer:
- AWS CLI Install AWS CLI.
- Docker (If you want to test local Docker build)
- SHIFTLEFT
Note: This is an ALL-AWS tutorial which means we'll be using CICD services provided by AWS ONLY. However, CloudGuard can be integrated with any other automation tools that can create CICD pipeline.
- AWS Account
- Access to Check Point Infinity portal (For now, the scan result can be viewed only on Infinity portal. Hopefully, we'll make it available on CloudGuard console soon.)
-
The IAM role(s) will be created as part of creating a CodeBuild project. Please take note that the role used by CodeBuild requires permissions to access to a number of AWS resources such as S3.
- AmazonEC2ContainerRegistryPowerUser
- An Inline Policy that allows it to "PUT OBJECT" to S3 Bucket that you've created. This is for uploading scan result to S3. (See JSON below)
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Stmt1602483338347",
"Action": [
"s3:PutObject"
],
"Effect": "Allow",
"Resource": "arn:aws:s3:::[YOUR-BUCKET-ARN]/*"
}
]
}
Please make sure that you UPDATE the resource ARN with the ARN of the S3 bucket you've created!
- Finally, you need to add another in-line policy for Codebuild to access CloudGuard credentials stored in AWS SSM parameter store. I'll explain in detail at a later stage.
In this tutorial, we'll be doing the followings;
- Create an AWS ECR repo
(Yes if you'd like to follow along my ALL-AWS tutorial, you'll need to create an ECR repo which will store the docker image.) - Create a CodeCommit Repo
- Generate CloudGuard API Key and Secret
- CodeBuild Project Configuration
- Test the build with SHIFTLEFT
- Integrate with AWS CodePipeline
First you'll need to create a ECR on AWS. Your docker image (after build stage) will be stored in the ECR repo.
You can create the ECR repo on AWS web console or you can just execute the following command.
aws ecr create-repository --repository-name project-a/my-docker
Take note of the Docker Image URI!You will need it later
Then you'll need to create a CodeCommit repo on AWS. We need the CodeCommit repo to store the "source" files that we'll use to build a docker image later in the tutorial. And the Docker image will then be uploaded to the ECR repo.
You can create a CodeCommit repo on AWS web console or you can just execute the following command.
aws codecommit create-repository --repository-name my-docker-repo --repository-description "My Docker Repo"
Then you'll need to do 'git clone your CodeCommit repo' via either SSH or HTTP. It'll be an empty repository first. (This CodeCommit will be used to host the source codes which we will use to build a Docker image.) Then you will need to download the source files (zip) into your local repo here
- Unzip the source files. You'll need to make sure that "src" folder and Dockerfile are in the same root directory in order for Docker build to work.
- Remove the zip file
- Download the Dockerfile & buildspec.yml
In your CodeCommit local directory, you should have the following folder and files.
- src (directory where source codes are)
- Dockerfile
- buildspec.yml (This file isn't needed for Docker image however, it is required to CodeBuild)
- Then you'll need to do
git init
,git add -A
,git commit -m "Your message"
andgit push
(This will upload your local files to your CodeCommit repository) - Above-mentioned files in your local directory should now be uploaded to your CodeCommit repo.
You can also download shiftleft-binary.zip for shiftleft executables for Windows,Linux and MacOs.
Check out the how SHIFTLEFT works and command line usage here.
SHIFTLEFT requires CloudGuard's API key and API secrets in order to run assessments. In Build stage, we'll need to export them into buildspec.yml securely. You can generate CloudGuard API key and API secrets on CloudGuard web console.
Check out How to generate CloudGuard API and API Secret
[IMPORTANT] DO NOT HARDCODE YOUR API KEYS AND SECRETS IN BUILDSPEC.YML IF POSSIBLE
CloudGuard API key and secret that you've just generated need to be declared in buildspec.yml and exported as variables for SHIFTLEFT to use as credentials. It's easier to just hard-code them in the buildspecs.yml in plain text. However, that is not in line with security best practices. You do not want these credentials to be clearly visible in buildspec.yml. (Think DevSecOps)
So here is what we are gonna do (The secure way):
-
We'll store your CloudGuard API key and secret in AWS Systems Manager Parameter Store. We'll need to create two AWS SSM Parameters for "CHKP_CLOUDGUARD_ID" and "CHKP_CLOUDGUARD_SECRET".
-
Then we'll add "ssm:GetParameter" in-line policy to the IAM role that's used by CodeBuild.
-
We'll then embed a couple of commands in buildspec.yml which calls AWS API to access SSM parameters for CloudGuard API key and secret (instead embedding of hard-coded values).
Note: You can also use AWS Secrets Manager to store credentials.
- Go to AWS Management > "Systems Manager"
- Choose "Parameter Store"
- Create a parameter for "CHKP_CLOUDGUARD_ID", and enter your CloudGuard API key. (Choose "String")
- Create a parameter for "CHKP_CLOUDGUARD_SECRET" and enter your CloudGuard Secret. (Choose "String)
And buildspec.yml will instruct Codebuild to access these parameters required for SHIFTLEFT when in build stage.
Optionally, you can choose "SecureString" in which chase the string will be encrypted using KMS keys from your account.
In addition to storing API keys and secrets in AWS SSM, you can store CloudGuard API Key and Secret in Secrets Manager. Please check out How To Store CloudGuard API Key and Secret in Secrets Manager as well.
At this stage, Codebuild IAM role is not yet created. So, Just Remember to add the following in-line policy to the CodeBuild role when it gets created as part of CodeBuild project configuration. This will allow CodeBuild to access to the AWS SSM parameters that we've just created.
(Of course alternatively, you can create a Codebuild role in advance for you to use at the stage when you create the build project.)
Below is a sample in-line policy in JSON format.
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Stmt1603607884407",
"Action": [
"ssm:GetParameter"
],
"Effect": "Allow",
"Resource": "arn:aws:ssm:ap-southeast-1:YOURACCOUNTNO:parameter/CHKP_CLOUDGUARD_ID"
},
{
"Sid": "Stmt1603607963982",
"Action": [
"ssm:GetParameter"
],
"Effect": "Allow",
"Resource": "arn:aws:ssm:ap-southeast-1:YOURACCOUNTNO:parameter/CHKP_CLOUDGUARD_SECRET"
}
]
}
Update resource ARNs with the ARNs of your CloudGuard API Key and Secret. Execute
aws ssm get-parameter --name "CHKP_CLOUDGUARD_ID"
andaws ssm get-parameter --name "CHKP_CLOUDGUARD_SECRET"
to get the ARNs.
Before creating a CodeBuild project you'll first need to do the followings;
- Create S3 Bucket for Build artifacts (Vulnerability Scan result)
- Update buildspec.yml
You'll also need to create an S3 bucket to upload and store a copy of SHIFTLEFT vulnerability scan result.
A copy of scan result is uploaded to Check Point Infinity portal (for now). Hopefully, the scan result will be available on CloudGuard (Dome9) portal soon. I cannot commit on this.
aws s3 mb s3://Your-Bucket-Name
Buildspec.yml instructs CodeBuild in build stage in terms of what to do. Basically, buildspec.yml will instruct AWS CodeBuild to automatically scan the docker image for vulnerability during build stage. And AWS CodeBuild will follow the steps declared in the buildspec.yml file. So this is an important configuration file.
[IMPORTANT] In the buildspec.yml, look for #UPDATE comments and replace the values with your own values accordingly.
In the buildspec.yml you will also see that the SHIFTLEFT binary will be downloaded from my lab S3 bucket. It is a Linux x64 executable file and I uploaded it for the purpose of this lab. In your case, you can upload your own SHIFTLEFT binary to your S3 bucket or whichever repo that can host the file.
version: 0.2
phases:
install:
runtime-versions:
docker: 18
commands:
- nohup /usr/local/bin/dockerd --host=unix:///var/run/docker.sock --host=tcp://127.0.0.1:2375 --storage-driver=overlay2&
- timeout 15 sh -c "until docker info; do echo .; sleep 1; done"
pre_build:
commands:
- echo Logging in to Amazon ECR....
- aws --version
# update the following line with your own region
- $(aws ecr get-login --no-include-email --region ap-southeast-1)
build:
commands:
- echo Downloading SHIFTLEFT
#This instructs CodeBuild to access and use SSM parameters that we've created fro CloudGuard API key and secret
- export CHKP_CLOUDGUARD_ID=$(aws ssm get-parameter --name "CHKP_CLOUDGUARD_ID" | jq -r '.Parameter.Value')
- export CHKP_CLOUDGUARD_SECRET=$(aws ssm get-parameter --name "CHKP_CLOUDGUARD_SECRET" | jq -r '.Parameter.Value')
#UPDATE the shifleft binary here
- wget https://jaydenstaticwebsite.s3-ap-southeast-1.amazonaws.com/download/shiftleft
- chmod -R +x ./shiftleft
- echo Build started on `date`
- echo Building the Docker image...
# UPDATE the following line with the name of your own ECR repository
- docker build -t your-docker-image .
# UPDATE the following line with the URI of your own ECR repository (view the Push Commands in the console)
- docker tag YOUR-DOCKER-IMAGE:latest ECR-URI-dkr.ecr.ap-southeast-1.amazonaws.com/YOUR-DOCKER-IAMGE:latest
#Saving the docker image in tar
- echo Saving Docker image
- docker save chkp-docker -o Your-DOCKER-IAMGE.tar
# Start Scan
- echo Starting scan on `date`
# Update the saved tar file with your docker image name
- ./shiftleft image-scan -i Your-DOCKER-IAMGE.tar > result.txt || if [ "$?" = "6" ]; then exit 0; fi
post_build:
commands:
- echo Build completed on `date`
- echo Pushing image to repo
# UPDATE the following line with the URI of your own ECR repository
- docker push ECR-URI-dkr.ecr.ap-southeast-1.amazonaws.com/YOUR-DOCKER-IAMGE:latest
artifacts:
files:
- result.txt
On AWS Console;
- Go to "CodeBuild"
- If you don't already have a codebuild project, choose "Create Project".
- Add "CodeCommit" as source
- Choose the CodeCommit repo that you've created earlier.
- Choose "Master" branch
In CodeBuild windows, do the following;
- Enter your project name
- Choose "Managed Image" and "Ubuntu" as Operating system
- Choose "Standard" & "Standard:4.0" (It's totally up to you to choose actually.)
- Check "Privileged ...." checkbox
- Choose an existing role or create a new service role. (Add SSM:get-parameter in-line policy to this role!)
Now, please take note that codebuild role requires permissions to access to S3 bucket, ECR repo, and SSM parameter store.
And Finally:
- Ensure that you configure "Artifacts" (THIS IS IMPORTANT)
- Choose "S3" bucket & In "Bucket Name", Enter the S3 Bucket that you've created earlier
- In "Name", Define a folder (e.g. output)
Now your Codebuild project has been created. You can go to your CodeBuild Project, click on "Start Build" and observe the CodeBuild log and output.
Below is an excerpt from the Codebuild output logs.
See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
Build complete.
Don't forget to run 'make test'.
Installing shared extensions: /usr/local/lib/php/extensions/no-debug-non-zts-20160303/
Installing header files: /usr/local/include/php/
warning: mbstring (mbstring.so) is already loaded!
find . -name \*.gcno -o -name \*.gcda | xargs rm -f
find . -name \*.lo -o -name \*.o | xargs rm -f
find . -name \*.la -o -name \*.a | xargs rm -f
find . -name \*.so | xargs rm -f
find . -name .libs -a -type d|xargs rm -rf
rm -f libphp.la modules/* libs/*
Removing intermediate container c9800506bba3
---> ecb661b8e7c5
Step 12/14 : RUN a2enmod rewrite
---> Running in aace68afc4f0
Enabling module rewrite.
To activate the new configuration, you need to run:
service apache2 restart
Removing intermediate container aace68afc4f0
---> e04362b2faaf
Step 13/14 : RUN a2enmod ssl
---> Running in dabd18966a41
Considering dependency setenvif for ssl:
Module setenvif already enabled
Considering dependency mime for ssl:
Module mime already enabled
Considering dependency socache_shmcb for ssl:
Enabling module socache_shmcb.
Enabling module ssl.
See /usr/share/doc/apache2/README.Debian.gz on how to configure SSL and create self-signed certificates.
To activate the new configuration, you need to run:
service apache2 restart
Removing intermediate container dabd18966a41
---> 35cad561b896
Step 14/14 : RUN service apache2 restart
---> Running in 867053eb27be
Restarting Apache httpd web server: apache2AH00558: apache2: Could not reliably determine the server's fully qualified domain name, using 172.18.0.2. Set the 'ServerName' directive globally to suppress this message
Removing intermediate container 867053eb27be
---> 7fdfbf48c822
Successfully built 7fdfbf48c822
Successfully tagged chkp-docker:latest
[Container] 2020/10/09 08:12:08 Running command docker tag chkp-docker:latest 116489363094.dkr.ecr.ap-southeast-1.amazonaws.com/chkp-docker:latest
[Container] 2020/10/09 08:12:08 Running command echo Saving Docker image
Saving Docker image
[Container] 2020/10/09 08:12:08 Running command docker save chkp-docker -o chkp-docker.tar
[Container] 2020/10/09 08:12:14 Running command echo Starting scan at `date`
Starting scan at Fri Oct 9 08:12:14 UTC 2020
[Container] 2020/10/09 08:12:14 Running command ./shiftleft image-scan -i chkp-docker.tar > result.txt || if [ "$?" = "6" ]; then exit 0; fi
INFO [09-10-2020 08:12:17.476] blade image-scan updated (0.0.130)
INFO [09-10-2020 08:12:17.594] SourceGuard Scan Started!
INFO [09-10-2020 08:12:19.471] Project name: chkp-docker path: /tmp/SourceGuard247824249
INFO [09-10-2020 08:12:19.471] Scan ID: 35cad561b8968f02ac5a2e0cb05b1b2fb417b756376dc04164ec5958908d23d8-SvBL8P
INFO [09-10-2020 08:12:31.647] Scanning ...
INFO [09-10-2020 08:12:48.892] Analyzing ...
[Container] 2020/10/09 08:14:25 Phase complete: BUILD State: SUCCEEDED
[Container] 2020/10/09 08:14:25 Phase context status code: Message:
[Container] 2020/10/09 08:14:25 Entering phase POST_BUILD
[Container] 2020/10/09 08:14:25 Running command echo Build completed on `date`
Build completed on Fri Oct 9 08:14:25 UTC 2020
[Container] 2020/10/09 08:14:25 Running command echo Pushing image to repo
Pushing image to repo
[Container] 2020/10/09 08:14:25 Running command docker push 123456789.dkr.ecr.ap-southeast-1.amazonaws.com/chkp-docker:latest
The push refers to repository [123456789.dkr.ecr.ap-southeast-1.amazonaws.com/chkp-docker]
98d3c49f13ab: Preparing
96fd7149e6a8: Preparing
5c008103b520: Preparing
897144f6e2ff: Preparing
eac34fee20ac: Preparing
c34869bde755: Preparing
bd51b78ec5a5: Preparing
ae9ead4be184: Preparing
36a33866c585: Preparing
4c4801c52898: Preparing
9a078a1d1b01: Preparing
a42cb226a41b: Preparing
0d678d51888b: Preparing
0817436a8f49: Preparing
3385a426f542: Preparing
35c986c7de74: Preparing
53bab0663330: Preparing
606c36b65880: Preparing
ab99fcc1a184: Preparing
9691e5d7a4c7: Preparing
6a4d393f0795: Preparing
e38834ac7561: Preparing
ec64f555d498: Preparing
840f3f414cf6: Preparing
17fce12edef0: Preparing
831c5620387f: Preparing
c34869bde755: Waiting
bd51b78ec5a5: Waiting
ae9ead4be184: Waiting
36a33866c585: Waiting
4c4801c52898: Waiting
9a078a1d1b01: Waiting
a42cb226a41b: Waiting
0d678d51888b: Waiting
0817436a8f49: Waiting
3385a426f542: Waiting
35c986c7de74: Waiting
53bab0663330: Waiting
606c36b65880: Waiting
ab99fcc1a184: Waiting
9691e5d7a4c7: Waiting
6a4d393f0795: Waiting
e38834ac7561: Waiting
ec64f555d498: Waiting
840f3f414cf6: Waiting
17fce12edef0: Waiting
831c5620387f: Waiting
5c008103b520: Pushed
96fd7149e6a8: Pushed
eac34fee20ac: Pushed
c34869bde755: Pushed
98d3c49f13ab: Pushed
bd51b78ec5a5: Pushed
897144f6e2ff: Pushed
4c4801c52898: Pushed
36a33866c585: Pushed
ae9ead4be184: Pushed
0817436a8f49: Layer already exists
3385a426f542: Layer already exists
35c986c7de74: Layer already exists
53bab0663330: Layer already exists
ab99fcc1a184: Layer already exists
606c36b65880: Layer already exists
9a078a1d1b01: Pushed
a42cb226a41b: Pushed
6a4d393f0795: Layer already exists
9691e5d7a4c7: Layer already exists
e38834ac7561: Layer already exists
ec64f555d498: Layer already exists
17fce12edef0: Layer already exists
840f3f414cf6: Layer already exists
831c5620387f: Layer already exists
0d678d51888b: Pushed
latest: digest: sha256:a46642efce16bbed3015725bfd40cbabb2115529ceb0e0a0430ca44b74f8453f size: 5740
[Container] 2020/10/26 04:33:51 Running command echo Build complete on `date`
Build complete on Mon Oct 26 04:33:51 UTC 2020
[Container] 2020/10/26 04:33:51 Phase complete: POST_BUILD State: SUCCEEDED
[Container] 2020/10/26 04:33:51 Phase context status code: Message:
[Container] 2020/10/26 04:33:51 Expanding base directory path: .
[Container] 2020/10/26 04:33:51 Assembling file list
[Container] 2020/10/26 04:33:51 Expanding .
[Container] 2020/10/26 04:33:51 Expanding file paths for base directory .
[Container] 2020/10/26 04:33:51 Assembling file list
[Container] 2020/10/26 04:33:51 Expanding result.txt
[Container] 2020/10/26 04:33:51 Found 1 file(s)
Check out that the build has been completed.
Finally, you can check and verify that SHIFTLEFT has been integrated with CodeBuild, and runs an assessment on the docker image.
On AWS Console, go to "S3", and the S3 bucket that we've created for storing artifacts while configuring CodeBuild project. In the "output" folder, you should see "result.txt" which basically is the vulnerability scan report generated by SHIFTLEFT.
NOTE A copy of the result has been sent to Check Point Infinity Portal. If you have access to infinity portal, you can view the scan result on the portal. (Hopefully, this will be available on CloudGuard portal soon) Otherwise, in result.txt, you can see a number of vulnerabilities found in the docker image!
CVEs Findings:
- ID: CVE-2018-21232
Description: re2c before 2.0 has uncontrolled recursion that causes stack consumption in find_fixed_tags.
Severity: MEDIUM
Last Modified: 2020-05-14T12:15:00Z
- ncurses-base 6.1+20181013-2+deb10u2
Severity: MEDIUM
Line: 3524
CVEs Findings:
- ID: CVE-2019-17594
Description: There is a heap-based buffer over-read in the _nc_find_entry function in tinfo/comp_hash.c in the terminfo library in ncurses before 6.1-20191012.
Severity: MEDIUM
Last Modified: 2019-12-26T15:35:00Z
- ID: CVE-2019-17595
Description: There is a heap-based buffer over-read in the fmt_entry function in tinfo/comp_hash.c in the terminfo library in ncurses before 6.1-20191012.
Severity: MEDIUM
Last Modified: 2019-12-23T19:26:00Z
- libbrotli1 1.0.7-2
Severity: MEDIUM
Line: 1350
CVEs Findings:
- ID: CVE-2020-8927
Description: A buffer overflow exists in the Brotli library versions prior to 1.0.8 where an attacker controlling the input length of a "one-shot" decompression request to a script can trigger a crash, which happens when copying over chunks of data larger than 2 GiB. It is recommended to update your Brotli library to 1.0.8 or later. If one cannot update, we recommend to use the "streaming" API as opposed to the "one-shot" API, and impose chunk size limits.
Severity: MEDIUM
Last Modified: 2020-09-30T18:15:00Z
- util-linux 2.33.1-0.1
Severity: UNKNOWN
Line: 3899
CVEs Findings:
- ID: CVE-2007-5191
Description: mount and umount in util-linux and loop-aes-utils call the setuid and setgid functions in the wrong order and do not check the return values, which might allow attackers to gain privileges via helpers such as mount.nfs.
Severity: UNKNOWN
Last Modified: 2018-10-15T21:41:00Z
- ID: CVE-2001-1494
Description: script command in the util-linux package before 2.11n allows local users to overwrite arbitrary files by setting a hardlink from the typescript log file to any file on the system, then having root execute the script command.
Severity: UNKNOWN
Last Modified: 2017-10-11T01:29:00Z
- m4 1.4.18-2
Severity: UNKNOWN
Line: 3407
CVEs Findings:
- ID: CVE-2008-1688
Description: Unspecified vulnerability in GNU m4 before 1.4.11 might allow context-dependent attackers to execute arbitrary code, related to improper handling of filenames specified with the -F option. NOTE: it is not clear when this issue crosses privilege boundaries.
Severity: UNKNOWN
Last Modified: 2017-08-08T01:30:00Z
- ID: CVE-2008-1687
Description: The (1) maketemp and (2) mkstemp builtin functions in GNU m4 before 1.4.11 do not quote their output when a file is created, which might allow context-dependent attackers to trigger a macro expansion, leading to unspecified use of an incorrect filename.
Severity: UNKNOWN
Last Modified: 2017-08-08T01:30:00Z
Please see full analysis: https://portal.checkpoint.com/Dashboard/SourceGuard#/scan/image/35cad561b8968f02ac5a2eabcderdfdkfndkfndk
Now you can go through the scan result and analyze the vulnerabilities in docker image discovered by SHIFTLEFT.
CONGRATULATIONS!!! You've successfully integrated CloudGuard SHIFTLEFT with on AWS CodeBuild!
You have successfully integrated SHIFTLEFT with AWS CodeBuild. If you want to take a step further, and integrate SHIFTLEFT with AWS CodePipeline, you can do so easily. You can create a CodePipeline, using your CodeCommit repo as source and Codebuild in the build stage (use the Codebuild project that you've created.). So every time you make changes to the docker image source files in CodeCommit repo, a pipeline execution in CodePipeline will be started, running a revision through every stage and action in the pipeline. While in build stage of the pipeline, SHIFTLEFT will be triggered to scan the docker image. In this way, a SHIFTLEFT assessment is triggered every time a new docker image is built, and you can fully integrate SHIFTLEFT into your CICD pipeline on AWS!
An easy and quick way to create a CodePipeline is using AWS CLI. You can download my-codepipeline.json from this Github repo which is a sample CodePipeline JSON file I've created for this lab. You can update the JSON file with your own values, and execute the following CLI.
aws codepipeline create-pipeline --cli-input-json file://my-codepipeline.json
This will basically create a CodePipeline!
Once the CodePipeline is set up, you can observe events in each stage of pipeline execution once it's started. You can also start the pipeline execution by making changes to the source code in the CodeCommit repo (followed by committing the code using git commands). Only this time, your docker image will be scanned for vulnerabilities by CloudGuard SHIFTLEFT every time a new docker image is built.
Happy DevSecOps-ing!
Jayden Aung
-
One of the issues you might probably encounter in Build is the build stage might fail due to IAM insufficient permissions. Ensure that the CodeBuild IAM role has the sufficient permissions attached to it.
-
Once CodePipeline has been set up, the artifact (result.txt) will be uploaded to CodePipeline's artifact S3, rather than CodeBuild's artifact S3 bucket. So if you still want to copy the scan result to the CodeBuild's artifact store S3 bucket, please add the following command to the "buildspec.yml".
aws s3 cp result.txt s3://your-codebuild-artifacts-s3-bucket/result.txt
-
Here is another good tutorial you might want to check out - CloudGuard integration with Jenkins by Dean Houari