Skip to content

Conversation

@ashwin-ant
Copy link
Collaborator

Summary

Add a new ssh_signing_key input that allows passing an SSH signing key for commit signing, as an alternative to the existing use_commit_signing (which uses GitHub API-based commits).

Why

The existing use_commit_signing option uses the GitHub API to create commits, which means it cannot perform complex git operations like rebasing, cherry-picking, or interactive history manipulation. The new ssh_signing_key option enables signed commits while still using the git CLI.

Behavior Matrix

ssh_signing_key use_commit_signing Result
not set false Regular git commands, no signing
not set true GitHub API (MCP server), verified commits
set false Git CLI with SSH signing
set true Git CLI with SSH signing (ssh_signing_key takes precedence)

Usage

- uses: anthropics/claude-code-action@main
  with:
    ssh_signing_key: ${{ secrets.SSH_SIGNING_KEY }}
    bot_id: "81847"
    bot_name: "claude"

See updated docs in docs/security.md for full setup instructions.

Changes

  • Add ssh_signing_key input to action.yml
  • Add setupSshSigning and cleanupSshSigning functions in git-config.ts
  • Update tag and agent modes to use SSH signing when provided
  • Add cleanup step to remove signing key after action completes
  • Add tests for SSH signing functionality
  • Update documentation in security.md and usage.md

Testing

Tested in https://github.com/ashwin-ant/install-test with verified commits working correctly.

Add a new ssh_signing_key input that allows passing an SSH signing key
for commit signing, as an alternative to the existing use_commit_signing
(which uses GitHub API-based commits).

When ssh_signing_key is provided:
- Git is configured to use SSH signing (gpg.format=ssh, commit.gpgsign=true)
- The key is written to ~/.ssh/claude_signing_key with 0600 permissions
- Git CLI commands are used (not MCP file ops)
- The key is cleaned up in a post step for security

Behavior matrix:
| ssh_signing_key | use_commit_signing | Result |
|-----------------|-------------------|--------|
| not set         | false             | Regular git, no signing |
| not set         | true              | GitHub API (MCP), verified commits |
| set             | false             | Git CLI with SSH signing |
| set             | true              | Git CLI with SSH signing (ssh_signing_key takes precedence)
- Update security.md with detailed setup instructions for both signing options
- Explain that ssh_signing_key enables full git CLI operations (rebasing, etc.)
- Add ssh_signing_key to inputs table in usage.md
- Update bot_id/bot_name descriptions to note they're needed for verified commits
@ashwin-ant ashwin-ant requested a review from a team January 2, 2026 00:17

// Create .ssh directory if it doesn't exist
const sshDir = join(homedir(), ".ssh");
await mkdir(sshDir, { recursive: true });
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

SECURITY: Missing .ssh Directory Permissions

The .ssh directory should be created with 0o700 permissions per SSH best practices.

Fix:

await mkdir(sshDir, { recursive: true, mode: 0o700 });

