summaryrefslogtreecommitdiff
path: root/lib
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 /lib
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
Diffstat (limited to 'lib')
-rw-r--r--lib/tasks/gitlab/import.rake47
1 files changed, 33 insertions, 14 deletions
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