codeql.yml 1.8 KB

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