* Configure git to use SSH signing for commits
* This is an alternative to GitHub API-based commit signing (use_commit_signing)
*/
export async function setupSshSigning(sshSigningKey: string): Promise<void> {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Input Validation Missing

The SSH key should be validated before use to catch misconfigurations early and prevent potential injection issues.

Recommendation:

export async function setupSshSigning(sshSigningKey: string): Promise<void> {
  if (!sshSigningKey.trim()) {
    throw new Error("SSH signing key cannot be empty");
  }
  
  if (!sshSigningKey.includes("BEGIN") || !sshSigningKey.includes("PRIVATE KEY")) {
    throw new Error("Invalid SSH private key format");
  }
  
  // ... rest of function
}

console.log(`✓ SSH signing key written to ${SSH_SIGNING_KEY_PATH}`);

// Configure git to use SSH signing
await $`git config gpg.format ssh`;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Performance: Sequential Git Config Commands

These three independent git config operations can be parallelized to save ~20-60ms per run:

await Promise.all([
  $`git config gpg.format ssh`,
  $`git config user.signingkey ${SSH_SIGNING_KEY_PATH}`,
  $`git config commit.gpgsign true`,
]);

login: context.inputs.botName,
id: parseInt(context.inputs.botId),
};
try {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Inconsistent Error Handling

Agent mode swallows git configuration errors with a comment "Continue anyway", while tag mode (lines 109-114) properly throws errors. This inconsistency could lead to confusing failures later.

Recommendation: Either make both modes consistent, or document why agent mode should continue on error. Users deserve clear error messages when git setup fails.

// Configure git authentication for agent mode (same as tag mode)
if (!context.inputs.useCommitSigning) {
// SSH signing takes precedence if provided
const useSshSigning = !!context.inputs.sshSigningKey;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Duplication

This SSH signing detection and git configuration logic (lines 86-118) is duplicated in tag mode (lines 96-128 in src/modes/tag/index.ts). This violates DRY principles and creates maintenance burden - note that error handling has already diverged between the two.

Recommendation: Extract this logic into a shared function like configureGitForMode(context, githubToken, throwOnError) in git-config.ts.

// Create the directory
await mkdir(testSshDir, { recursive: true });

// Write key with proper permissions (same as setupSshSigning does)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Test Coverage Gap: No Integration Testing

This test manually recreates file operations but never actually calls setupSshSigning(). The tests pass but don't validate the actual behavior.

Critical missing scenarios:

  1. No integration test of setupSshSigning() function itself
  2. Git config commands (git config gpg.format ssh, etc.) are never tested
  3. Error handling completely untested (invalid keys, permission failures, git command failures)
  4. Mode integration not tested (tag/agent mode SSH signing paths)

Recommendation: Add integration tests that call the actual functions and verify git configuration.

@claude
Copy link
Contributor

claude bot commented Jan 2, 2026

Comprehensive Code Review Summary

I've completed a thorough review of PR #784 using specialized review agents for code quality, performance, security, test coverage, and documentation. Here are the key findings:

Critical Issues

🔴 SECURITY: SSH Private Key Exposure Risk
The ssh_signing_key is included in the ALL_INPUTS JSON (action.yml:195) which could expose it in logs. This secret should be excluded from ALL_INPUTS and handled separately.

🔴 SECURITY: Race Condition in File Permissions
The SSH key is written then chmod'd in separate operations (git-config.ts:75-76), creating a brief window with insecure permissions. Use writeFile(path, data, { mode: 0o600 }) instead.

🔴 SECURITY: Missing .ssh Directory Permissions
The .ssh directory should be created with mode: 0o700 (git-config.ts:72).

High Priority Issues

⚠️ Code Duplication
SSH signing setup logic is duplicated between tag and agent modes. This has already caused error handling to diverge between the two. Recommend extracting to a shared configureGitForMode() function.

⚠️ Inconsistent Error Handling
Agent mode swallows git config errors (agent/index.ts:99-104) while tag mode throws. This could lead to confusing failures later.

⚠️ Test Coverage Gaps
Tests simulate file operations but never call the actual setupSshSigning() function. Critical missing scenarios:

  • No integration tests of the actual functions
  • Git config commands never tested
  • Error handling completely untested
  • Mode integration not tested

⚠️ Missing Input Validation
SSH key format should be validated before use to catch misconfigurations early and prevent potential issues.

Medium Priority

💡 Performance Optimization
Three independent git config commands (git-config.ts:80-82) can be parallelized with Promise.all() to save ~20-60ms per run.

Positive Aspects

✅ Well-structured code with clean separation of concerns
✅ Proper cleanup with if: always() in action.yml
✅ Correct file permissions (0o600) for SSH keys
✅ Clear precedence logic (SSH signing takes precedence over API signing)
✅ Comprehensive and accurate documentation
✅ Good test coverage for mode detection logic

Documentation

The documentation is accurate and comprehensive. Setup instructions are clear and include all necessary security considerations. No changes required.

Recommendation

Address the three critical security issues before merging. The code duplication and test coverage gaps should also be resolved to ensure maintainability and reliability.

- Write SSH key atomically with mode 0o600 (fixes TOCTOU race condition)
- Create .ssh directory with mode 0o700 (SSH best practices)
- Add input validation for SSH key format
- Remove unused chmod import
- Add tests for validation logic
@ashwin-ant ashwin-ant merged commit 7e4bf87 into main Jan 2, 2026
20 checks passed
@ashwin-ant ashwin-ant deleted the ashwin/add-ssh-signing-key-input branch January 2, 2026 18:37
mergify bot added a commit to robfrank/linklift that referenced this pull request Jan 9, 2026
…updates [skip ci]

Bumps the github-actions group with 4 updates in the / directory: [graalvm/setup-graalvm](https://github.com/graalvm/setup-graalvm), [dorny/test-reporter](https://github.com/dorny/test-reporter), [anthropics/claude-code-action](https://github.com/anthropics/claude-code-action) and [ruby/setup-ruby](https://github.com/ruby/setup-ruby).
Updates `graalvm/setup-graalvm` from 1.4.4 to 1.4.5
Commits

* [`54b4f5a`](graalvm/setup-graalvm@54b4f5a) Bump version to `1.4.5`.
* [`3742797`](graalvm/setup-graalvm@3742797) Update dist files.
* [`24f39d0`](graalvm/setup-graalvm@24f39d0) Bump the npm-updates group with 11 updates
* [`f9a4cbb`](graalvm/setup-graalvm@f9a4cbb) Bump the github-actions-updates group with 3 updates
* [`3f22a48`](graalvm/setup-graalvm@3f22a48) Add 25e1 EA builds.
* [`2e57584`](graalvm/setup-graalvm@2e57584) Replace `macos-13` with `macos-15-intel`.
* See full diff in [compare view](graalvm/setup-graalvm@790e289...54b4f5a)
  
Updates `dorny/test-reporter` from 2.3.0 to 2.5.0
Release notes

*Sourced from [dorny/test-reporter's releases](https://github.com/dorny/test-reporter/releases).*

> v2.5.0
> ------
>
> What's Changed
> --------------
>
> ### Features
>
> * Add Nette Tester JUnit Reporter by [`@​jozefizso`](https://github.com/jozefizso) in [dorny/test-reporter#707](https://redirect.github.com/dorny/test-reporter/pull/707)
>
> ### Project maintanance
>
> * Bump actions/upload-artifact from 5 to 6 by [`@​dependabot`](https://github.com/dependabot)[bot] in [dorny/test-reporter#695](https://redirect.github.com/dorny/test-reporter/pull/695)
>
> **Full Changelog**: <dorny/test-reporter@v2.4.0...v2.5.0>
>
> v2.4.0
> ------
>
> What's Changed
> --------------
>
> * Create tests for sample JUnit files by [`@​jozefizso`](https://github.com/jozefizso) in [dorny/test-reporter#701](https://redirect.github.com/dorny/test-reporter/pull/701)
> * Support for the PHPUnit dialect of JUnit by [`@​mbeccati`](https://github.com/mbeccati) in [dorny/test-reporter#422](https://redirect.github.com/dorny/test-reporter/pull/422)
> * Use `String.substring()` function by [`@​jozefizso`](https://github.com/jozefizso) in [dorny/test-reporter#704](https://redirect.github.com/dorny/test-reporter/pull/704)
>
> New Contributors
> ----------------
>
> * [`@​mbeccati`](https://github.com/mbeccati) made their first contribution in [dorny/test-reporter#422](https://redirect.github.com/dorny/test-reporter/pull/422)
>
> **Full Changelog**: <dorny/test-reporter@v2.3.0...v2.4.0>


Changelog

*Sourced from [dorny/test-reporter's changelog](https://github.com/dorny/test-reporter/blob/main/CHANGELOG.md).*

> Changelog
> =========
>
> 2.5.0
> -----
>
> * Feature: Add Nette Tester support with `tester-junit` reporter [dorny/test-reporter#707](https://redirect.github.com/dorny/test-reporter/pull/707)
> * Maintenance: Bump actions/upload-artifact from 5 to 6 [dorny/test-reporter#695](https://redirect.github.com/dorny/test-reporter/pull/695)
>
> 2.4.0
> -----
>
> * Feature: Add PHPUnit support with JUnit XML dialect parser [dorny/test-reporter#422](https://redirect.github.com/dorny/test-reporter/pull/422)
> * Feature: Add JUnit XML sample files and tests for validation [dorny/test-reporter#701](https://redirect.github.com/dorny/test-reporter/pull/701)
> * Fix: Refactor deprecated `String.substr()` function to use `String.substring()` [dorny/test-reporter#704](https://redirect.github.com/dorny/test-reporter/pull/704)
>
> 2.3.0
> -----
>
> * Feature: Add Python support with `python-xunit` reporter (pytest) [dorny/test-reporter#643](https://redirect.github.com/dorny/test-reporter/pull/643)
> * Feature: Add pytest traceback parsing and `directory-mapping` option [dorny/test-reporter#238](https://redirect.github.com/dorny/test-reporter/pull/238)
> * Performance: Update sax.js to fix large XML file parsing [dorny/test-reporter#681](https://redirect.github.com/dorny/test-reporter/pull/681)
> * Documentation: Complete documentation for all supported reporters [dorny/test-reporter#691](https://redirect.github.com/dorny/test-reporter/pull/691)
> * Security: Bump js-yaml and mocha in /reports/mocha (fixes prototype pollution) [dorny/test-reporter#682](https://redirect.github.com/dorny/test-reporter/pull/682)
>
> 2.2.0
> -----
>
> * Feature: Add collapsed option to control report summary visibility [dorny/test-reporter#664](https://redirect.github.com/dorny/test-reporter/pull/664)
> * Fix badge encoding for values including underscore and hyphens [dorny/test-reporter#672](https://redirect.github.com/dorny/test-reporter/pull/672)
> * Fix missing `report-title` attribute in action definition [dorny/test-reporter#637](https://redirect.github.com/dorny/test-reporter/pull/637)
> * Refactor variable names to fix shadowing issues [dorny/test-reporter#630](https://redirect.github.com/dorny/test-reporter/pull/630)
>
> 2.1.1
> -----
>
> * Fix error when a TestMethod element does not have a className attribute in a trx file [dorny/test-reporter#623](https://redirect.github.com/dorny/test-reporter/pull/623)
> * Add stack trace from trx to summary [dorny/test-reporter#615](https://redirect.github.com/dorny/test-reporter/pull/615)
> * List only failed tests [dorny/test-reporter#606](https://redirect.github.com/dorny/test-reporter/pull/606)
> * Add type definitions to `github-utils.ts` [dorny/test-reporter#604](https://redirect.github.com/dorny/test-reporter/pull/604)
> * Avoid split on undefined [dorny/test-reporter#258](https://redirect.github.com/dorny/test-reporter/pull/258)
> * Return links to summary report [dorny/test-reporter#588](https://redirect.github.com/dorny/test-reporter/pull/588)
> * Add step summary short summary [dorny/test-reporter#589](https://redirect.github.com/dorny/test-reporter/pull/589)
> * Fix for empty TRX TestDefinitions [dorny/test-reporter#582](https://redirect.github.com/dorny/test-reporter/pull/582)
> * Increase step summary limit to 1MiB [dorny/test-reporter#581](https://redirect.github.com/dorny/test-reporter/pull/581)
> * Fix input description for list options [dorny/test-reporter#572](https://redirect.github.com/dorny/test-reporter/pull/572)
>
> 2.1.0
> -----
>
> * Feature: Add summary title [dorny/test-reporter#568](https://redirect.github.com/dorny/test-reporter/pull/568)
> * Feature: Add Golang test parser [dorny/test-reporter#571](https://redirect.github.com/dorny/test-reporter/pull/571)
> * Increase step summary limit to 1MiB [dorny/test-reporter#581](https://redirect.github.com/dorny/test-reporter/pull/581)
> * Fix for empty TRX TestDefinitions [dorny/test-reporter#582](https://redirect.github.com/dorny/test-reporter/pull/582)
> * Fix input description for list options [dorny/test-reporter#572](https://redirect.github.com/dorny/test-reporter/pull/572)
> * Update npm packages [dorny/test-reporter#583](https://redirect.github.com/dorny/test-reporter/pull/583)
>
> 2.0.0
> -----
>
> * Parse JUnit report with detailed message in failure [dorny/test-reporter#559](https://redirect.github.com/dorny/test-reporter/pull/559)
> * Support displaying test results in markdown using GitHub Actions Job Summaries [dorny/test-reporter#383](https://redirect.github.com/dorny/test-reporter/pull/383)
>
> 1.9.1
> -----
>
> * Fix problematic retransmission of authentication token [dorny/test-reporter#438](https://redirect.github.com/dorny/test-reporter/pull/438)

... (truncated)


Commits

* [`b082adf`](dorny/test-reporter@b082adf) test-reporter release v2.5.0
* [`bcafc9f`](dorny/test-reporter@bcafc9f) Merge pull request [#707](https://redirect.github.com/dorny/test-reporter/issues/707) from dorny/feature/700-nette-tester-junit-reporter
* [`b0cbac6`](dorny/test-reporter@b0cbac6) Rebuild the `dist/index.js` file
* [`c92a289`](dorny/test-reporter@c92a289) Remove unnecessary output files
* [`6697ec4`](dorny/test-reporter@6697ec4) Merge pull request [#695](https://redirect.github.com/dorny/test-reporter/issues/695) from dorny/dependabot/github\_actions/actions/upload-a...
* [`6387029`](dorny/test-reporter@6387029) Create `tester-junit` reporter for Nette Tester tool
* [`6896772`](dorny/test-reporter@6896772) Merge pull request [#706](https://redirect.github.com/dorny/test-reporter/issues/706) from dorny/release/v2.4.0
* [`e17be7e`](dorny/test-reporter@e17be7e) test-reporter release v2.4.0
* [`6efb86e`](dorny/test-reporter@6efb86e) Merge pull request [#704](https://redirect.github.com/dorny/test-reporter/issues/704) from dorny/bugfix/703-refactor-deprecated-substr-func...
* [`055bc8c`](dorny/test-reporter@055bc8c) Rebuild the `dist/index.js` file
* Additional commits viewable in [compare view](dorny/test-reporter@fe45e95...b082adf)
  
Updates `anthropics/claude-code-action` from 1.0.27 to 1.0.28
Release notes

*Sourced from [anthropics/claude-code-action's releases](https://github.com/anthropics/claude-code-action/releases).*

> v1.0.28
> -------
>
> What's Changed
> --------------
>
> * fix: update broken link in cloud-providers.md by [`@​ashwin-ant`](https://github.com/ashwin-ant) in [anthropics/claude-code-action#758](https://redirect.github.com/anthropics/claude-code-action/pull/758)
> * chore: remove unused ci yaml file by [`@​kiwamizamurai`](https://github.com/kiwamizamurai) in [anthropics/claude-code-action#763](https://redirect.github.com/anthropics/claude-code-action/pull/763)
> * feat: add instant "Fix this" links to PR code reviews by [`@​aiddun`](https://github.com/aiddun) in [anthropics/claude-code-action#773](https://redirect.github.com/anthropics/claude-code-action/pull/773)
> * feat: add ssh\_signing\_key input for SSH commit signing by [`@​ashwin-ant`](https://github.com/ashwin-ant) in [anthropics/claude-code-action#784](https://redirect.github.com/anthropics/claude-code-action/pull/784)
> * feat: send user request as separate content block for slash command support by [`@​ashwin-ant`](https://github.com/ashwin-ant) in [anthropics/claude-code-action#785](https://redirect.github.com/anthropics/claude-code-action/pull/785)
> * feat: support local plugin marketplace paths by [`@​gor-st`](https://github.com/gor-st) in [anthropics/claude-code-action#761](https://redirect.github.com/anthropics/claude-code-action/pull/761)
> * fix: prevent orphaned installer processes from blocking retries by [`@​ashwin-ant`](https://github.com/ashwin-ant) in [anthropics/claude-code-action#790](https://redirect.github.com/anthropics/claude-code-action/pull/790)
> * fix: set CLAUDE\_CODE\_ENTRYPOINT for SDK path to match CLI path by [`@​ashwin-ant`](https://github.com/ashwin-ant) in [anthropics/claude-code-action#791](https://redirect.github.com/anthropics/claude-code-action/pull/791)
>
> New Contributors
> ----------------
>
> * [`@​kiwamizamurai`](https://github.com/kiwamizamurai) made their first contribution in [anthropics/claude-code-action#763](https://redirect.github.com/anthropics/claude-code-action/pull/763)
> * [`@​aiddun`](https://github.com/aiddun) made their first contribution in [anthropics/claude-code-action#773](https://redirect.github.com/anthropics/claude-code-action/pull/773)
>
> **Full Changelog**: <anthropics/claude-code-action@v1...v1.0.28>


Commits

* [`c9ec2b0`](anthropics/claude-code-action@c9ec2b0) fix: set CLAUDE\_CODE\_ENTRYPOINT for SDK path to match CLI path ([#791](https://redirect.github.com/anthropics/claude-code-action/issues/791))
* [`63ea7e3`](anthropics/claude-code-action@63ea7e3) fix: prevent orphaned installer processes from blocking retries ([#790](https://redirect.github.com/anthropics/claude-code-action/issues/790))
* [`653f9cd`](anthropics/claude-code-action@653f9cd) feat: support local plugin marketplace paths ([#761](https://redirect.github.com/anthropics/claude-code-action/issues/761))
* [`b17b541`](anthropics/claude-code-action@b17b541) feat: send user request as separate content block for slash command support (...
* [`7e4bf87`](anthropics/claude-code-action@7e4bf87) feat: add ssh\_signing\_key input for SSH commit signing ([#784](https://redirect.github.com/anthropics/claude-code-action/issues/784))
* [`154d0de`](anthropics/claude-code-action@154d0de) feat: add instant "Fix this" links to PR code reviews ([#773](https://redirect.github.com/anthropics/claude-code-action/issues/773))
* [`3ba9f7c`](anthropics/claude-code-action@3ba9f7c) chore: bump Claude Code to 2.0.76 and Agent SDK to 0.1.76
* [`e5b0741`](anthropics/claude-code-action@e5b0741) chore: remove unused ci yaml file ([#763](https://redirect.github.com/anthropics/claude-code-action/issues/763))
* [`b89827f`](anthropics/claude-code-action@b89827f) fix: update broken link in cloud-providers.md ([#758](https://redirect.github.com/anthropics/claude-code-action/issues/758))
* See full diff in [compare view](anthropics/claude-code-action@7145c3e...c9ec2b0)
  
Updates `ruby/setup-ruby` from 1.275.0 to 1.280.0
Release notes

*Sourced from [ruby/setup-ruby's releases](https://github.com/ruby/setup-ruby/releases).*

> v1.280.0
> --------
>
> What's Changed
> --------------
>
> * Test ruby 4.0 on windows by [`@​ntkme`](https://github.com/ntkme) in [ruby/setup-ruby#853](https://redirect.github.com/ruby/setup-ruby/pull/853)
> * Add token input for downloading release assets by [`@​TingluoHuang`](https://github.com/TingluoHuang) in [ruby/setup-ruby#851](https://redirect.github.com/ruby/setup-ruby/pull/851)
>
> New Contributors
> ----------------
>
> * [`@​TingluoHuang`](https://github.com/TingluoHuang) made their first contribution in [ruby/setup-ruby#851](https://redirect.github.com/ruby/setup-ruby/pull/851)
>
> **Full Changelog**: <ruby/setup-ruby@v1.279.0...v1.280.0>
>
> v1.279.0
> --------
>
> **Full Changelog**: <ruby/setup-ruby@v1.278.0...v1.279.0>
>
> v1.278.0
> --------
>
> What's Changed
> --------------
>
> * Set BUNDLER\_VERSION whenever we know which version to use by [`@​eregon`](https://github.com/eregon) in [ruby/setup-ruby#849](https://redirect.github.com/ruby/setup-ruby/pull/849)
>
> **Full Changelog**: <ruby/setup-ruby@v1.277.0...v1.278.0>
>
> v1.277.0
> --------
>
> What's Changed
> --------------
>
> * Update CRuby releases on Windows by [`@​ruby-builder-bot`](https://github.com/ruby-builder-bot) in [ruby/setup-ruby#847](https://redirect.github.com/ruby/setup-ruby/pull/847)
>
> **Full Changelog**: <ruby/setup-ruby@v1.276.0...v1.277.0>
>
> v1.276.0
> --------
>
> What's Changed
> --------------
>
> * Add ruby-4.0.0 by [`@​ruby-builder-bot`](https://github.com/ruby-builder-bot) in [ruby/setup-ruby#844](https://redirect.github.com/ruby/setup-ruby/pull/844)
>
> **Full Changelog**: <ruby/setup-ruby@v1.275.0...v1.276.0>


Commits

* [`d5f787c`](ruby/setup-ruby@d5f787c) Define a helper to download to avoid duplication
* [`1010da4`](ruby/setup-ruby@1010da4) Tweaks
* [`7f50f6e`](ruby/setup-ruby@7f50f6e) Add token input and pass it to release assets download.
* [`be19563`](ruby/setup-ruby@be19563) Test ruby 4.0 on windows
* [`b90be12`](ruby/setup-ruby@b90be12) Rename 3.4-asan to asan-release
* [`4c24fa5`](ruby/setup-ruby@4c24fa5) Set BUNDLER\_VERSION whenever we know which version to use
* [`8a836ef`](ruby/setup-ruby@8a836ef) Update CRuby releases on Windows
* [`ae195bb`](ruby/setup-ruby@ae195bb) Add ruby-4.0.0
* See full diff in [compare view](ruby/setup-ruby@d354de1...d5f787c)
  
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`.
[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)
---
Dependabot commands and options
  
You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
- `@dependabot show  ignore conditions` will show all of the ignore conditions of the specified dependency
- `@dependabot ignore  major version` will close this group update PR and stop Dependabot creating any more for the specific dependency's major version (unless you unignore this specific dependency's major version or upgrade to it yourself)
- `@dependabot ignore  minor version` will close this group update PR and stop Dependabot creating any more for the specific dependency's minor version (unless you unignore this specific dependency's minor version or upgrade to it yourself)
- `@dependabot ignore ` will close this group update PR and stop Dependabot creating any more for the specific dependency (unless you unignore this specific dependency or upgrade to it yourself)
- `@dependabot unignore ` will remove all of the ignore conditions of the specified dependency
- `@dependabot unignore  ` will remove the ignore condition of the specified dependency and ignore conditions
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants