Infrastructure as Code scanning
- Tier: Free, Premium, Ultimate
- Offering: GitLab.com, GitLab Self-Managed, GitLab Dedicated
Infrastructure as Code (IaC) scanning runs in your CI/CD pipeline, checking your infrastructure definition files for known vulnerabilities. Identify vulnerabilities before they're committed to the default branch to proactively address the risk to your application.
The IaC scanning analyzer outputs JSON-formatted reports as job artifacts.
With GitLab Ultimate, IaC scanning results are also processed so you can:
- See them in merge requests.
- Use them in approval workflows.
- Review them in the vulnerability report.
Getting started
If you are new to IaC scanning, the following steps show how you can quickly enable IaC scanning for your project.
Prerequisites:
- IaC scanning requires the AMD64 architecture. Microsoft Windows is not supported.
- Minimum of 4 GB RAM to ensure consistent performance.
- The teststage is required in the.gitlab-ci.ymlfile.
- On GitLab Self-Managed you need GitLab Runner with the
dockerorkubernetesexecutor.
- If you're using SaaS runners on GitLab.com, this is enabled by default.
To enable IaC scanning:
- On the left sidebar, select Search or go to and find your project.
- If your project does not already have one, create a .gitlab-ci.ymlfile in the root directory.
- At the top of the .gitlab-ci.ymlfile, add one of the following lines:
Using a template:
include:
  - template: Jobs/SAST-IaC.gitlab-ci.ymlOr using a CI/CD component:
include:
  - component: gitlab.com/components/sast/iac-sast@mainAt this point, IaC scanning is enabled in your pipeline. If supported IaC source code is present, the default rules automatically scan for vulnerabilities when a pipeline runs. The corresponding job appears under the test stage in your pipeline.
You can see a working example in IaC scanning example project.
After completing these steps, you can:
- Learn more about how to understand the results
- Review optimization tips
- Plan a rollout to more projects
Understanding the results
You can review vulnerabilities in a pipeline:
- On the left sidebar, select Search or go to and find your project.
- On the left sidebar, select Build > Pipelines.
- Select the pipeline.
- Select the Security tab.
- Select a vulnerability to view its details, including:
- Description: Explains the cause of the vulnerability, its potential impact, and recommended remediation steps.
- Status: Indicates whether the vulnerability has been triaged or resolved.
- Severity: Learn more about severity levels.
- Location: Shows the filename and line number where the issue was found. Selecting the file path opens the corresponding line in the code view.
- Scanner: Identifies which analyzer detected the vulnerability.
- Identifiers: A list of references used to classify the vulnerability, such as CWE identifiers and the IDs of the rules that detected it.
 
You can also download the security scan results:
- In the pipeline's Security tab, select Download results.
For more details, see Pipeline security report.
Findings are generated on feature branches. When they are merged into the default branch, they become vulnerabilities. This distinction is important when evaluating your security posture.
Additional ways to see IaC scanning results:
- Merge request widget: Shows newly introduced or resolved findings.
- Merge request changes view: Shows inline annotations for changed lines.
- Vulnerability report: Shows confirmed vulnerabilities on the default branch.
Supported languages and frameworks
IaC scanning supports a variety of IaC configuration files. When any supported configuration files are detected in a project, they are scanned by using KICS. Projects with a mix of IaC configuration files are supported.
Supported configuration formats:
- 
Ansible 
- 
AWS CloudFormation 
- 
Azure Resource Manager IaC scanning can analyze Azure Resource Manager templates in JSON format. If you write templates in Bicep, you must use the Bicep CLI to convert your Bicep files into JSON before IaC scanning can analyze them. 
- 
Dockerfile 
- 
Google Deployment Manager 
- 
Kubernetes 
- 
OpenAPI 
- 
Terraform Terraform modules in a custom registry are not scanned for vulnerabilities. For more information about the proposed feature, see issue 357004. 
Optimization
- Tier: Ultimate
- Offering: GitLab.com, GitLab Self-Managed, GitLab Dedicated
You can customize IaC scanning by:
- Disabling a rule for all files.
- Disabling scanning of a file, entirely or only for a rule.
- Overriding a rule's attributes.
Ruleset definition
Every IaC scanning rule is contained in a ruleset section, which contains:
- A typefield for the rule. For IaC scanning, the identifier type iskics_id.
- A valuefield for the rule identifier. KICS rule identifiers are alphanumeric strings. To find the rule identifier:- Find it in the JSON report artifact.
- Search for the rule name in the list of KICS queries and copy the alphanumeric identifier that's shown. The rule name is shown on the vulnerability details page when a rule violation is detected.
 
