Application Security Review Process

This page details the application security review process for appsec engineers. The purpose of application security reviews are to proactively discover and mitigate vulnerabilities in GitLab developed or deployed applications in order to reduce risk and ultimately help make the company’s mission successful.

An application security review may include any or all of the following stages:

  • Threat modeling
  • In-depth code review
  • Dynamic testing

The results of each stage will inform the review done in the next stage. Ideally, all new features would receive some threat modeling, with the latter two stages being performed based on the risk profile. Features already in development or production can receive an appsec review as well. The testing done is dependent on the circumstances.

What does an application security review mean for the team owning the feature?

A security review conducted by the application security team is non-blocking. This means that the team owning the feature should continue with their development plan, and the expected time investment should be limited to the time necessary to answer questions asynchronously.

Security issues found, if any, will be triaged following the standard process. Application security reviews allow us to discover vulnerabilities that exist in GitLab before they’re discovered by a third party and, if the review is done for new features, we might catch the vulnerabilities even before they make it into a release. It reduces risk, gives us a better understanding of the threat model of the given feature, and allows us to proactively mitigate vulnerabilities.

Roles & Responsibilities

Teams

The team owning the feature should proactively involve the Stable Counterpart in Epics, Issues, and/or MRs which might require a review or their attention. This is primarily the responsibility of the team’s Engineering Manager(s) and the Engineer(s) working on the Issue / MR. Ideal trigger points (in order of preference) are when the Epic/Issue/MR is created/updated, when an engineering proposal is updated, or when an engineer is working on the MR.

Teams should have a bias towards involving the Stable Counterpart, to prevent potential security-sensitive changes from being overlooked.

Stable Counterparts

One of the goals of the stable counterpart is to help identify features that need security review in the area to which they are assigned. Each week Stable Counterparts should review Issue boards and recorded weekly team meetings as part of this.

An Application Security team member is on rotation each week to triage Application Security Reviews.

What Should Be Reviewed?

The application security review queue is a priority queue of application features for security review. The priority can range from priority::1 (Critical) to priority::4 (Low/Backlog).

Some guidelines for which features should be added to the queue are:

  • All new major features
  • Features that have had repeat vulnerabilities
  • Features related to authorization or authentication
  • Features that handle Red or Orange data
  • Features that work with cryptography or other data protection solutions
  • Features which touch on topics mentioned in the secure coding guidelines

The idea is to capture features determined to be higher risk for vulnerabilities. It is quite probable that all features, especially priority::4 issues, will not get a full review, but by capturing those that are at higher risk, we can track additional statistics. For example, how many related vulnerabilities were reported in the bug bounty program. This data can help us to help iterate on priority.

Single Issue / MR Pings

Single Issue/MR pings that can be completed by the engineer on triage rotation do not need a separate issue. This process is primarily for tracking features over time. With that in mind, if a ping will need additional review, an issue should be created.

Adding Features to the Queue / Requesting a Security Review

Separate issues will be used to track the appsec review process, as this process could outlive the original issue/merge request.

The process is the same for appsec engineers adding something to the backlog or for team members requesting a review for a GitLab feature:

  1. Create an issue in the Appsec Reviews issue tracker using the Appsec Review template
    1. Set the title to a unique name for the feature
  2. Follow the description in the template

Assigning Priority

Every issue should have a priority assigned to help team members plan testing. It is up to the application security engineer creating the issue to determine priority based on the data available to them. If you are not sure of the appropriate priority, be conservative and assign a higher priority. It can always be adjusted given feedback from other team members.

Guidelines for Priority (Not comprehensive, please build upon)

Priority Criteria
priority::1 Red data, AuthN/AuthZ, Crypto, Single severity::1, Repeat severity::2 vulns
priority::2 Orange data, Single severity::2 vulns
priority::3 Yellow data
priority::4 Only standard secure practices necessary

Including Threat Modeling in the review

When threat modeling should be done during the review add the threat model::needed label to the original issue or epic and the appsec review issue. That way we can track the adoption of threat modeling throughout GitLab. When the threat modeling step is done the threat model::done label should be added to all involved issues and epics. The process for threat modeling is further defined in its own handbook page.

Quantifying interactions

The engineering team has created multiple labels with the purpose of quantifying interactions done by stable counterparts and tracking the status of these interactions. Stable counterparts should add the right label depending on the status of the interaction following the conditions below:

  • ~sec-planning::in-progress: The issue or MR is under review.
  • ~sec-planning::pending-followup: Stable counterpart expects to follow up on the review.
  • ~sec-planning::complete: Review finished with comments.
  • ~sec-planning::no-action: Review completed and no action required.

