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:
authorJames Edwards-Jones <jedwardsjones@gitlab.com>2018-01-12 02:12:34 +0300
committerJames Edwards-Jones <jedwardsjones@gitlab.com>2018-03-15 05:39:08 +0300
commit1baac9211238f60d2d2a50cccd0bea6979bfa6ba (patch)
tree7f07f3d1eb65f31f01c52973d115d349a95e3de2 /app/services/lfs
parentffb1c65b0ba7fa8a4ea7e128cb47449f04837869 (diff)
Multi-file upload and Commit API obey LFS filters
Updates Files::MultiService for the commits API which is in turn used by the multi-file upload web UI Ensures that files which should be in LFS are transformed into LFS pointers Uses Lfs::Transformer which then links LfsObjectProjects on success
Diffstat (limited to 'app/services/lfs')
-rw-r--r--app/services/lfs/file_transformer.rb35
1 files changed, 31 insertions, 4 deletions
diff --git a/app/services/lfs/file_transformer.rb b/app/services/lfs/file_transformer.rb
index 030f2c6aeba..7c93659b60d 100644
--- a/app/services/lfs/file_transformer.rb
+++ b/app/services/lfs/file_transformer.rb
@@ -1,4 +1,16 @@
module Lfs
+ # Usage: Open a `.link_lfs_objects` block, call `new_file` on the yielded object
+ # as many times as needed. LfsObjectProject links will be saved if the
+ # return value of the block is truthy.
+ #
+ # Calling `new_file` will check the path to see if it should be in LFS,
+ # save and LFS pointer of needed and return its content to be saved in
+ # a commit. If the file isn't LFS the untransformed content is returned.
+ #
+ # Lfs::FileTransformer.link_lfs_objects(project, @branch_name) do |transformer|
+ # content_or_lfs_pointer = transformer.new_file(file_path, file_content)
+ # create_transformed_commit(content_or_lfs_pointer)
+ # end
class FileTransformer
attr_reader :project, :branch_name
@@ -9,26 +21,41 @@ module Lfs
@branch_name = branch_name
end
+ def self.link_lfs_objects(project, branch_name)
+ transformer = new(project, branch_name)
+ result = yield(transformer)
+ transformer.after_transform! if result
+
+ result
+ end
+
def new_file(file_path, file_content)
if project.lfs_enabled? && lfs_file?(file_path)
lfs_pointer_file = Gitlab::Git::LfsPointerFile.new(file_content)
lfs_object = create_lfs_object!(lfs_pointer_file, file_content)
- content = lfs_pointer_file.pointer
- success = yield(content)
+ on_success_actions << -> { link_lfs_object!(lfs_object) }
- link_lfs_object!(lfs_object) if success
+ lfs_pointer_file.pointer
else
- yield(file_content)
+ file_content
end
end
+ def after_transform!
+ on_success_actions.map(&:call)
+ end
+
private
def lfs_file?(file_path)
repository.attributes_at(branch_name, file_path)['filter'] == 'lfs'
end
+ def on_success_actions
+ @on_success_actions ||= []
+ end
+
def create_lfs_object!(lfs_pointer_file, file_content)
LfsObject.find_or_create_by(oid: lfs_pointer_file.sha256, size: lfs_pointer_file.size) do |lfs_object|
lfs_object.file = CarrierWaveStringFile.new(file_content)