This product is not supported for your selected Datadog site. ().
Code Security is not available for the site.
Overview
Static Code Analysis is Datadog’s Static Application Security Testing (SAST) capability. SAST is a clear-box software testing technique that analyzes a program’s pre-production code without the need to execute the program.
Static Code Analysis helps you identify security vulnerabilities and maintainability issues early in the software development life cycle (SDLC) to ensure only the highest quality, most secure code makes it to production. It provides organizations with the following benefits:
Applications are less vulnerable to security breaches over time, due to new vulnerabilities being caught through SAST scans before code reaches production.
Takes the guesswork out of adhering to an organization’s code standards, enabling your development team to ship compliant code without significant impacts to developer velocity.
Onboard developers faster because Static Code Analysis enables an organization to maintain a more readable codebase over time.
Set up Static Code Analysis
Static Code Analysis supports scanning for security vulnerabilities and poor coding practices in the following languages and technologies:
During code reviews, Datadog can automatically flag Static Code Analysis violations in pull requests by adding inline review comments on the relevant line(s) of code. When applicable, Datadog also provides suggested fixes that can be applied directly in the pull request.
You can identify code vulnerabilities in real time as you edit a file in your Integrated Development Environment (IDE). See integration-specific documentation for more information:
After setting up Static Code Analysis, a scan is run on each commit to a scanned repository. Violations are summarized per repository on the Code Security Repositories page. Click on a repository to analyze Code Vulnerabilities and Code Quality results from Static Code Analysis.
The Code Vulnerabilities tab contains the violations found by Datadog’s rules in the Security category.
Every row represents a violation. Each violation is associated with the specific commit and branch that is selected in the filters at the top of the page (by default, results are shown for the latest commit on the default branch of the repository you are viewing).
Click on a violation to open a side panel that contains information about the scope of the violation and where it originated.
The content of the violation is shown in tabs:
Details: A description of the violation and the lines of code that caused it. To see the offending code snippet, configure the relevant source code integration for your provider (GitHub4, GitLab5).
Remediation: One or more code fixes that can resolve the violation, with options for remediation.
Event: JSON metadata regarding the violation.
Filter out false positives
For a subset of SAST vulnerabilities, Bits AI can review the context of the finding and assess whether it is more likely to be a true or false positive, along with a short explanation of the reasoning. Select the toggle “Filter out false positives” on the SAST vulnerabilities explorer to quickly narrow down your initial list for triage.
For each finding, you can provide Bits AI with feedback on its assessment.
Supported advisories
False positive filtering is supported for the following CWEs:
If one method succeeds, no further mapping attempts are made. Each mapping method is detailed below.
Identifying the code location in the Software Catalog
The schema version v3 and later of the Software Catalog allows you to add the mapping of your code location for your service. The codeLocations section specifies the location of the repository containing the code and its associated paths.
The paths attribute is a list of globs that should match paths in the repository.
Datadog associates scan results with the team attached to a service. For example, if the file domains/ecommerce/apps/myservice/foo.py
is associated with myservice, then the team myservice will be associated to any violation
detected in this file.
If no services or teams are found, Datadog uses the CODEOWNERS file in your repository. The CODEOWNERS file determines which team owns a file in your Git provider.
Note: You must accurately map your Git provider teams to your Datadog teams for this feature to function properly.
Apply suggested fixes
In Datadog Static Code Analysis, there are two types of suggested fixes:
Deterministic Suggested Fix: For simple violations like linting issues, the rule analyzer automatically provides templated fixes.
AI-suggested Fix: For complex violations, fixes are typically not available beforehand. Instead, you can use AI-suggested fixes, which use OpenAI’s GPT-4 to generate a suggested fix. You can choose between “Text” and “Unified Diff” fixes, which outputs plain text instructions or a code change for resolving the violation, respectively.
Fix a vulnerability or quality issue directly from Datadog
If GitHub is your source code manager, you can push a code change to fix a SAST issue directly from Datadog in two ways.
Open a pull request
If your GitHub app’s Pull Requests permission is set to Read & Write, one-click remediation is enabled for all Static Code Analysis findings with an available suggested fix.
Follow these steps to fix a vulnerability and open a pull request:
View a specific SAST result in Code Security.
Click Fix Violation in the side panel of the result.
Select Open a Pull Request.
Enter a pull request title and commit message.
Click Create PR.
Commit directly to the current branch
You can also fix a vulnerability by committing directly to the branch the result was found on.
To commit a suggested fix:
View a specific SAST result in Code Security.
Click Fix Violation in the side panel of the result.
Click Commit to current branch.
Report false positives
If you believe a specific violation is a false positive, you can flag it as a false positive with a reason for flagging, which sends a report directly to Datadog. Submissions are reviewed on a regular basis to improve ruleset quality over time.