commit
9b07ed0690
11 changed files with 135 additions and 112 deletions
|
@ -4,7 +4,7 @@ Creates a backup archive of the database and all repositories. This archive will
|
|||
The filename will be `[TIMESTAMP]_gitlab_backup.tar`. This timestamp can be used to restore an specific backup.
|
||||
|
||||
```
|
||||
bundle exec rake gitlab:app:backup_create
|
||||
bundle exec rake gitlab:backup:create
|
||||
```
|
||||
|
||||
Example output:
|
||||
|
@ -40,7 +40,7 @@ Deleting old backups... [SKIPPING]
|
|||
### Restore a previously created backup
|
||||
|
||||
```
|
||||
bundle exec rake gitlab:app:backup_restore
|
||||
bundle exec rake gitlab:backup:restore
|
||||
```
|
||||
|
||||
Options:
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
### Enable usernames and namespaces for user projects
|
||||
|
||||
This command will enable the namespace feature introduced in v4.0. It will move every project in its namespace folder.
|
||||
This command will enable the namespaces feature introduced in v4.0. It will move every project in its namespace folder.
|
||||
|
||||
Note:
|
||||
|
||||
|
@ -13,7 +13,7 @@ Old path: `git@example.org:myrepo.git`
|
|||
New path: `git@example.org:username/myrepo.git` or `git@example.org:groupname/myrepo.git`
|
||||
|
||||
```
|
||||
bundle exec rake gitlab:activate_namespaces
|
||||
bundle exec rake gitlab:enable_namespaces
|
||||
```
|
||||
|
||||
|
||||
|
@ -22,7 +22,7 @@ bundle exec rake gitlab:activate_namespaces
|
|||
This command will enable the auto merge feature. After this you will be able to **merge a merge request** via GitLab and use the **online editor**.
|
||||
|
||||
```
|
||||
bundle exec rake gitlab:app:enable_automerge
|
||||
bundle exec rake gitlab:enable_automerge
|
||||
```
|
||||
|
||||
Example output:
|
||||
|
|
|
@ -139,6 +139,16 @@ Checking GitLab ... Finished
|
|||
```
|
||||
|
||||
|
||||
### (Re-)Create satellite repos
|
||||
|
||||
This will create satellite repos for all your projects.
|
||||
If necessary, remove the `tmp/repo_satellites` directory and rerun the command below.
|
||||
|
||||
```
|
||||
bundle exec rake gitlab:satellites:create
|
||||
```
|
||||
|
||||
|
||||
### Rebuild each key at gitolite config
|
||||
|
||||
This will send all users ssh public keys to gitolite and grant them access (based on their permission) to their projects.
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
### Add user to as a developer to all projects
|
||||
|
||||
```
|
||||
bundle exec rake add_user_to_project_teams[username@domain.tld]
|
||||
bundle exec rake gitlab:import:user_to_projects[username@domain.tld]
|
||||
```
|
||||
|
||||
|
||||
|
@ -12,5 +12,5 @@ Notes:
|
|||
* admin users are added as masters
|
||||
|
||||
```
|
||||
bundle exec rake add_users_to_project_teams
|
||||
bundle exec rake gitlab:import:all_users_to_all_projects
|
||||
```
|
||||
|
|
|
@ -1,20 +0,0 @@
|
|||
desc "Add all users to all projects (admin users are added as masters)"
|
||||
task :add_users_to_project_teams => :environment do |t, args|
|
||||
user_ids = User.where(:admin => false).pluck(:id)
|
||||
admin_ids = User.where(:admin => true).pluck(:id)
|
||||
|
||||
Project.find_each do |project|
|
||||
puts "Importing #{user_ids.size} users into #{project.code}"
|
||||
UsersProject.bulk_import(project, user_ids, UsersProject::DEVELOPER)
|
||||
puts "Importing #{admin_ids.size} admins into #{project.code}"
|
||||
UsersProject.bulk_import(project, admin_ids, UsersProject::MASTER)
|
||||
end
|
||||
end
|
||||
|
||||
desc "Add user to as a developer to all projects"
|
||||
task :add_user_to_project_teams, [:email] => :environment do |t, args|
|
||||
user = User.find_by_email args.email
|
||||
project_ids = Project.pluck(:id)
|
||||
|
||||
UsersProject.user_bulk_import(user, project_ids, UsersProject::DEVELOPER)
|
||||
end
|
|
@ -1,12 +1,12 @@
|
|||
require 'active_record/fixtures'
|
||||
|
||||
namespace :gitlab do
|
||||
namespace :app do
|
||||
namespace :backup do
|
||||
# Create backup of GitLab system
|
||||
desc "GITLAB | Create a backup of the GitLab system"
|
||||
task :backup_create => :environment do
|
||||
Rake::Task["gitlab:app:db_dump"].invoke
|
||||
Rake::Task["gitlab:app:repo_dump"].invoke
|
||||
task :create => :environment do
|
||||
Rake::Task["gitlab:backup:db:create"].invoke
|
||||
Rake::Task["gitlab:backup:repo:create"].invoke
|
||||
|
||||
Dir.chdir(Gitlab.config.backup.path)
|
||||
|
||||
|
@ -54,7 +54,7 @@ namespace :gitlab do
|
|||
|
||||
# Restore backup of GitLab system
|
||||
desc "GITLAB | Restore a previously created backup"
|
||||
task :backup_restore => :environment do
|
||||
task :restore => :environment do
|
||||
Dir.chdir(Gitlab.config.backup.path)
|
||||
|
||||
# check for existing backups in the backup dir
|
||||
|
@ -62,7 +62,7 @@ namespace :gitlab do
|
|||
puts "no backups found" if file_list.count == 0
|
||||
if file_list.count > 1 && ENV["BACKUP"].nil?
|
||||
puts "Found more than one backup, please specify which one you want to restore:"
|
||||
puts "rake gitlab:app:backup_restore BACKUP=timestamp_of_backup"
|
||||
puts "rake gitlab:backup:restore BACKUP=timestamp_of_backup"
|
||||
exit 1;
|
||||
end
|
||||
|
||||
|
@ -93,8 +93,8 @@ namespace :gitlab do
|
|||
exit 1
|
||||
end
|
||||
|
||||
Rake::Task["gitlab:app:db_restore"].invoke
|
||||
Rake::Task["gitlab:app:repo_restore"].invoke
|
||||
Rake::Task["gitlab:backup:db:restore"].invoke
|
||||
Rake::Task["gitlab:backup:repo:restore"].invoke
|
||||
|
||||
# cleanup: remove tmp files
|
||||
print "Deleting tmp directories..."
|
||||
|
@ -110,82 +110,86 @@ namespace :gitlab do
|
|||
|
||||
################################# REPOSITORIES #################################
|
||||
|
||||
task :repo_dump => :environment do
|
||||
backup_path_repo = File.join(Gitlab.config.backup.path, "repositories")
|
||||
FileUtils.mkdir_p(backup_path_repo) until Dir.exists?(backup_path_repo)
|
||||
puts "Dumping repositories:"
|
||||
project = Project.all.map { |n| [n.path, n.path_to_repo] }
|
||||
project << ["gitolite-admin.git", File.join(File.dirname(project.first.second), "gitolite-admin.git")]
|
||||
project.each do |project|
|
||||
print "- Dumping repository #{project.first}... "
|
||||
if Kernel.system("cd #{project.second} > /dev/null 2>&1 && git bundle create #{backup_path_repo}/#{project.first}.bundle --all > /dev/null 2>&1")
|
||||
puts "[DONE]".green
|
||||
else
|
||||
puts "[FAILED]".red
|
||||
namespace :repo do
|
||||
task :create => :environment do
|
||||
backup_path_repo = File.join(Gitlab.config.backup.path, "repositories")
|
||||
FileUtils.mkdir_p(backup_path_repo) until Dir.exists?(backup_path_repo)
|
||||
puts "Dumping repositories:"
|
||||
project = Project.all.map { |n| [n.path, n.path_to_repo] }
|
||||
project << ["gitolite-admin.git", File.join(File.dirname(project.first.second), "gitolite-admin.git")]
|
||||
project.each do |project|
|
||||
print "- Dumping repository #{project.first}... "
|
||||
if Kernel.system("cd #{project.second} > /dev/null 2>&1 && git bundle create #{backup_path_repo}/#{project.first}.bundle --all > /dev/null 2>&1")
|
||||
puts "[DONE]".green
|
||||
else
|
||||
puts "[FAILED]".red
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
task :repo_restore => :environment do
|
||||
backup_path_repo = File.join(Gitlab.config.backup.path, "repositories")
|
||||
puts "Restoring repositories:"
|
||||
project = Project.all.map { |n| [n.path, n.path_to_repo] }
|
||||
project << ["gitolite-admin.git", File.join(File.dirname(project.first.second), "gitolite-admin.git")]
|
||||
project.each do |project|
|
||||
print "- Restoring repository #{project.first}... "
|
||||
FileUtils.rm_rf(project.second) if File.dirname(project.second) # delete old stuff
|
||||
if Kernel.system("cd #{File.dirname(project.second)} > /dev/null 2>&1 && git clone --bare #{backup_path_repo}/#{project.first}.bundle #{project.first}.git > /dev/null 2>&1")
|
||||
permission_commands = [
|
||||
"sudo chmod -R g+rwX #{Gitlab.config.gitolite.repos_path}",
|
||||
"sudo chown -R #{Gitlab.config.gitolite.ssh_user}:#{Gitlab.config.gitolite.ssh_user} #{Gitlab.config.gitolite.repos_path}"
|
||||
]
|
||||
permission_commands.each { |command| Kernel.system(command) }
|
||||
puts "[DONE]".green
|
||||
else
|
||||
puts "[FAILED]".red
|
||||
task :restore => :environment do
|
||||
backup_path_repo = File.join(Gitlab.config.backup.path, "repositories")
|
||||
puts "Restoring repositories:"
|
||||
project = Project.all.map { |n| [n.path, n.path_to_repo] }
|
||||
project << ["gitolite-admin.git", File.join(File.dirname(project.first.second), "gitolite-admin.git")]
|
||||
project.each do |project|
|
||||
print "- Restoring repository #{project.first}... "
|
||||
FileUtils.rm_rf(project.second) if File.dirname(project.second) # delete old stuff
|
||||
if Kernel.system("cd #{File.dirname(project.second)} > /dev/null 2>&1 && git clone --bare #{backup_path_repo}/#{project.first}.bundle #{project.first}.git > /dev/null 2>&1")
|
||||
permission_commands = [
|
||||
"sudo chmod -R g+rwX #{Gitlab.config.git_base_path}",
|
||||
"sudo chown -R #{Gitlab.config.ssh_user}:#{Gitlab.config.ssh_user} #{Gitlab.config.git_base_path}"
|
||||
]
|
||||
permission_commands.each { |command| Kernel.system(command) }
|
||||
puts "[DONE]".green
|
||||
else
|
||||
puts "[FAILED]".red
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
###################################### DB ######################################
|
||||
|
||||
task :db_dump => :environment do
|
||||
backup_path_db = File.join(Gitlab.config.backup.path, "db")
|
||||
FileUtils.mkdir_p(backup_path_db) unless Dir.exists?(backup_path_db)
|
||||
namespace :db do
|
||||
task :create => :environment do
|
||||
backup_path_db = File.join(Gitlab.config.backup.path, "db")
|
||||
FileUtils.mkdir_p(backup_path_db) unless Dir.exists?(backup_path_db)
|
||||
|
||||
puts "Dumping database tables:"
|
||||
ActiveRecord::Base.connection.tables.each do |tbl|
|
||||
print "- Dumping table #{tbl}... "
|
||||
count = 1
|
||||
File.open(File.join(backup_path_db, tbl + ".yml"), "w+") do |file|
|
||||
ActiveRecord::Base.connection.select_all("SELECT * FROM `#{tbl}`").each do |line|
|
||||
line.delete_if{|k,v| v.blank?}
|
||||
output = {tbl + '_' + count.to_s => line}
|
||||
file << output.to_yaml.gsub(/^---\n/,'') + "\n"
|
||||
count += 1
|
||||
puts "Dumping database tables:"
|
||||
ActiveRecord::Base.connection.tables.each do |tbl|
|
||||
print "- Dumping table #{tbl}... "
|
||||
count = 1
|
||||
File.open(File.join(backup_path_db, tbl + ".yml"), "w+") do |file|
|
||||
ActiveRecord::Base.connection.select_all("SELECT * FROM `#{tbl}`").each do |line|
|
||||
line.delete_if{|k,v| v.blank?}
|
||||
output = {tbl + '_' + count.to_s => line}
|
||||
file << output.to_yaml.gsub(/^---\n/,'') + "\n"
|
||||
count += 1
|
||||
end
|
||||
puts "[DONE]".green
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
task :restore=> :environment do
|
||||
backup_path_db = File.join(Gitlab.config.backup.path, "db")
|
||||
|
||||
puts "Restoring database tables:"
|
||||
Rake::Task["db:reset"].invoke
|
||||
|
||||
Dir.glob(File.join(backup_path_db, "*.yml") ).each do |dir|
|
||||
fixture_file = File.basename(dir, ".*" )
|
||||
print "- Loading fixture #{fixture_file}..."
|
||||
if File.size(dir) > 0
|
||||
ActiveRecord::Fixtures.create_fixtures(backup_path_db, fixture_file)
|
||||
puts "[DONE]".green
|
||||
else
|
||||
puts "[SKIPPING]".yellow
|
||||
end
|
||||
puts "[DONE]".green
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
task :db_restore=> :environment do
|
||||
backup_path_db = File.join(Gitlab.config.backup.path, "db")
|
||||
|
||||
puts "Restoring database tables:"
|
||||
Rake::Task["db:reset"].invoke
|
||||
|
||||
Dir.glob(File.join(backup_path_db, "*.yml") ).each do |dir|
|
||||
fixture_file = File.basename(dir, ".*" )
|
||||
print "- Loading fixture #{fixture_file}..."
|
||||
if File.size(dir) > 0
|
||||
ActiveRecord::Fixtures.create_fixtures(backup_path_db, fixture_file)
|
||||
puts "[DONE]".green
|
||||
else
|
||||
puts "[SKIPPING]".yellow
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
end # namespace end: app
|
||||
end # namespace end: backup
|
||||
end # namespace end: gitlab
|
||||
|
|
24
lib/tasks/gitlab/bulk_add_permission.rake
Normal file
24
lib/tasks/gitlab/bulk_add_permission.rake
Normal file
|
@ -0,0 +1,24 @@
|
|||
namespace :gitlab do
|
||||
namespace :import do
|
||||
desc "GITLAB | Add all users to all projects (admin users are added as masters)"
|
||||
task :all_users_to_all_projects => :environment do |t, args|
|
||||
user_ids = User.where(:admin => false).pluck(:id)
|
||||
admin_ids = User.where(:admin => true).pluck(:id)
|
||||
|
||||
Project.find_each do |project|
|
||||
puts "Importing #{user_ids.size} users into #{project.code}"
|
||||
UsersProject.bulk_import(project, user_ids, UsersProject::DEVELOPER)
|
||||
puts "Importing #{admin_ids.size} admins into #{project.code}"
|
||||
UsersProject.bulk_import(project, admin_ids, UsersProject::MASTER)
|
||||
end
|
||||
end
|
||||
|
||||
desc "GITLAB | Add a specific user to all projects (as a developer)"
|
||||
task :user_to_projects, [:email] => :environment do |t, args|
|
||||
user = User.find_by_email args.email
|
||||
project_ids = Project.pluck(:id)
|
||||
|
||||
UsersProject.user_bulk_import(user, project_ids, UsersProject::DEVELOPER)
|
||||
end
|
||||
end
|
||||
end
|
|
@ -192,7 +192,9 @@ namespace :gitlab do
|
|||
else
|
||||
puts "no".red
|
||||
try_fixing_it(
|
||||
"sudo -u gitlab -H bundle exec rake gitlab:app:enable_automerge"
|
||||
"sudo -u gitlab -H bundle exec rake gitlab:satellites:create",
|
||||
"If necessary, remove the tmp/repo_satellites directory ...",
|
||||
"... and rerun the above command"
|
||||
)
|
||||
for_more_information(
|
||||
"doc/raketasks/maintenance.md "
|
||||
|
|
|
@ -1,17 +1,20 @@
|
|||
namespace :gitlab do
|
||||
namespace :app do
|
||||
desc "GITLAB | Enable auto merge"
|
||||
task :enable_automerge => :environment do
|
||||
Gitlab::Gitolite.new.enable_automerge
|
||||
desc "GITLAB | Enable auto merge"
|
||||
task :enable_automerge => :environment do
|
||||
Gitlab::Gitolite.new.enable_automerge
|
||||
|
||||
Project.find_each do |project|
|
||||
if project.repo_exists? && !project.satellite.exists?
|
||||
puts "Creating satellite for #{project.name}...".green
|
||||
project.satellite.create
|
||||
end
|
||||
Project.find_each do |project|
|
||||
if project.repo_exists? && !project.satellite.exists?
|
||||
puts "Creating satellite for #{project.name}...".green
|
||||
project.satellite.create
|
||||
end
|
||||
|
||||
puts "Done!".green
|
||||
end
|
||||
|
||||
puts "Done!".green
|
||||
end
|
||||
|
||||
namespace :satellites do
|
||||
desc "GITLAB | Create satellite repos"
|
||||
task create: 'gitlab:enable_automerge'
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
namespace :gitlab do
|
||||
desc "GITLAB | Enable usernames and namespaces for user projects"
|
||||
task activate_namespaces: :environment do
|
||||
task enable_namespaces: :environment do
|
||||
print "\nUsernames for users:".yellow
|
||||
|
||||
User.find_each(batch_size: 500) do |user|
|
|
@ -4,7 +4,7 @@ namespace :gitlab do
|
|||
task :setup => [
|
||||
'db:setup',
|
||||
'db:seed_fu',
|
||||
'gitlab:app:enable_automerge'
|
||||
'gitlab:enable_automerge'
|
||||
]
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Reference in a new issue