summaryrefslogtreecommitdiff
path: root/lib/gitlabhq
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2011-12-20 09:36:02 -0800
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2011-12-20 09:36:02 -0800
commit6793422e115c9972f966bd43e7cc53ea8f15b103 (patch)
treed6848b518323f1d10369250cc97228d788981880 /lib/gitlabhq
parent6d5c9698726e268a9cd392a5782c055031bb1bb9 (diff)
parent8a1deea58673b66cd99e06877914ef32b15f3944 (diff)
downloadgitlab-ce-6793422e115c9972f966bd43e7cc53ea8f15b103.tar.gz
Merge pull request #221 from mutewinter/fix_key_add_remove_slowness
Fixes Timeout When Adding an SSH key with Many Projects
Diffstat (limited to 'lib/gitlabhq')
-rw-r--r--lib/gitlabhq/gitolite.rb28
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/gitlabhq/gitolite.rb b/lib/gitlabhq/gitolite.rb
index e79afb55577..0822c25e621 100644
--- a/lib/gitlabhq/gitolite.rb
+++ b/lib/gitlabhq/gitolite.rb
@@ -81,5 +81,33 @@ module Gitlabhq
ga_repo.save
end
+
+ # Updates many projects and uses project.path as the repo path
+ # An order of magnitude faster than update_project
+ def update_projects(projects)
+ ga_repo = ::Gitolite::GitoliteAdmin.new(File.join(@local_dir,'gitolite'))
+ conf = ga_repo.config
+
+ projects.each do |project|
+ repo_name = project.path
+
+ repo = if conf.has_repo?(repo_name)
+ conf.get_repo(repo_name)
+ else
+ ::Gitolite::Config::Repo.new(repo_name)
+ end
+
+ name_readers = project.repository_readers
+ name_writers = project.repository_writers
+
+ repo.clean_permissions
+ repo.add_permission("R", "", name_readers) unless name_readers.blank?
+ repo.add_permission("RW+", "", name_writers) unless name_writers.blank?
+ conf.add_repo(repo, true)
+ end
+
+ ga_repo.save
+ end
+
end
end