Skip to content

GitLab Advanced SAST

DETAILS: Tier: Ultimate Offering: GitLab.com, GitLab Self-Managed, GitLab Dedicated

  • Introduced in GitLab 17.1 as an experiment for Python.
  • Support for Go and Java added in 17.2.
  • Changed from experiment to beta in GitLab 17.2.
  • Support for JavaScript, TypeScript, and C# added in 17.3.
  • Generally available in GitLab 17.3.
  • Support for Java Server Pages (JSP) added in GitLab 17.4.

GitLab Advanced SAST is a Static Application Security Testing (SAST) analyzer designed to discover vulnerabilities by performing cross-function and cross-file taint analysis.

GitLab Advanced SAST is an opt-in feature. When it is enabled, the GitLab Advanced SAST analyzer scans all the files of the supported languages, using the GitLab Advanced SAST predefined ruleset. The Semgrep analyzer will not scan these files.

All vulnerabilities identified by the GitLab Advanced SAST analyzer will be reported, including vulnerabilities previously reported by the Semgrep-based analyzer. An automated transition automatically de-duplicates findings when Advanced SAST locates the same type of vulnerability in the same location as the Semgrep-based analyzer.

For an overview of GitLab Advanced SAST and how it works, see GitLab Advanced SAST: Accelerating Vulnerability Resolution.

For a product tour, see the GitLab Advanced SAST product tour.

When vulnerabilities are reported

GitLab Advanced SAST uses cross-file, cross-function scanning with taint analysis to trace the flow of user input into the program. By following the paths user inputs take, the analyzer identifies potential points where untrusted data can influence the execution of your application in unsafe ways, ensuring that injection vulnerabilities, such as SQL injection and cross-site scripting (XSS), are detected even when they span multiple functions and files.

To minimize noise, Advanced SAST only reports taint-based vulnerabilities when there is a verifiable flow that brings untrusted user input source to a sensitive sink. Other products may report vulnerabilities with less validation.

Advanced SAST is tuned to emphasize input that crosses trust boundaries, like values that are sourced from HTTP requests. The set of untrusted input sources does not include command-line arguments, environment variables, or other inputs that are typically provided by the user operating the program.

For details of which types of vulnerabilities Advanced SAST detects, see Advanced SAST CWE coverage.

Supported languages

GitLab Advanced SAST supports the following languages with cross-function and cross-file taint analysis:

  • C#
  • Go
  • Java, including Java Server Pages (JSP)
  • JavaScript, TypeScript
  • Python
  • Ruby

Configuration

Enable the Advanced SAST analyzer to discover vulnerabilities in your application by performing cross-function and cross-file taint analysis. You can then adjust its behavior by using CI/CD variables.

Requirements

Like other GitLab SAST analyzers, the Advanced SAST analyzer requires a runner and a CI/CD pipeline; see SAST requirements for details.

On GitLab self-managed, you must also use a GitLab version that supports Advanced SAST:

  • You should use GitLab 17.4 or later if possible. GitLab 17.4 includes a new code-flow view, vulnerability deduplication, and further updates to the SAST CI/CD template.
  • The SAST CI/CD templates were updated to include Advanced SAST in the following releases:
    • The stable template includes Advanced SAST in GitLab 17.3 or later.
    • The latest template includes Advanced SAST in GitLab 17.2 or later. Note that you should not mix latest and stable templates in a single project.
  • At a minimum, GitLab Advanced SAST requires version 17.1 or later.

Enable Advanced SAST scanning

Advanced SAST is included in the standard GitLab SAST CI/CD template, but isn't yet enabled by default. To enable it, set the CI/CD variable GITLAB_ADVANCED_SAST_ENABLED to true. You can set this variable in different ways depending on how you manage your CI/CD configuration.

Edit the CI/CD pipeline definition manually

If you've already enabled GitLab SAST scanning in your project, add a new CI/CD variable to enable GitLab SAST.

This minimal YAML file includes the stable SAST template and enables Advanced SAST:

include:
  - template: Jobs/SAST.gitlab-ci.yml

variables:
  GITLAB_ADVANCED_SAST_ENABLED: 'true'

Enforce it in a Scan Execution Policy

To enable Advanced SAST in a Scan Execution Policy, update your policy's scan action to set the CI/CD variable GITLAB_ADVANCED_SAST_ENABLED to true. You can set this variable by:

By using the pipeline editor

To enable Advanced SAST by using the pipeline editor:

  1. In your project, select Build > Pipeline editor.

  2. If no .gitlab-ci.yml file exists, select Configure pipeline, then delete the example content.

  3. Update the CI/CD configuration to:

    • Include one of the GitLab-managed SAST CI/CD templates if it is not already included.
      • In GitLab 17.3 or later, you should use the stable template, Jobs/SAST.gitlab-ci.yml.
      • In GitLab 17.2, Advanced SAST is only available in the latest template, Jobs/SAST.latest.gitlab-ci.yml. Note that you should not mix latest and stable templates in a single project.
      • In GitLab 17.1, you must manually copy the contents of the Advanced SAST job into your CI/CD pipeline definition.
    • Set the CI/CD variable GITLAB_ADVANCED_SAST_ENABLED to true.

    See the minimal YAML example above.

  4. Select the Validate tab, then select Validate pipeline.

    The message Simulation completed successfully confirms the file is valid.

  5. Select the Edit tab.

  6. Complete the fields. Do not use the default branch for the Branch field.

  7. Select the Start a new merge request with these changes checkbox, then select Commit changes.

  8. Complete the fields according to your standard workflow, then select Create merge request.

  9. Review and edit the merge request according to your standard workflow, then select Merge.

Pipelines now include an Advanced SAST job.

Vulnerability code flow

FLAG: The availability of this feature is controlled by feature flags. For more information, see Code flow feature availability.

For specific types of vulnerabilities, GitLab Advanced SAST provides code flow information. A vulnerability's code flow is the path the data takes from the user input (source) to the vulnerable line of code (sink), through all assignments, manipulation, and sanitization. This information helps you understand and evaluate the vulnerability's context, impact, and risk. Code flow information is available for vulnerabilities that are detected by tracing input from a source to a sink, including:

  • SQL injection
  • Command injection
  • Cross-site scripting (XSS)
  • Path traversal

The code flow information is shown the Code flow tab and includes:

  • The steps from source to sink.
  • The relevant files, including code snippets.

A code flow of a Python application across two files

Code flow feature availability

The code flow view is integrated into each view where vulnerability details are shown. On GitLab self-managed, you can activate the view by enabling the required feature flags starting in the minimum version shown.

Location Availability on GitLab.com Availability on GitLab self-managed Feature flags required
Vulnerability Report Enabled by default in GitLab 17.3 Enabled by default in GitLab 17.6. Available in GitLab 17.3 or later.
Merge request widget Enabled by default in GitLab 17.6 Enabled by default in GitLab 17.6. Available in GitLab 17.5 or later.
Pipeline security report Enabled by default in GitLab 17.6 Enabled by default in GitLab 17.6. Available in GitLab 17.5 or later.
Merge request changes view Enabled by default in GitLab 17.7 Enabled by default in GitLab 17.7. Available in GitLab 17.7 or later. mr_vulnerability_code_flow

Troubleshooting

If you encounter issues while using GitLab Advanced SAST, refer to the troubleshooting guide.

Customize Advanced SAST

You can disable Advanced SAST rules or edit their metadata, just as you can other analyzers. For details, see Customize rulesets.

Feedback

Feel free to add your feedback in the dedicated issue 466322.