1010 schedule :
1111 - cron : ' 0 0 * * 0' # Weekly on Sunday
1212 workflow_dispatch :
13+ # Estate guardrail: cancel superseded runs so re-pushes don't pile up
14+ # queued runs across the estate. Safe here because this workflow only
15+ # performs read-only checks/lint/test/scan with no publish or mutation.
16+ concurrency :
17+ group : ${{ github.workflow }}-${{ github.ref }}
18+ cancel-in-progress : true
1319
1420permissions :
1521 contents : read
22+ # security-events: read lets the built-in GITHUB_TOKEN query this
23+ # repo's own Dependabot alerts via the Hypatia DependabotAlerts rule
24+ # (DA001-DA004). Without this, `scan_from_path` gets HTTP 403 and
25+ # the rule silently returns no findings.
26+ # See 007-lang/audits/audit-dependabot-automation-gap-2026-04-17.md.
27+ security-events : read
28+ # pull-requests: write lets the advisory "Comment on PR with findings"
29+ # step post its summary. Without it the built-in GITHUB_TOKEN gets
30+ # "Resource not accessible by integration" and (absent continue-on-error)
31+ # hard-fails the scan — exactly what the gate-decoupling design forbids.
32+ pull-requests : write
1633
1734jobs :
1835 scan :
2138
2239 steps :
2340 - name : Checkout repository
24- uses : actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v4
41+ uses : actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
2542 with :
2643 fetch-depth : 0 # Full history for better pattern analysis
2744
@@ -38,26 +55,27 @@ jobs:
3855 fi
3956
4057 - name : Build Hypatia scanner (if needed)
41- working-directory : /home/runner/hypatia
4258 run : |
43- if [ ! -f hypatia-v2 ]; then
44- echo "Building hypatia-v2 scanner..."
45- cd scanner
59+ cd "$HOME/ hypatia"
60+ if [ ! -f hypatia ]; then
61+ echo "Building hypatia scanner..."
4662 mix deps.get
4763 mix escript.build
48- mv hypatia ../hypatia-v2
4964 fi
5065
5166 - name : Run Hypatia scan
5267 id : scan
5368 env :
54- # Suppress the Dependabot "GITHUB_TOKEN not set" warning.
69+ # Pass the built-in Actions token through to Hypatia so the
70+ # DependabotAlerts rule can query this repo's own alerts.
71+ # For cross-repo scanning (fleet-coordinator scan-supervised),
72+ # a PAT with `security_events` scope is required instead.
5573 GITHUB_TOKEN : ${{ secrets.GITHUB_TOKEN }}
5674 run : |
5775 echo "Scanning repository: ${{ github.repository }}"
5876
59- # Run scanner
60- HYPATIA_FORMAT=json "$HOME/hypatia/hypatia-cli.sh" scan . --exit-zero > hypatia-findings.json
77+ # Run scanner (exits non-zero when findings exist — suppress to continue)
78+ HYPATIA_FORMAT=json "$HOME/hypatia/hypatia-cli.sh" scan . --exit-zero > hypatia-findings.json || true
6179
6280 # Count findings
6381 FINDING_COUNT=$(jq '. | length' hypatia-findings.json 2>/dev/null || echo 0)
@@ -198,6 +216,11 @@ jobs:
198216
199217 - name : Comment on PR with findings
200218 if : github.event_name == 'pull_request' && steps.scan.outputs.findings_count > 0
219+ # Advisory only — posting findings as a PR comment must never gate
220+ # the scan (hypatia#213 gate decoupling). Belt-and-braces alongside
221+ # the pull-requests: write permission above: a token/API hiccup or
222+ # a fork PR (read-only token) skips the comment, not the check.
223+ continue-on-error : true
201224 uses : actions/github-script@ed597411d8f924073f98dfc5c65a23a2325f34cd # v7
202225 with :
203226 script : |
0 commit comments