2021-09-30 23:02:18 +05:30
# To contribute improvements to CI/CD templates, please follow the Development guide at:
# https://docs.gitlab.com/ee/development/cicd/templates.html
# This specific template is located at:
2021-12-11 22:18:48 +05:30
# https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Security/DAST.latest.gitlab-ci.yml
2021-09-30 23:02:18 +05:30
2021-04-29 21:17:54 +05:30
# To use this template, add the following to your .gitlab-ci.yml file:
#
# include:
# template: DAST.latest.gitlab-ci.yml
#
# You also need to add a `dast` stage to your `stages:` configuration. A sample configuration for DAST:
#
# stages:
# - build
# - test
# - deploy
# - dast
2021-03-08 18:12:59 +05:30
# Read more about this feature here: https://docs.gitlab.com/ee/user/application_security/dast/
2021-09-30 23:02:18 +05:30
# Configure DAST with CI/CD variables (https://docs.gitlab.com/ee/ci/variables/index.html).
2021-09-04 01:27:46 +05:30
# List of available variables: https://docs.gitlab.com/ee/user/application_security/dast/#available-variables
2021-03-08 18:12:59 +05:30
variables :
2022-07-16 23:28:13 +05:30
DAST_VERSION : 3
2021-03-08 18:12:59 +05:30
# Setting this variable will affect all Security templates
# (SAST, Dependency Scanning, ...)
2022-08-27 11:52:29 +05:30
SECURE_ANALYZERS_PREFIX : "$CI_TEMPLATE_REGISTRY_HOST/security-products"
2021-03-08 18:12:59 +05:30
dast :
stage : dast
image :
name : "$SECURE_ANALYZERS_PREFIX/dast:$DAST_VERSION"
variables :
GIT_STRATEGY : none
allow_failure : true
script :
- export DAST_WEBSITE=${DAST_WEBSITE:-$(cat environment_url.txt)}
- if [ -z "$DAST_WEBSITE$DAST_API_SPECIFICATION" ]; then echo "Either DAST_WEBSITE or DAST_API_SPECIFICATION must be set. See https://docs.gitlab.com/ee/user/application_security/dast/#configuration for more details." && exit 1; fi
- /analyze
artifacts :
2022-08-27 11:52:29 +05:30
paths :
- dast_artifacts/*
2021-03-08 18:12:59 +05:30
reports :
dast : gl-dast-report.json
rules :
2023-06-20 00:43:36 +05:30
- if : $DAST_DISABLED == 'true' || $DAST_DISABLED == '1'
2021-03-08 18:12:59 +05:30
when : never
2023-06-20 00:43:36 +05:30
- if : $DAST_DISABLED_FOR_DEFAULT_BRANCH == 'true' &&
2021-03-08 18:12:59 +05:30
$CI_DEFAULT_BRANCH == $CI_COMMIT_REF_NAME
when : never
2023-06-20 00:43:36 +05:30
- if : $DAST_DISABLED_FOR_DEFAULT_BRANCH == '1' &&
$CI_DEFAULT_BRANCH == $CI_COMMIT_REF_NAME
when : never
- if : $CI_DEFAULT_BRANCH != $CI_COMMIT_REF_NAME &&
$REVIEW_DISABLED == 'true'
when : never
2021-03-08 18:12:59 +05:30
- if : $CI_DEFAULT_BRANCH != $CI_COMMIT_REF_NAME &&
2023-06-20 00:43:36 +05:30
$REVIEW_DISABLED == '1'
2021-03-08 18:12:59 +05:30
when : never
2022-11-25 23:54:43 +05:30
# Add the job to merge request pipelines if there's an open merge request.
- if : $CI_PIPELINE_SOURCE == "merge_request_event" &&
$GITLAB_FEATURES =~ /\bdast\b/
# Don't add it to a *branch* pipeline if it's already in a merge request pipeline.
- if : $CI_OPEN_MERGE_REQUESTS
when : never
# Add the job to branch pipelines.
2021-03-08 18:12:59 +05:30
- if : $CI_COMMIT_BRANCH &&
2022-07-23 23:45:48 +05:30
$GITLAB_FEATURES =~ /\bdast\b/
2022-08-27 11:52:29 +05:30
after_script :
# Remove any debug.log files because they might contain secrets.
- rm -f /zap/wrk/**/debug.log
- cp -r /zap/wrk dast_artifacts