codeql.yml 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. name: "CodeQL Advanced"
  2. on:
  3. push:
  4. tags-ignore:
  5. - "v*"
  6. paths:
  7. - "**.go"
  8. - "go.mod"
  9. - "go.sum"
  10. - "**.js"
  11. - "**.mjs"
  12. - "**.cjs"
  13. - "**.ts"
  14. - "**.vue"
  15. - "frontend/package-lock.json"
  16. pull_request:
  17. paths:
  18. - "**.go"
  19. - "go.mod"
  20. - "go.sum"
  21. - "**.js"
  22. - "**.mjs"
  23. - "**.cjs"
  24. - "**.ts"
  25. - "**.vue"
  26. - "frontend/package-lock.json"
  27. schedule:
  28. - cron: "18 2 * * 2"
  29. jobs:
  30. analyze:
  31. name: Analyze (${{ matrix.language }})
  32. runs-on: ${{ (matrix.language == 'swift' && 'macos-latest') || 'ubuntu-latest' }}
  33. env:
  34. CODEQL_ACTION_FILE_COVERAGE_ON_PRS: true
  35. permissions:
  36. security-events: write
  37. packages: read
  38. actions: read
  39. contents: read
  40. strategy:
  41. fail-fast: false
  42. matrix:
  43. include:
  44. - language: actions
  45. build-mode: none
  46. - language: go
  47. build-mode: autobuild
  48. - language: javascript-typescript
  49. build-mode: none
  50. steps:
  51. - name: Checkout repository
  52. uses: actions/checkout@v6
  53. - name: Setup Node.js
  54. if: matrix.language == 'go'
  55. uses: actions/setup-node@v6
  56. with:
  57. node-version: '22'
  58. cache: 'npm'
  59. cache-dependency-path: frontend/package-lock.json
  60. - name: Build frontend bundle
  61. if: matrix.language == 'go'
  62. run: |
  63. npm ci
  64. npm run build
  65. working-directory: frontend
  66. - name: Initialize CodeQL
  67. uses: github/codeql-action/init@v4
  68. with:
  69. languages: ${{ matrix.language }}
  70. build-mode: ${{ matrix.build-mode }}
  71. - name: Perform CodeQL Analysis
  72. uses: github/codeql-action/analyze@v4
  73. with:
  74. category: "/language:${{matrix.language}}"