summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2013-05-27 03:03:30 -0700
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2013-05-27 03:03:30 -0700
commitf44bd269ee427a87cfcf541fa968ab103709588b (patch)
treebd65ffbe4b451ef92308f6299d01a4bfda1a0e75
parentb3bb558501c52ac6cc9d478133eedff8b7384e20 (diff)
parent5f9d78fdff746a0b50313cf415acac809569a186 (diff)
downloadgitlab-ce-f44bd269ee427a87cfcf541fa968ab103709588b.tar.gz
Merge pull request #4072 from ndpgroup/import_w_groups
Include groups in import with import repos rake task
-rw-r--r--doc/raketasks/maintenance.md5
-rw-r--r--lib/tasks/gitlab/import.rake47
2 files changed, 38 insertions, 14 deletions
diff --git a/doc/raketasks/maintenance.md b/doc/raketasks/maintenance.md
index 13f238df3e9..68c1a72b230 100644
--- a/doc/raketasks/maintenance.md
+++ b/doc/raketasks/maintenance.md
@@ -116,6 +116,8 @@ bundle exec rake gitlab:satellites:create RAILS_ENV=production
Notes:
* project owner will be a first admin
+* groups will be created as needed
+* group owner will be the first admin
* existing projects will be skipped
How to use:
@@ -132,5 +134,8 @@ Example output:
```
Processing abcd.git
* Created abcd (abcd.git)
+Processing group/xyz.git
+ * Created Group group (2)
+ * Created xyz (group/xyz.git)
[...]
```
diff --git a/lib/tasks/gitlab/import.rake b/lib/tasks/gitlab/import.rake
index acf6abedd19..c11284e3d78 100644
--- a/lib/tasks/gitlab/import.rake
+++ b/lib/tasks/gitlab/import.rake
@@ -13,42 +13,61 @@ namespace :gitlab do
task repos: :environment do
git_base_path = Gitlab.config.gitlab_shell.repos_path
- repos_to_import = Dir.glob(git_base_path + '/*')
+ repos_to_import = Dir.glob(git_base_path + '/**/*.git')
namespaces = Namespace.pluck(:path)
repos_to_import.each do |repo_path|
- repo_name = File.basename repo_path
+ # strip repo base path
+ repo_path[0..git_base_path.length] = ''
- # Skip if group or user
- next if namespaces.include?(repo_name)
+ path = repo_path.sub(/\.git$/, '')
+ name = File.basename path
+ group_name = File.dirname path
+ group_name = nil if group_name == '.'
- # skip if not git repo
- next unless repo_name =~ /.git$/
+ # Skip if group or user
+ next if namespaces.include?(name)
- next if repo_name == 'gitolite-admin.git'
+ next if name == 'gitolite-admin'
- path = repo_name.sub(/\.git$/, '')
+ puts "Processing #{repo_path}".yellow
project = Project.find_with_namespace(path)
- puts "Processing #{repo_name}".yellow
-
if project
- puts " * #{project.name} (#{repo_name}) exists"
+ puts " * #{project.name} (#{repo_path}) exists"
else
user = User.admins.first
project_params = {
- name: path,
+ name: name,
}
+ # find group namespace
+ if group_name
+ group = Group.find_by_path(group_name)
+ # create group namespace
+ if !group
+ group = Group.new(:name => group_name)
+ group.path = group_name
+ group.owner = user
+ if group.save
+ puts " * Created Group #{group.name} (#{group.id})".green
+ else
+ puts " * Failed trying to create group #{group.name}".red
+ end
+ end
+ # set project group
+ project_params[:namespace_id] = group.id
+ end
+
project = Projects::CreateContext.new(user, project_params).execute
if project.valid?
- puts " * Created #{project.name} (#{repo_name})".green
+ puts " * Created #{project.name} (#{repo_path})".green
else
- puts " * Failed trying to create #{project.name} (#{repo_name})".red
+ puts " * Failed trying to create #{project.name} (#{repo_path})".red
end
end
end