Skip to content

Poutine & Zizmor

Poutine & Zizmor #128

name: "Claude React on comment"
on:
issues:
types: [opened]
issue_comment:
types: [created]
pull_request_review:
types: [submitted]
pull_request_review_comment:
types: [created]
concurrency:
group: claude-pr-reactions-${{ github.event.pull_request.number || github.event.issue.number }}
cancel-in-progress: false
jobs:
check-trigger:
name: "Check trigger phrase"
runs-on: ubuntu-latest
timeout-minutes: 1
outputs:
triggered: ${{ steps.check.outputs.triggered }}
steps:
- name: "Check for trigger phrase"
id: check
env:
COMMENT_BODY: ${{ github.event.comment.body || github.event.review.body || github.event.issue.body || '' }}
run: |
if echo "$COMMENT_BODY" | grep -qF "@phpstan-bot"; then
echo "triggered=true" >> "$GITHUB_OUTPUT"
else
echo "triggered=false" >> "$GITHUB_OUTPUT"
fi
react:
name: "React on comment"
needs: check-trigger
if: needs.check-trigger.outputs.triggered == 'true' && github.event.issue.number != 15
runs-on: ubuntu-latest
timeout-minutes: 60
permissions:
contents: read
issues: write
pull-requests: write
steps:
- name: "Checkout"
uses: actions/checkout@v4
- name: "React to feedback"
uses: anthropics/claude-code-action@v1
with:
claude_code_oauth_token: ${{ secrets.CLAUDE_CODE_OAUTH_TOKEN }}
trigger_phrase: "@phpstan-bot"
claude_args: "--model claude-opus-4-6"
bot_name: "phpstan-bot"
bot_id: "79867460"
additional_permissions: |
actions: read