2017-08-17 22:00:37 +05:30
|
|
|
module RecordsUploads
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
|
|
|
included do
|
|
|
|
after :store, :record_upload
|
|
|
|
before :remove, :destroy_upload
|
|
|
|
end
|
|
|
|
|
|
|
|
# After storing an attachment, create a corresponding Upload record
|
|
|
|
#
|
|
|
|
# NOTE: We're ignoring the argument passed to this callback because we want
|
|
|
|
# the `SanitizedFile` object from `CarrierWave::Uploader::Base#file`, not the
|
|
|
|
# `Tempfile` object the callback gets.
|
|
|
|
#
|
|
|
|
# Called `after :store`
|
2017-09-10 17:25:29 +05:30
|
|
|
def record_upload(_tempfile = nil)
|
|
|
|
return unless model
|
2017-08-17 22:00:37 +05:30
|
|
|
return unless file_storage?
|
|
|
|
return unless file.exists?
|
|
|
|
|
|
|
|
Upload.record(self)
|
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
private
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
# Before removing an attachment, destroy any Upload records at the same path
|
|
|
|
#
|
|
|
|
# Called `before :remove`
|
|
|
|
def destroy_upload(*args)
|
|
|
|
return unless file_storage?
|
|
|
|
return unless file
|
|
|
|
|
|
|
|
Upload.remove_path(relative_path)
|
|
|
|
end
|
|
|
|
end
|