debian-mirror-gitlab/lib/tasks/gitlab/shell.rake

148 lines
4.7 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
namespace :gitlab do
namespace :shell do
2015-09-11 14:41:01 +05:30
desc "GitLab | Install or upgrade gitlab-shell"
2014-09-02 18:07:02 +05:30
task :install, [:tag, :repo] => :environment do |t, args|
warn_user_is_not_gitlab
2015-04-26 12:48:37 +05:30
default_version = Gitlab::Shell.version_required
2016-09-13 17:45:13 +05:30
default_version_tag = 'v' + default_version
args.with_defaults(tag: default_version_tag, repo: "https://gitlab.com/gitlab-org/gitlab-shell.git")
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
user = Gitlab.config.gitlab.user
home_dir = Rails.env.test? ? Rails.root.join('tmp/tests') : Gitlab.config.gitlab.user_home
gitlab_url = Gitlab.config.gitlab.url
2014-09-02 18:07:02 +05:30
# gitlab-shell requires a / at the end of the url
2015-04-26 12:48:37 +05:30
gitlab_url += '/' unless gitlab_url.end_with?('/')
2014-09-02 18:07:02 +05:30
target_dir = Gitlab.config.gitlab_shell.path
# Clone if needed
2016-09-13 17:45:13 +05:30
if File.directory?(target_dir)
Dir.chdir(target_dir) do
system(*%W(Gitlab.config.git.bin_path} fetch --tags --quiet))
system(*%W(Gitlab.config.git.bin_path} checkout --quiet #{default_version_tag}))
end
else
2015-11-26 14:37:03 +05:30
system(*%W(#{Gitlab.config.git.bin_path} clone -- #{args.repo} #{target_dir}))
2014-09-02 18:07:02 +05:30
end
# Make sure we're on the right tag
Dir.chdir(target_dir) do
2015-04-26 12:48:37 +05:30
# First try to checkout without fetching
# to avoid stalling tests if the Internet is down.
reseted = reset_to_commit(args)
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
unless reseted
2015-11-26 14:37:03 +05:30
system(*%W(#{Gitlab.config.git.bin_path} fetch origin))
2015-04-26 12:48:37 +05:30
reset_to_commit(args)
end
2014-09-02 18:07:02 +05:30
config = {
user: user,
gitlab_url: gitlab_url,
http_settings: {self_signed_cert: false}.stringify_keys,
auth_file: File.join(home_dir, ".ssh", "authorized_keys"),
redis: {
bin: %x{which redis-cli}.chomp,
namespace: "resque:gitlab"
}.stringify_keys,
log_level: "INFO",
audit_usernames: false
}.stringify_keys
2015-04-26 12:48:37 +05:30
redis_url = URI.parse(ENV['REDIS_URL'] || "redis://localhost:6379")
if redis_url.scheme == 'unix'
config['redis']['socket'] = redis_url.path
else
config['redis']['host'] = redis_url.host
config['redis']['port'] = redis_url.port
end
2014-09-02 18:07:02 +05:30
# Generate config.yml based on existing gitlab settings
File.open("config.yml", "w+") {|f| f.puts config.to_yaml}
# Launch installation process
2016-08-24 12:49:21 +05:30
system(*%W(bin/install) + repository_storage_paths_args)
2015-09-11 14:41:01 +05:30
# (Re)create hooks
2016-08-24 12:49:21 +05:30
system(*%W(bin/create-hooks) + repository_storage_paths_args)
2014-09-02 18:07:02 +05:30
end
# Required for debian packaging with PKGR: Setup .ssh/environment with
# the current PATH, so that the correct ruby version gets loaded
# Requires to set "PermitUserEnvironment yes" in sshd config (should not
# be an issue since it is more than likely that there are no "normal"
# user accounts on a gitlab server). The alternative is for the admin to
# install a ruby (1.9.3+) in the global path.
File.open(File.join(home_dir, ".ssh", "environment"), "w+") do |f|
f.puts "PATH=#{ENV['PATH']}"
end
2016-08-24 12:49:21 +05:30
Gitlab::Shell.new.generate_and_link_secret_token
2014-09-02 18:07:02 +05:30
end
2015-09-11 14:41:01 +05:30
desc "GitLab | Setup gitlab-shell"
2014-09-02 18:07:02 +05:30
task setup: :environment do
setup
end
2015-09-11 14:41:01 +05:30
desc "GitLab | Build missing projects"
2014-09-02 18:07:02 +05:30
task build_missing_projects: :environment do
Project.find_each(batch_size: 1000) do |project|
2015-04-26 12:48:37 +05:30
path_to_repo = project.repository.path_to_repo
2016-09-13 17:45:13 +05:30
if File.exist?(path_to_repo)
2014-09-02 18:07:02 +05:30
print '-'
else
2016-08-24 12:49:21 +05:30
if Gitlab::Shell.new.add_repository(project.repository_storage_path,
project.path_with_namespace)
2014-09-02 18:07:02 +05:30
print '.'
else
print 'F'
end
end
end
end
end
def setup
warn_user_is_not_gitlab
unless ENV['force'] == 'yes'
puts "This will rebuild an authorized_keys file."
puts "You will lose any data stored in authorized_keys file."
ask_to_continue
puts ""
end
Gitlab::Shell.new.remove_all_keys
Gitlab::Shell.new.batch_add_keys do |adder|
Key.find_each(batch_size: 1000) do |key|
adder.add_key(key.shell_id, key.key)
print '.'
end
end
2015-04-26 12:48:37 +05:30
puts ""
2014-09-02 18:07:02 +05:30
unless $?.success?
puts "Failed to add keys...".color(:red)
2014-09-02 18:07:02 +05:30
exit 1
end
rescue Gitlab::TaskAbortedByUserError
puts "Quitting...".color(:red)
2014-09-02 18:07:02 +05:30
exit 1
end
2015-04-26 12:48:37 +05:30
def reset_to_commit(args)
2015-11-26 14:37:03 +05:30
tag, status = Gitlab::Popen.popen(%W(#{Gitlab.config.git.bin_path} describe -- #{args.tag}))
2015-04-26 12:48:37 +05:30
unless status.zero?
2015-11-26 14:37:03 +05:30
tag, status = Gitlab::Popen.popen(%W(#{Gitlab.config.git.bin_path} describe -- origin/#{args.tag}))
2015-04-26 12:48:37 +05:30
end
tag = tag.strip
2015-11-26 14:37:03 +05:30
system(*%W(#{Gitlab.config.git.bin_path} reset --hard #{tag}))
2015-04-26 12:48:37 +05:30
end
2014-09-02 18:07:02 +05:30
end