-
Notifications
You must be signed in to change notification settings - Fork 6
Add claude GitHub actions 1752454958200 #3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
name: Claude Code Review | ||
|
||
on: | ||
pull_request: | ||
types: [opened, synchronize] | ||
# Optional: Only run on specific file changes | ||
# paths: | ||
# - "src/**/*.ts" | ||
# - "src/**/*.tsx" | ||
# - "src/**/*.js" | ||
# - "src/**/*.jsx" | ||
|
||
jobs: | ||
claude-review: | ||
# Optional: Filter by PR author | ||
# if: | | ||
# github.event.pull_request.user.login == 'external-contributor' || | ||
# github.event.pull_request.user.login == 'new-developer' || | ||
# github.event.pull_request.author_association == 'FIRST_TIME_CONTRIBUTOR' | ||
|
||
runs-on: ubuntu-latest | ||
permissions: | ||
contents: read | ||
pull-requests: read | ||
issues: read | ||
id-token: write | ||
|
||
steps: | ||
- name: Checkout repository | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 1 | ||
|
||
- name: Run Claude Code Review | ||
id: claude-review | ||
uses: anthropics/claude-code-action@beta | ||
with: | ||
claude_code_oauth_token: ${{ secrets.CLAUDE_CODE_OAUTH_TOKEN }} | ||
|
||
# Optional: Specify model (defaults to Claude Sonnet 4, uncomment for Claude Opus 4) | ||
# model: "claude-opus-4-20250514" | ||
|
||
# Direct prompt for automated review (no @claude mention needed) | ||
direct_prompt: | | ||
Please review this pull request and provide feedback on: | ||
- Code quality and best practices | ||
- Potential bugs or issues | ||
- Performance considerations | ||
- Security concerns | ||
- Test coverage | ||
Be constructive and helpful in your feedback. | ||
# Optional: Use sticky comments to make Claude reuse the same comment on subsequent pushes to the same PR | ||
# use_sticky_comment: true | ||
|
||
# Optional: Customize review based on file types | ||
# direct_prompt: | | ||
# Review this PR focusing on: | ||
# - For TypeScript files: Type safety and proper interface usage | ||
# - For API endpoints: Security, input validation, and error handling | ||
# - For React components: Performance, accessibility, and best practices | ||
# - For tests: Coverage, edge cases, and test quality | ||
|
||
# Optional: Different prompts for different authors | ||
# direct_prompt: | | ||
# ${{ github.event.pull_request.author_association == 'FIRST_TIME_CONTRIBUTOR' && | ||
# 'Welcome! Please review this PR from a first-time contributor. Be encouraging and provide detailed explanations for any suggestions.' || | ||
# 'Please provide a thorough code review focusing on our coding standards and best practices.' }} | ||
|
||
# Optional: Add specific tools for running tests or linting | ||
# allowed_tools: "Bash(npm run test),Bash(npm run lint),Bash(npm run typecheck)" | ||
|
||
# Optional: Skip review for certain conditions | ||
# if: | | ||
# !contains(github.event.pull_request.title, '[skip-review]') && | ||
# !contains(github.event.pull_request.title, '[WIP]') | ||
|
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
@@ -0,0 +1,64 @@ | ||||||||||||||||||||||||||
name: Claude Code | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
on: | ||||||||||||||||||||||||||
issue_comment: | ||||||||||||||||||||||||||
types: [created] | ||||||||||||||||||||||||||
pull_request_review_comment: | ||||||||||||||||||||||||||
types: [created] | ||||||||||||||||||||||||||
issues: | ||||||||||||||||||||||||||
types: [opened, assigned] | ||||||||||||||||||||||||||
pull_request_review: | ||||||||||||||||||||||||||
types: [submitted] | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
jobs: | ||||||||||||||||||||||||||
claude: | ||||||||||||||||||||||||||
if: | | ||||||||||||||||||||||||||
(github.event_name == 'issue_comment' && contains(github.event.comment.body, '@claude')) || | ||||||||||||||||||||||||||
(github.event_name == 'pull_request_review_comment' && contains(github.event.comment.body, '@claude')) || | ||||||||||||||||||||||||||
(github.event_name == 'pull_request_review' && contains(github.event.review.body, '@claude')) || | ||||||||||||||||||||||||||
(github.event_name == 'issues' && (contains(github.event.issue.body, '@claude') || contains(github.event.issue.title, '@claude'))) | ||||||||||||||||||||||||||
runs-on: ubuntu-latest | ||||||||||||||||||||||||||
Comment on lines
+15
to
+20
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Guard against empty
- (github.event_name == 'pull_request_review' && contains(github.event.review.body, '@claude')) ||
+ (github.event_name == 'pull_request_review' && contains(github.event.review.body || '', '@claude')) || Adding the 📝 Committable suggestion
Suggested change
🤖 Prompt for AI Agents
|
||||||||||||||||||||||||||
permissions: | ||||||||||||||||||||||||||
contents: read | ||||||||||||||||||||||||||
pull-requests: read | ||||||||||||||||||||||||||
issues: read | ||||||||||||||||||||||||||
id-token: write | ||||||||||||||||||||||||||
actions: read # Required for Claude to read CI results on PRs | ||||||||||||||||||||||||||
Comment on lines
+21
to
+26
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 💡 Verification agent 🧩 Analysis chainRe-verify the need for
Unless you have an internal fork that consumes OIDC, drop this permission: - id-token: write #!/bin/bash echo "🔍 Fetching Claude action source (beta)…" echo "🔎 Checking for OIDC/GetIDToken usage in dist/index.js" echo "🔎 Checking for oidcToken references in dist/index.js" 🏁 Script executed: #!/bin/bash
set -euo pipefail
echo "🔍 Fetching anthopics/claude-code-action@beta dist/index.js…"
curl -sSL https://github.com/anthropics/claude-code-action/beta/dist/index.js -o /tmp/claude-dist.js
echo "🔎 Searching for getIDToken references…"
grep -n "getIDToken" /tmp/claude-dist.js || echo "✔️ No getIDToken references found"
echo "🔎 Searching for oidcToken references…"
grep -n "oidcToken" /tmp/claude-dist.js || echo "✔️ No oidcToken references found" Length of output: 677 Drop unnecessary After inspecting • File: - id-token: write 📝 Committable suggestion
Suggested change
🤖 Prompt for AI Agents
|
||||||||||||||||||||||||||
steps: | ||||||||||||||||||||||||||
- name: Checkout repository | ||||||||||||||||||||||||||
uses: actions/checkout@v4 | ||||||||||||||||||||||||||
with: | ||||||||||||||||||||||||||
fetch-depth: 1 | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
- name: Run Claude Code | ||||||||||||||||||||||||||
id: claude | ||||||||||||||||||||||||||
uses: anthropics/claude-code-action@beta | ||||||||||||||||||||||||||
with: | ||||||||||||||||||||||||||
claude_code_oauth_token: ${{ secrets.CLAUDE_CODE_OAUTH_TOKEN }} | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
# This is an optional setting that allows Claude to read CI results on PRs | ||||||||||||||||||||||||||
additional_permissions: | | ||||||||||||||||||||||||||
actions: read | ||||||||||||||||||||||||||
# Optional: Specify model (defaults to Claude Sonnet 4, uncomment for Claude Opus 4) | ||||||||||||||||||||||||||
# model: "claude-opus-4-20250514" | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
# Optional: Customize the trigger phrase (default: @claude) | ||||||||||||||||||||||||||
# trigger_phrase: "/claude" | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
# Optional: Trigger when specific user is assigned to an issue | ||||||||||||||||||||||||||
# assignee_trigger: "claude-bot" | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
# Optional: Allow Claude to run specific commands | ||||||||||||||||||||||||||
# allowed_tools: "Bash(npm install),Bash(npm run build),Bash(npm run test:*),Bash(npm run lint:*)" | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
# Optional: Add custom instructions for Claude to customize its behavior for your project | ||||||||||||||||||||||||||
# custom_instructions: | | ||||||||||||||||||||||||||
# Follow our coding standards | ||||||||||||||||||||||||||
# Ensure all new code has tests | ||||||||||||||||||||||||||
# Use TypeScript for new files | ||||||||||||||||||||||||||
|
||||||||||||||||||||||||||
# Optional: Custom environment variables for Claude | ||||||||||||||||||||||||||
# claude_env: | | ||||||||||||||||||||||||||
# NODE_ENV: test | ||||||||||||||||||||||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
💡 Verification agent
🧩 Analysis chain
Same permission concern – confirm
id-token: write
necessityAs with the other workflow, the action does not currently exchange an OIDC token.
Consider removing the line to follow the principle of least privilege.
- id-token: write
🏁 Script executed:
Length of output: 3105
Remove unnecessary
id-token: write
permissionThe
anthropics/claude-code-action@beta
step uses theCLAUDE_CODE_OAUTH_TOKEN
secret for authentication and does not exchange an OIDC token. You can safely drop theid-token: write
grant to adhere to the principle of least privilege.• File:
.github/workflows/claude-code-review.yml
Lines 20–27
permissions: contents: read pull-requests: read issues: read - id-token: write
📝 Committable suggestion
🧰 Tools
🪛 YAMLlint (1.37.1)
[error] 20-20: trailing spaces
(trailing-spaces)
[error] 27-27: trailing spaces
(trailing-spaces)
🤖 Prompt for AI Agents