From 9b9ceca6ffc6383a5701b976a1145c32cf751471 Mon Sep 17 00:00:00 2001 From: Sean Millichamp Date: Fri, 21 Jun 2024 10:29:06 -0400 Subject: [PATCH] Limit Rugged Control Repo refspec Some Git platforms (e.g. GitLab) store additional references beyond the ones typically found in refs/heads for various tracking/historical reference purposes. For Control Repos which have been around a long time these additional refs can number in the tens of thousands. Refs that numerous seem to cause issues with some versions of Rugged being unable to properly clone and reference the Control Repo. This patch limits Control Repo reference fetching to refs/heads, which is all R10K should need anyways. See https://docs.gitlab.com/ee/development/gitaly.html#gitlab-specific-references for details on some of these additional references. --- CHANGELOG.mkd | 1 + lib/r10k/git/rugged/bare_repository.rb | 4 ++-- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.mkd b/CHANGELOG.mkd index 255980761..422b216e4 100644 --- a/CHANGELOG.mkd +++ b/CHANGELOG.mkd @@ -8,6 +8,7 @@ Unreleased - Require Ruby 3.1 [#1402](https://github.com/puppetlabs/r10k/pull/1402) - Replace deprecated action: actions/setup-ruby->ruby/setup-ruby [#1406](https://github.com/puppetlabs/r10k/pull/1406) - Ensure git repositories are pruned on fetch [#1410](https://github.com/puppetlabs/r10k/pull/1410) +- Limit Rugged Control Repo refspec to only clone refs/heads 4.1.0 ----- diff --git a/lib/r10k/git/rugged/bare_repository.rb b/lib/r10k/git/rugged/bare_repository.rb index cb1a91e8a..02404a42b 100644 --- a/lib/r10k/git/rugged/bare_repository.rb +++ b/lib/r10k/git/rugged/bare_repository.rb @@ -36,7 +36,7 @@ def clone(remote) @_rugged_repo = ::Rugged::Repository.init_at(@path.to_s, true).tap do |repo| config = repo.config config['remote.origin.url'] = remote - config['remote.origin.fetch'] = '+refs/*:refs/*' + config['remote.origin.fetch'] = '+refs/heads/*:refs/heads/*' config['remote.origin.mirror'] = 'true' end @@ -60,7 +60,7 @@ def fetch(remote_name='origin') proxy = R10K::Git.get_proxy_for_remote(remote) options = {:credentials => credentials, :prune => true, :proxy_url => proxy} - refspecs = ['+refs/*:refs/*'] + refspecs = ['+refs/heads/*:refs/heads/*'] results = nil