Commit 8c478874 authored by James Lopez's avatar James Lopez

Merge branches 'feature/project-export' and 'feature/project-import' of...

Merge branches 'feature/project-export' and 'feature/project-import' of gitlab.com:gitlab-org/gitlab-ce into feature/project-import
parents 30aa37c8 5777ad9a
......@@ -4,12 +4,16 @@ module Projects
def execute(options = {})
@shared = Gitlab::ImportExport::Shared.new(relative_path: File.join(project.path_with_namespace, 'work'))
save_all if [save_project_tree, bundle_repo, bundle_wiki_repo].all?
notify_worker if @shared.errors.any?
save_all if [save_version, save_project_tree, bundle_repo, bundle_wiki_repo].all?
cleanup_and_notify_worker if @shared.errors.any?
end
private
def save_version
Gitlab::ImportExport::VersionSaver.save(shared: @shared)
end
def save_project_tree
Gitlab::ImportExport::ProjectTreeSaver.new(project: project, shared: @shared).save
end
......@@ -26,7 +30,8 @@ module Projects
Gitlab::ImportExport::Saver.save(shared: @shared)
end
def notify_worker
def cleanup_and_notify_worker
FileUtils.rm_rf(@shared.export_path)
raise Gitlab::ImportExport::Error.new(@shared.errors.join(', '))
end
end
......
......@@ -2,6 +2,8 @@ module Gitlab
module ImportExport
extend self
VERSION = '0.1.0'
def export_path(relative_path:)
File.join(storage_path, relative_path)
end
......@@ -17,5 +19,9 @@ module Gitlab
def project_bundle_filename
"project.bundle"
end
def version_filename
'VERSION'
end
end
end
module Gitlab
module ImportExport
class VersionSaver
def self.save(*args)
new(*args).save
end
def initialize(shared:)
@shared = shared
end
def save
File.open(version_file, 'w') do |file|
file.write(Gitlab::ImportExport.VERSION)
end
rescue => e
@shared.error(e.message)
false
end
private
def version_file
File.join(@shared.export_path, Gitlab::ImportExport.version_filename)
end
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment