forked from dbt-checkpoint/dbt-checkpoint
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #10 from pleo-io/centralized-files
chore(ci-deps): Update files based on repository configuration
- Loading branch information
Showing
1 changed file
with
131 additions
and
0 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,131 @@ | ||
# THIS CODE WAS AUTOGENERATED. DO NOT MODIFY THIS FILE DIRECTLY | ||
# THE SOURCE CODE LIVES IN A DIFFERENT REPOSITORY: | ||
# - centralized-templates | ||
# FILE STEWARD: @pleo-io/security | ||
|
||
name: CodeQL Analysis | ||
|
||
on: | ||
push: | ||
branches: | ||
- main | ||
- master | ||
- develop | ||
pull_request: | ||
branches: | ||
- main | ||
- master | ||
- develop | ||
|
||
env: | ||
language_Kotlin: "java" | ||
language_Java: "java" | ||
language_Go: "go" | ||
language_Python: "python" | ||
language_JavaScript: "javascript" | ||
language_TypeScript: "javascript" | ||
WORKING_LANGUAGE: "" | ||
CONFIG_FILE: "" | ||
RUN_ON_DEFAULT_BRANCH: true | ||
GRADLE_SCRIPT_PATH: ./gradlew | ||
|
||
jobs: | ||
preflight: | ||
name: Determine if CodeQL should run | ||
runs-on: ubuntu-latest | ||
outputs: | ||
should_run_analyze: ${{ steps.maybe_skip_analyze.outputs.should_run_analyze }} | ||
working_language: ${{steps.working_language_step.outputs.WORKING_LANGUAGE}} | ||
steps: | ||
- uses: winterjung/split@v2 | ||
id: split | ||
with: | ||
msg: ${{ github.repository }} | ||
separator: "/" | ||
- id: get_default_branch | ||
name: Determine our default branch | ||
uses: octokit/request-action@v2.x | ||
with: | ||
route: GET /repos/{owner}/{repo} | ||
owner: ${{ github.repository_owner }} | ||
repo: ${{ steps.split.outputs._1 }} | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
- id: set_default_branch | ||
name: Set our default branch | ||
run: echo "DEFAULT_BRANCH=${{ fromJson(steps.get_default_branch.outputs.data).default_branch }}" >> "$GITHUB_ENV" | ||
- id: maybe_skip_analyze | ||
name: Check if analyze should run | ||
shell: bash | ||
run: | | ||
if [[ "${{ env.RUN_ON_DEFAULT_BRANCH }}" == "false" && "${{ github.ref }}" == "refs/heads/${{ env.DEFAULT_BRANCH }}" && "${{ github.event_name }}" == "push" ]]; then | ||
echo "Skipping CodeQL analysis on main branch due to configuration" | ||
echo "should_run_analyze=false" >> "$GITHUB_OUTPUT" | ||
else | ||
echo "Running CodeQL analysis" | ||
echo "should_run_analyze=true" >> "$GITHUB_OUTPUT" | ||
fi | ||
- id: working_language_step | ||
name: We check if the repository language is supported by CodeQL | ||
run: echo "WORKING_LANGUAGE=${{env[format('language_{0}', github.event.repository.language)]}}" >> "$GITHUB_OUTPUT" | ||
analyze-code: | ||
name: Analyze code with CodeQL | ||
if: ${{ (needs.preflight.outputs.should_run_analyze == 'true') && (needs.preflight.outputs.working_language != '')}} | ||
needs: preflight | ||
continue-on-error: true | ||
runs-on: codeql-runner | ||
timeout-minutes: 30 | ||
permissions: | ||
actions: read | ||
contents: read | ||
security-events: write | ||
steps: | ||
- name: Checkout repository | ||
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4 | ||
- name: Set Working Language | ||
run: echo "WORKING_LANGUAGE=${{needs.preflight.outputs.working_language}}" >> "$GITHUB_ENV" | ||
# Set up a JDK environment for building, testing and releasing. | ||
- name: Set up JDK 17 | ||
uses: actions/setup-java@v4.0.0 | ||
if: ${{ env.WORKING_LANGUAGE == 'java' }} | ||
with: | ||
java-version: 17 | ||
distribution: temurin | ||
|
||
# Allow caching Gradle executions to further speed up CI/CD steps invoking Gradle. | ||
- name: Setup Gradle | ||
uses: gradle/actions/setup-gradle@v3.1.0 | ||
if: ${{ env.WORKING_LANGUAGE == 'java' }} | ||
with: | ||
gradle-version: wrapper | ||
cache-read-only: true | ||
|
||
# Set up a Node environment for JS/TS/Node client generation. | ||
- name: Set up Node 20 | ||
uses: actions/setup-node@v4 | ||
if: ${{ env.WORKING_LANGUAGE == 'javascript' }} | ||
with: | ||
node-version: 20 | ||
|
||
# Initializes the CodeQL tools for scanning. | ||
- name: Initialize CodeQL | ||
uses: github/codeql-action/init@v3 | ||
with: | ||
languages: ${{ github.event.repository.language }} | ||
ram: 4096 | ||
queries: security-and-quality | ||
tools: latest | ||
config-file: ${{ env.CONFIG_FILE }} | ||
|
||
- name: Gradle Build | ||
run: ${{ env.GRADLE_SCRIPT_PATH }} classes testClasses --stacktrace -Dorg.gradle.jvmargs=-Xmx4g -Dorg.gradle.parallel=true | ||
if: ${{ env.WORKING_LANGUAGE == 'java' }} | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GH_REGISTRY_GRADLE_TOKEN }} | ||
GRADLE_READ_KEY: ${{ secrets.GH_REGISTRY_GRADLE_TOKEN }} | ||
JOB_RUNR_REPO_PASSWORD: ${{ secrets.JOB_RUNR_REPO_PASSWORD }} | ||
|
||
- name: Perform CodeQL Analysis | ||
uses: github/codeql-action/analyze@v3 | ||
with: | ||
ram: 4096 |