0ab89d8e36
Suggests to use a JSON structured log instead Related to https://gitlab.com/gitlab-org/gitlab-ce/issues/54102
54 lines
1.7 KiB
Ruby
54 lines
1.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Storage
|
|
class LegacyProject
|
|
attr_accessor :project
|
|
delegate :namespace, :gitlab_shell, :repository_storage, to: :project
|
|
|
|
def initialize(project)
|
|
@project = project
|
|
end
|
|
|
|
# Base directory
|
|
#
|
|
# @return [String] directory where repository is stored
|
|
def base_dir
|
|
namespace.full_path
|
|
end
|
|
|
|
# Disk path is used to build repository and project's wiki path on disk
|
|
#
|
|
# @return [String] combination of base_dir and the repository own name without `.git` or `.wiki.git` extensions
|
|
def disk_path
|
|
project.full_path
|
|
end
|
|
|
|
def ensure_storage_path_exists
|
|
return unless namespace
|
|
|
|
gitlab_shell.add_namespace(repository_storage, base_dir)
|
|
end
|
|
|
|
def rename_repo(old_full_path: nil, new_full_path: nil)
|
|
old_full_path ||= project.full_path_before_last_save
|
|
new_full_path ||= project.build_full_path
|
|
|
|
if gitlab_shell.mv_repository(repository_storage, old_full_path, new_full_path)
|
|
# If repository moved successfully we need to send update instructions to users.
|
|
# However we cannot allow rollback since we moved repository
|
|
# So we basically we mute exceptions in next actions
|
|
begin
|
|
gitlab_shell.mv_repository(repository_storage, "#{old_full_path}.wiki", "#{new_full_path}.wiki")
|
|
return true
|
|
rescue => e
|
|
Rails.logger.error "Exception renaming #{old_full_path} -> #{new_full_path}: #{e}" # rubocop:disable Gitlab/RailsLogger
|
|
# Returning false does not rollback after_* transaction but gives
|
|
# us information about failing some of tasks
|
|
return false
|
|
end
|
|
end
|
|
|
|
false
|
|
end
|
|
end
|
|
end
|