Disable rules
You can disable specific IaC scanning rules.
To disable analyzer rules:
- Create a .gitlabdirectory at the root of your project, if one doesn't already exist.
- Create a custom ruleset file named sast-ruleset.tomlin the.gitlabdirectory, if one doesn't already exist.
- Set the disabledflag totruein the context of arulesetsection.
- In one or more rulesetsubsections, list the rules to disable.
After you merge the sast-ruleset.toml file to the default branch, existing findings for disabled rules are automatically resolved.
In the following example sast-ruleset.toml file, the disabled rules are assigned to
the kics analyzer by matching the type and value of identifiers:
[kics]
  [[kics.ruleset]]
    disable = true
    [kics.ruleset.identifier]
      type = "kics_id"
      value = "8212e2d7-e683-49bc-bf78-d6799075c5a7"
  [[kics.ruleset]]
    disable = true
    [kics.ruleset.identifier]
      type = "kics_id"
      value = "b03a748a-542d-44f4-bb86-9199ab4fd2d5"Disable scanning of a file
To disable scanning of a file, either entirely or for only a rule, use KICS annotations in that file.
This feature is only available for some types of IaC files. See the KICS documentation for a list of supported file types.
- To skip scanning an entire file, add # kics-scan ignoreas a comment at the top of the file.
- To disable a specific rule in an entire file, add # kics-scan disable=<kics_id>as a comment at the top of the file.
Override rules
You can override specific IaC scanning rules to customize them. For example, assign a rule a lower severity, or link to your own documentation about how to fix a finding.
To override rules:
- Create a .gitlabdirectory at the root of your project, if one doesn't already exist.
- Create a custom ruleset file named sast-ruleset.tomlin the.gitlabdirectory, if one doesn't already exist.
- In one or more ruleset.identifiersubsections, list the rules to override.
- In the ruleset.overridecontext of arulesetsection, provide the keys to override. Any combination of keys can be overridden. Valid keys are:- description
- message
- name
- severity (valid options are: Critical, High, Medium, Low, Unknown, Info)
 
In the following example sast-ruleset.toml file, rules are matched by the type and
value of identifiers and then overridden:
[kics]
  [[kics.ruleset]]
    [kics.ruleset.identifier]
      type = "kics_id"
      value = "8212e2d7-e683-49bc-bf78-d6799075c5a7"
    [kics.ruleset.override]
      description = "OVERRIDDEN description"
      message = "OVERRIDDEN message"
      name = "OVERRIDDEN name"
      severity = "Info"Offline configuration
