New Adapter: Alkimi #279
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Adapter semgrep checks | |
on: | |
pull_request_target: | |
paths: ["adapters/*/*.go"] | |
permissions: | |
pull-requests: write | |
jobs: | |
semgrep-check: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
ref: ${{github.event.pull_request.head.ref}} | |
repository: ${{github.event.pull_request.head.repo.full_name}} | |
- name: Calculate diff | |
id: calculate_diff | |
uses: actions/github-script@v6 | |
with: | |
result-encoding: string | |
script: | | |
const utils = require('./.github/workflows/helpers/pull-request-utils.js') | |
// consider only non-test Go files that are part of the adapter code | |
function fileNameFilter(filename) { | |
return filename.startsWith("adapters/") && filename.split("/").length > 2 && filename.endsWith(".go") && !filename.endsWith("_test.go") | |
} | |
const helper = utils.diffHelper({github, context, fileNameFilter, event: "${{github.event.action}}", testName: "${{github.job}}"}) | |
return await helper.buildDiff() | |
- name: Should run semgrep | |
id: should_run_semgrep | |
run: | | |
hasChanges=$(echo '${{ steps.calculate_diff.outputs.result }}' | jq .pullRequest.hasChanges) | |
echo "hasChanges=${hasChanges}" >> $GITHUB_OUTPUT | |
- name: Install semgrep | |
if: contains(steps.should_run_semgrep.outputs.hasChanges, 'true') | |
run: | | |
pip3 install semgrep==1.22.0 | |
semgrep --version | |
- name: Run semgrep tests | |
id: run_semgrep_tests | |
if: contains(steps.should_run_semgrep.outputs.hasChanges, 'true') | |
run: | | |
unqouted_string=$(echo '${{ steps.calculate_diff.outputs.result }}' | jq .pullRequest.files | tr -d '"') | |
outputs=$(semgrep --gitlab-sast --config=.semgrep/adapter $unqouted_string | jq '[.vulnerabilities[] | {"file": .location.file, "severity": .severity, "start": .location.start_line, "end": .location.end_line, "message": (.message | gsub("\\n"; "\n"))}]' | jq -c | jq -R) | |
echo "semgrep_result=${outputs}" >> "$GITHUB_OUTPUT" | |
- name: Add pull request comment | |
id: add_pull_request_comment | |
if: contains(steps.should_run_semgrep.outputs.hasChanges, 'true') | |
uses: actions/[email protected] | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
result-encoding: string | |
script: | | |
const utils = require('./.github/workflows/helpers/pull-request-utils.js') | |
const helper = utils.semgrepHelper({ | |
github, context, event: "${{github.event.action}}", | |
semgrepResult: JSON.parse(${{ steps.run_semgrep_tests.outputs.semgrep_result }}), | |
diff: ${{ steps.calculate_diff.outputs.result }}, headSha: "${{github.event.pull_request.head.sha}}" | |
}) | |
const { previousScan, currentScan } = await helper.addReviewComments() | |
return previousScan.unAddressedComments + currentScan.newComments | |
- name: Adapter semgrep checks result | |
if: contains(steps.should_run_semgrep.outputs.hasChanges, 'true') | |
run: | | |
if [ "${{steps.add_pull_request_comment.outputs.result}}" -ne "0" ]; then | |
echo 'Semgrep has found "${{steps.add_pull_request_comment.outputs.result}}" errors' | |
exit 1 | |
else | |
echo 'Semgrep did not find any errors in the pull request changes' | |
fi |