| # For most projects, this workflow file will not need changing; you simply need |
| # to commit it to your repository. |
| # |
| # You may wish to alter this file to override the set of languages analyzed, |
| # or to provide custom queries or build logic. |
| # |
| # ******** NOTE ******** |
| # We have attempted to detect the languages in your repository. Please check |
| # the `language` matrix defined below to confirm you have the correct set of |
| # supported CodeQL languages. |
| # |
| name: "CodeQL" |
| |
| on: |
| push: |
| branches: ["main"] |
| pull_request: |
| # The branches below must be a subset of the branches above |
| branches: ["main"] |
| schedule: |
| - cron: "0 0 * * 1" |
| |
| permissions: |
| contents: read |
| |
| jobs: |
| analyze: |
| name: Analyze |
| runs-on: ubuntu-latest |
| permissions: |
| actions: read |
| contents: read |
| security-events: write |
| |
| strategy: |
| fail-fast: false |
| matrix: |
| language: ["cpp", "javascript"] |
| # CodeQL supports [ $supported-codeql-languages ] |
| # Learn more about CodeQL language support at https://aka.ms/codeql-docs/language-support |
| |
| steps: |
| - name: Harden Runner |
| uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1 |
| with: |
| egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs |
| |
| - name: Checkout repository |
| uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 # v4.1.6 |
| |
| # Initializes the CodeQL tools for scanning. |
| - name: Initialize CodeQL |
| uses: github/codeql-action/init@9fdb3e49720b44c48891d036bb502feb25684276 # v3.25.6 |
| with: |
| languages: ${{ matrix.language }} |
| # If you wish to specify custom queries, you can do so here or in a config file. |
| # By default, queries listed here will override any specified in a config file. |
| # Prefix the list here with "+" to use these queries and those in the config file. |
| |
| # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). |
| # If this step fails, then you should remove it and run the build manually (see below) |
| # - name: Autobuild |
| # uses: github/codeql-action/autobuild@7df0ce34898d659f95c0c4a09eaa8d4e32ee64db # v2.2.12 |
| |
| # âšī¸ Command-line programs to run using the OS shell. |
| # đ See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun |
| |
| # If the Autobuild fails above, remove it and uncomment the following three lines. |
| # modify them (or add more) to build your code if your project, please refer to the EXAMPLE below for guidance. |
| |
| - name: Use Node.js v18.x |
| if: matrix.language == 'cpp' |
| uses: actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 # v4.0.2 |
| with: |
| node-version: 18.x |
| |
| - name: Build cpp |
| if: matrix.language == 'cpp' |
| run: | |
| npx node-gyp rebuild -C test |
| |
| - name: Perform CodeQL Analysis |
| uses: github/codeql-action/analyze@9fdb3e49720b44c48891d036bb502feb25684276 # v3.25.6 |
| with: |
| category: "/language:${{matrix.language}}" |