- Tier: Premium, Ultimate
- Offering: GitLab Self-Managed
An offline environment has limited, restricted, or intermittent access to external resources through the internet. For instances in such an environment, IaC requires some configuration changes. The instructions in this section must be completed together with the instructions detailed in offline environments.
Configure GitLab Runner
By default, a runner tries to pull Docker images from the GitLab container registry even if a local
copy is available. You should use this default setting, to ensure Docker images remain current.
However, if no network connectivity is available, you must change the default GitLab Runner
pull_policy variable.
Configure the GitLab Runner CI/CD variable pull_policy to
if-not-present.
Use local IaC analyzer image
Use a local IaC analyzer image if you want to obtain the image from a local Docker registry instead of the GitLab container registry.
Prerequisites:
- Importing Docker images into a local offline Docker registry depends on your network security policy. Consult your IT staff to find an accepted and approved process to import or temporarily access external resources.
- 
Import the default IaC analyzer image from registry.gitlab.cominto your local Docker container registry:registry.gitlab.com/security-products/kics:5The IaC analyzer's image is periodically updated so you should periodically update the local copy. 
- 
Set the CI/CD variable SECURE_ANALYZERS_PREFIXto the local Docker container registry.include: - template: Jobs/SAST-IaC.gitlab-ci.yml variables: SECURE_ANALYZERS_PREFIX: "localhost:5000/analyzers"
The IaC job should now use the local copy of the analyzer Docker image, without requiring internet access.
Use a specific analyzer version
The GitLab-managed CI/CD template specifies a major version and automatically pulls the latest analyzer release in that major version. In some cases, you may need to use a specific version. For example, you might need to avoid a regression in a later release.
To use a specific analyzer version:
- 
On the left sidebar, select Search or go to and find your project. 
- 
Select Build > Pipeline editor. 
- 
Add the SAST_ANALYZER_IMAGE_TAGCI/CD variable, after the line that includes theSAST-IaC.gitlab-ci.ymltemplate.Only set this variable in a specific job. If you set it at the top level, the version you set is used for other SAST analyzers. Set the tag to: - A major version, like 3. Your pipelines use any minor or patch updates that are released in this major version.
- A minor version, like 3.7. Your pipelines use any patch updates that are released in this minor version.
- A patch version, like 3.7.0. Your pipelines don't receive any updates.
 
- A major version, like 
This example uses a specific minor version of the IaC analyzer:
include:
  - template: Jobs/SAST-IaC.gitlab-ci.yml
kics-iac-sast:
  variables:
    SAST_ANALYZER_IMAGE_TAG: "3.1"Supported distributions
GitLab scanners are provided with a base Alpine image for size and maintainability.
Use FIPS-enabled images
GitLab provides FIPS-enabled Red Hat UBI versions of the scanners' images, in addition to the standard images.
To use the FIPS-enabled images in a pipeline, set the SAST_IMAGE_SUFFIX to -fips or modify the
standard tag plus the -fips extension.
The following example uses the SAST_IMAGE_SUFFIX CI/CD variable.
variables:
  SAST_IMAGE_SUFFIX: '-fips'
include:
  - template: Jobs/SAST-IaC.gitlab-ci.ymlAutomatic vulnerability resolution
Version history
- 
Introduced in GitLab 15.9 with a project-level flag named sec_mark_dropped_findings_as_resolved.
- 
Generally available in GitLab 16.2. Feature flag sec_mark_dropped_findings_as_resolvedremoved.
To help you focus on the vulnerabilities that are still relevant, IaC scanning automatically resolves vulnerabilities when:
- You disable a predefined rule.
- We remove a rule from the default ruleset.
If you re-enable the rule later, the findings are reopened for triage.
The vulnerability management system adds a note when it automatically resolves a vulnerability.
Reports JSON format
The IaC scanner outputs a JSON report file in the existing SAST report format. For more information, see the schema for this report.
The JSON report file can be downloaded from:
- The CI/CD pipelines page.
- The pipelines tab on merge requests by
setting artifacts: pathstogl-sast-report.json.
For more information see Downloading artifacts.
Roll out
After validating the IaC scanning results for one project, you can implement the same approach across additional projects.
- Use enforced scan execution to apply IaC scanning settings across groups.
- Share and reuse a central ruleset by specifying a remote configuration file.
Troubleshooting
When working with IaC scanning, you might encounter the following issues.
IaC scanning findings show as No longer detected unexpectedly
If a previously detected finding unexpectedly shows as No longer detected, it might
be due to an update to the scanner. An update can disable rules that are found to
be ineffective or false positives, and the findings are marked as No longer detected.
Message exec /bin/sh: exec format error in job log
You might get an error in the job log that states exec /bin/sh: exec format error. This issue
occurs when attempting to run the IaC scanning analyzer on an architecture other than AMD64
architecture. For details of IaC scanning prerequisites, see the prerequisites.