Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app/services/projects/hashed_storage/rollback_repository_service.rb')
-rw-r--r--app/services/projects/hashed_storage/rollback_repository_service.rb28
1 files changed, 23 insertions, 5 deletions
diff --git a/app/services/projects/hashed_storage/rollback_repository_service.rb b/app/services/projects/hashed_storage/rollback_repository_service.rb
index d6646e3765e..6ab49630603 100644
--- a/app/services/projects/hashed_storage/rollback_repository_service.rb
+++ b/app/services/projects/hashed_storage/rollback_repository_service.rb
@@ -21,14 +21,32 @@ module Projects
project.storage_version = ::Project::HASHED_STORAGE_FEATURES[:repository]
end
- project.repository_read_only = false
- project.save!(validate: false)
-
- if result && block_given?
- yield
+ project.transaction do
+ project.save!(validate: false)
+ project.set_repository_writable!
end
result
+ rescue Gitlab::Git::CommandError => e
+ logger.error("Repository #{project.full_path} failed to rollback (PROJECT_ID=#{project.id}). Git operation failed: #{e.inspect}")
+
+ rollback_migration!
+
+ false
+ rescue OpenSSL::Cipher::CipherError => e
+ logger.error("Repository #{project.full_path} failed to rollback (PROJECT_ID=#{project.id}). There is a problem with encrypted attributes: #{e.inspect}")
+
+ rollback_migration!
+
+ false
+ end
+
+ private
+
+ def rollback_migration!
+ rollback_folder_move
+ project.storage_version = ::Project::HASHED_STORAGE_FEATURES[:repository]
+ project.set_repository_writable!
end
end
end