From 855c6be910eed81e1eb87576be5eb9368b705f1e Mon Sep 17 00:00:00 2001 From: Olivia Guyot Date: Mon, 24 Apr 2023 11:58:56 +0200 Subject: [PATCH] Add Snyk workflow This will automatically scan pull requests and commits on main, and upload the result to github --- .github/workflows/checks.yml | 2 +- .github/workflows/snyk-security.yml | 48 +++++++++++++++++++++++++++++ .github/workflows/webcomponents.yml | 2 +- 3 files changed, 50 insertions(+), 2 deletions(-) create mode 100644 .github/workflows/snyk-security.yml diff --git a/.github/workflows/checks.yml b/.github/workflows/checks.yml index 40c6b56cbb..1f587947bb 100644 --- a/.github/workflows/checks.yml +++ b/.github/workflows/checks.yml @@ -1,5 +1,5 @@ name: Checks -run-name: 🩺 Quality assurance checks +run-name: 🩺 Quality assurance checks on ${{ github.event_name == 'pull_request' && 'PR' || '🌱' }} ${{ github.event_name == 'pull_request' && github.event.number || github.ref_name }} env: NODE_VERSION: 16.17.0 diff --git a/.github/workflows/snyk-security.yml b/.github/workflows/snyk-security.yml new file mode 100644 index 0000000000..69459dc7b0 --- /dev/null +++ b/.github/workflows/snyk-security.yml @@ -0,0 +1,48 @@ +# This workflow uses actions that are not certified by GitHub. +# They are provided by a third-party and are governed by +# separate terms of service, privacy policy, and support +# documentation. + +# A sample workflow which sets up Snyk to analyze the full Snyk platform (Snyk Open Source, Snyk Code, +# Snyk Container and Snyk Infrastructure as Code) +# The setup installs the Snyk CLI - for more details on the possible commands +# check https://docs.snyk.io/snyk-cli/cli-reference +# The results of Snyk Code are then uploaded to GitHub Security Code Scanning +# +# In order to use the Snyk Action you will need to have a Snyk API token. +# More details in https://github.com/snyk/actions#getting-your-snyk-token +# or you can signup for free at https://snyk.io/login +# +# For more examples, including how to limit scans to only high-severity issues +# and fail PR checks, see https://github.com/snyk/actions/ + +name: Snyk Security +run-name: 🐺 Run Snyk on ${{ github.event_name == 'pull_request' && 'PR' || '🌱' }} ${{ github.event_name == 'pull_request' && github.event.number || github.ref_name }} + +on: + push: + branches: ['main'] + pull_request: + types: [opened, synchronize, ready_for_review] + +permissions: + contents: read + +jobs: + security: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + + - name: Run Snyk to check for vulnerabilities + uses: snyk/actions/node@master + continue-on-error: true # To make sure that SARIF upload gets called + env: + SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }} + with: + args: --sarif-file-output=snyk.sarif + + - name: Upload result to GitHub Code Scanning + uses: github/codeql-action/upload-sarif@v2 + with: + sarif_file: snyk.sarif diff --git a/.github/workflows/webcomponents.yml b/.github/workflows/webcomponents.yml index 551929611d..2dd89f3011 100644 --- a/.github/workflows/webcomponents.yml +++ b/.github/workflows/webcomponents.yml @@ -1,4 +1,4 @@ -name: Artifacts +name: Web Components run-name: 🧩 Build Web Components for ${{ github.event_name == 'issue_comment' && 'PR' || (github.event_name == 'release' && '🏷' || '🌱') }} ${{github.event_name == 'issue_comment' && github.event.issue.number || github.ref_name}} # This workflow runs whenever a commit is pushed on main or a release is published