diff options
author | Stan Hu <stanhu@gmail.com> | 2016-06-08 18:04:31 -0700 |
---|---|---|
committer | Stan Hu <stanhu@gmail.com> | 2016-06-10 10:17:54 -0700 |
commit | f03df228155ae2d8dd779bd1a8e4078698b23c06 (patch) | |
tree | 4d8cf16596c8852cdd331deb7773544053e4bbab /lib/backup | |
parent | 9c96074c0e277489637d7d27e681515edd2714ea (diff) | |
download | gitlab-ce-f03df228155ae2d8dd779bd1a8e4078698b23c06.tar.gz |
Only create the backup directory if it is local
Closes #12710
Diffstat (limited to 'lib/backup')
-rw-r--r-- | lib/backup/manager.rb | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/lib/backup/manager.rb b/lib/backup/manager.rb index 9dd665441a0..2ff3e3bdfb0 100644 --- a/lib/backup/manager.rb +++ b/lib/backup/manager.rb @@ -38,7 +38,6 @@ module Backup end def upload(tar_file) - remote_directory = Gitlab.config.backup.upload.remote_directory $progress.print "Uploading backup archive to remote storage #{remote_directory} ... " connection_settings = Gitlab.config.backup.upload.connection @@ -47,8 +46,7 @@ module Backup return end - connection = ::Fog::Storage.new(connection_settings) - directory = connection.directories.create(key: remote_directory) + directory = connect_to_remote_directory(connection_settings) if directory.files.create(key: tar_file, body: File.open(tar_file), public: false, multipart_chunk_size: Gitlab.config.backup.upload.multipart_chunk_size, @@ -155,6 +153,23 @@ module Backup private + def connect_to_remote_directory(connection_settings) + connection = ::Fog::Storage.new(connection_settings) + + # We only attempt to create the directory for local backups. For AWS + # and other cloud providers, we cannot guarantee the user will have + # permission to create the bucket. + if connection.service == ::Fog::Storage::Local + connection.directories.create(key: remote_directory) + else + connection.directories.get(remote_directory) + end + end + + def remote_directory + Gitlab.config.backup.upload.remote_directory + end + def backup_contents folders_to_backup + archives_to_backup + ["backup_information.yml"] end |