Internal Application Security Reviews

For systems built (or significantly modified) by Departments that house customer and other sensitive data, the Security Team should perform applicable application security reviews to ensure the systems are hardened. Security reviews aim to help reduce vulnerabilities and to create a more secure product.

When to request a security review?

This short questionnaire below should help you in quickly deciding if you should engage the application security team:

If the change is doing one or more of the following:

  1. Processing, storing, or transferring any kind of RED or ORANGE data

  2. If your changes have a goal which requires a cryptographic function such as: confidentiality, integrity, authentication, or non-repudiation, it should be reviewed by the application security team.

  3. Deployment of a customer facing application into a new environment

  4. Changes to an existing security control

  5. Modification of any pipeline security checks or scans

  6. A new authentication mechanism

  7. Adding code that touches the authentication model, tokens or sessions

  8. Dealing with user supplied data

  9. Touching cryptography functions, see the GitLab Cryptography Standard for more details

  10. Touching the permission model

  11. Implement new security controls (i.e. new library for a specific protection, HTTP header, …)

  12. Exposing a new API endpoint, or modifying an existing one

  13. Introducing new database queries

  14. Using regex to :

    • validate user supplied data
    • make decisions related to authorisation and authentication
  15. A new feature that can manipulate or display sensitive data (i.e PII), see our Data Classification Standard for more details

  16. Persisting sensitive data such as tokens, crypto keys, credentials, PII in temp storages/files/DB, manipulating or displaying sensitive data (i.e PII), see our Data Classification Standard for more details

You should engage @gitlab-com/gl-security/product-security/appsec.

How to request a security review?

There are two ways to request a security review depending on how significant the changes are. It is divided between individual merge requests and larger scale initiatives.

Individual merge requests or issues

Loop in the application security team by /cc @gitlab-com/gl-security/product-security/appsec in your merge request or issue.

These reviews are intended to be faster, more lightweight, and have a lower barrier of entry.

Larger scale initiatives

To get started, create an issue in the internal application security reviews repository using the Appsec Review template. The complete process can be found at here.

Some use cases of this are for epics, milestones, reviewing for a common security weakness in the entire codebase, or larger features.

Is security approval required to progress?

No, code changes do not require security approval to progress. Non-blocking reviews enables the freedom for our code to keep shipping fast, and it closer aligns with our values of iteration and efficiency. They operate more as guardrails instead of a gate.

What should I provide when requesting a security review?

To help speed up a review, it’s recommended to provide any or all of the following:

  • The background and context of the changes being made.
  • Any documentation or diagrams which help provide a clear understanding its purpose and use cases.
  • The type of data it’s processing or storing.
  • The security requirements for the data.
  • Your security concerns and a worst case scenario that could happen.
  • A test environment.

What does the security process look like?

The current process for larger scale internal application security reviews be found here

My changes have been reviewed by security, so is my project now secure?

Security reviews are not proof or certification that the code changes are secure. They are best effort, and additional vulnerabilities may exist after a review.

It’s important to note here that application security reviews are not a one-and-done, but can be ongoing as the application under review evolves.

Using third party libraries ?

If you are using third party libraries make sure that:

  1. You use the latest stable and available version
  2. Your team has the ability to support and upgrade this library as security patches are published
  3. The maintainer has a security policy

MR Review guidelines

When concluding a review of a Merge Request make sure you document what you covered, and what your conclusions on the reviewed items were.

Having a summary of your steps taken, concerns and coverage helps collaboration with other reviewers.

  1. Coverage: Clearly outline what aspects of the code you have reviewed. This may include:

    • Specific files or modules examined
    • Functionality changes assessed
    • Security implications considered
  2. Steps Taken: Provide a brief overview of your review process, such as:

    • Code reading and analysis
    • Local testing or code execution
    • Use of any automated tools or linters
    • Cross-referencing with related issues or documentation
  3. Concerns and Observations: Document any issues, potential problems, or areas for improvement you’ve identified during the review. This could include:

    • Security vulnerabilities
    • Code quality issues
    • Potential bugs or edge cases
    • Suggestions for optimization
  4. Conclusions: Summarize your overall assessment of the reviewed items, including:

    • Whether the changes meet the intended requirements
    • Any blockers or critical issues that need addressing
    • Recommendations for further actions or improvements

By providing a comprehensive summary of your review process, concerns, and coverage, you facilitate:

  • Improved collaboration with other reviewers
  • Easier follow-up on identified issues
  • A clear record of the review process for future reference
  • More efficient resolution of any concerns or questions raised during the review

A well-documented MR review not only helps in the immediate code review process but also contributes to the overall quality and maintainability of the project in the long run.