56 lines
1.4 KiB
Ruby
56 lines
1.4 KiB
Ruby
class GitlabUploader < CarrierWave::Uploader::Base
|
|
def self.absolute_path(upload_record)
|
|
File.join(CarrierWave.root, upload_record.path)
|
|
end
|
|
|
|
def self.root_dir
|
|
'uploads'
|
|
end
|
|
|
|
# When object storage is used, keep the `root_dir` as `base_dir`.
|
|
# The files aren't really in folders there, they just have a name.
|
|
# The files that contain user input in their name, also contain a hash, so
|
|
# the names are still unique
|
|
#
|
|
# This method is overridden in the `FileUploader`
|
|
def self.base_dir
|
|
return root_dir unless file_storage?
|
|
|
|
File.join(root_dir, 'system')
|
|
end
|
|
|
|
def self.file_storage?
|
|
self.storage == CarrierWave::Storage::File
|
|
end
|
|
|
|
delegate :base_dir, :file_storage?, to: :class
|
|
|
|
def file_cache_storage?
|
|
cache_storage.is_a?(CarrierWave::Storage::File)
|
|
end
|
|
|
|
# Reduce disk IO
|
|
def move_to_cache
|
|
true
|
|
end
|
|
|
|
# Reduce disk IO
|
|
def move_to_store
|
|
true
|
|
end
|
|
|
|
# Designed to be overridden by child uploaders that have a dynamic path
|
|
# segment -- that is, a path that changes based on mutable attributes of its
|
|
# associated model
|
|
#
|
|
# For example, `FileUploader` builds the storage path based on the associated
|
|
# project model's `path_with_namespace` value, which can change when the
|
|
# project or its containing namespace is moved or renamed.
|
|
def relative_path
|
|
self.file.path.sub("#{root}/", '')
|
|
end
|
|
|
|
def exists?
|
|
file.try(:exists?)
|
|
end
|
|
end
|