-
Notifications
You must be signed in to change notification settings - Fork 168
Try and address TOCTOU issues in gemini-cli.yml #187
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
Conversation
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.
📋 Review Summary
This PR does a great job of addressing the TOCTOU vulnerability by checking out the specific commit SHA from the event. The workflow is now more secure and robust.
🔍 General Feedback
- The simplification of the workflow by removing the
get_contextstep is a great improvement. - The addition of a failure message is a nice touch for user experience.
- The changes to the prompt make it much clearer for the model to understand the context.
Great work on this PR!
c815b53 to
0ccfb28
Compare
|
@gemini-cli /review |
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.
📋 Review Summary
This pull request is a great improvement that significantly refactors the workflow to be simpler, more secure, and easier to maintain. The changes to address the TOCTOU issue by checking out a specific commit SHA are excellent.
🔍 General Feedback
- The simplification of the context gathering and the prompt is a major improvement.
- Pinning the checkout action to a specific commit hash is a good security practice.
- The addition of a failure step is a great enhancement for user experience.
I have one question about the removal of the workflow_dispatch trigger. Otherwise, this is a great PR!
This ensures we check out the data from the event (instead of the head).
0ccfb28 to
c8813b7
Compare
## What's Changed * fix(output): separate the stdout and stderr logs by @sethvargo in #186 * fix: correct step numbering in setup_workload_identity.sh by @jasmeetsb in #188 * Try and address TOCTOU issues in gemini-cli.yml by @sethvargo in #187 * chore: bump `actions/checkout` GitHub Actions by @Marukome0743 in #193 * docs: add gitignore recommendations across all workflows by @jerop in #198 * chore: bump `actions/create-github-app-token` from 2.0.6 to 2.1.1 by @Marukome0743 in #200 * bug(output): do not print output by default by @sethvargo in #202 * Add GOOGLE_API_KEY variable by @vivekkairi in #201 * Stream live output if (and only if) debug mode is enabled by @sethvargo in #207 * bug(debug): use `vars` (not `env`) when enabling debug mode by @sethvargo in #211 * feat: Add GEMINI_MODEL support by @vivekkairi in #214 * feat(actions): use the dispatcher pattern to separate concerns by @sethvargo in #212 * bug(ci): set id-token permissions by @sethvargo in #223 * chore: add a debugger by @sethvargo in #226 * Add release notes generation example in awesome list by @jerop in #225 * feat(invoke): update invoke prompt to better separate execution flow by @sethvargo in #227 * chore(ci): refactor scheduled triage workflow by @sethvargo in #232 * Fix triage workflow by @sethvargo in #233 * Auto trigger PR reviews when they are from branches in repo by @jerop in #234 * rename workflow from `gemini-issue-scheduled-triage` to `gemini-scheduled-triage` by @jerop in #238 * feat: rename triage workflows by @jerop in #240 * feat: rename gemini-cli to gemini-invoke by @jerop in #239 * rename PR review workflow to be consistent with the rest by @jerop in #241 * feat(workflows): refactor examples/workflows to use dispatch pattern by @jerop in #242 * feat: pin example workflows to v0 by @jerop in #246 * add google_api_key input in gemini-triage workflows by @jerop in #243 * feat: add best practices guide by @jerop in #245 ## New Contributors * @vivekkairi made their first contribution in #201 **Full Changelog**: v0.1.11...v0.1.12
This ensures we check out the data from the event (instead of the head).
I am struggling to test this in my local branch. I keep getting failed invocations or tool command errors.