mirror of
https://github.com/immich-app/immich.git
synced 2025-05-24 01:12:58 -04:00
* fix: set persist-credentials explicitly for checkout https://woodruffw.github.io/zizmor/audits/#artipacked * fix: minimize permissions scope for workflows https://woodruffw.github.io/zizmor/audits/#excessive-permissions * fix: remove potential template injections https://woodruffw.github.io/zizmor/audits/#template-injection * fix: only pass needed secrets in workflow_call https://woodruffw.github.io/zizmor/audits/#secrets-inherit * fix: push perm for single-arch build jobs I hadn't realised these push to the registry too :x * chore: fix formatting * fix: $ * fix: retag job quoting * feat: static analysis job for gha workflows * chore: fix formatting * fix: clear last zizmor checks * fix: broken merge --------- Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
62 lines
1.8 KiB
YAML
62 lines
1.8 KiB
YAML
name: Weblate checks
|
|
|
|
on:
|
|
pull_request:
|
|
branches: [main]
|
|
|
|
permissions: {}
|
|
|
|
jobs:
|
|
pre-job:
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
contents: read
|
|
outputs:
|
|
should_run: ${{ steps.found_paths.outputs.i18n == 'true' && github.head_ref != 'chore/translations'}}
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4
|
|
with:
|
|
persist-credentials: false
|
|
- id: found_paths
|
|
uses: dorny/paths-filter@de90cc6fb38fc0963ad72b210f1f284cd68cea36 # v3
|
|
with:
|
|
filters: |
|
|
i18n:
|
|
- 'i18n/!(en)**\.json'
|
|
|
|
enforce-lock:
|
|
name: Check Weblate Lock
|
|
needs: [pre-job]
|
|
runs-on: ubuntu-latest
|
|
permissions: {}
|
|
if: ${{ needs.pre-job.outputs.should_run == 'true' }}
|
|
steps:
|
|
- name: Check weblate lock
|
|
run: |
|
|
if [[ "false" = $(curl https://hosted.weblate.org/api/components/immich/immich/lock/ | jq .locked) ]]; then
|
|
exit 1
|
|
fi
|
|
- name: Find Pull Request
|
|
uses: juliangruber/find-pull-request-action@48b6133aa6c826f267ebd33aa2d29470f9d9e7d0 # v1
|
|
id: find-pr
|
|
with:
|
|
branch: chore/translations
|
|
- name: Fail if existing weblate PR
|
|
if: ${{ steps.find-pr.outputs.number }}
|
|
run: exit 1
|
|
success-check-lock:
|
|
name: Weblate Lock Check Success
|
|
needs: [enforce-lock]
|
|
runs-on: ubuntu-latest
|
|
permissions: {}
|
|
if: always()
|
|
steps:
|
|
- name: Any jobs failed?
|
|
if: ${{ contains(needs.*.result, 'failure') }}
|
|
run: exit 1
|
|
- name: All jobs passed or skipped
|
|
if: ${{ !(contains(needs.*.result, 'failure')) }}
|
|
# zizmor: ignore[template-injection]
|
|
run: echo "All jobs passed or skipped" && echo "${{ toJSON(needs.*.result) }}"
|