Store AJAX uploaded documents with timestamp prefix to avoid file name collision. Remove cached_attachments after document save.

This commit is contained in:
Senén Rodero Rodríguez
2017-08-24 18:15:43 +02:00
parent 2e1d98c408
commit f4ac8b17d0
2 changed files with 31 additions and 22 deletions

View File

@@ -14,7 +14,7 @@ class DocumentsController < ApplicationController
end end
def create def create
recover_attachment_from_cache recover_attachments_from_cache
if @document.save if @document.save
flash[:notice] = t "documents.actions.create.notice" flash[:notice] = t "documents.actions.create.notice"
redirect_to params[:from] redirect_to params[:from]
@@ -60,6 +60,7 @@ class DocumentsController < ApplicationController
@document = Document.new(document_params.merge(user: current_user)) @document = Document.new(document_params.merge(user: current_user))
@document.documentable = @documentable @document.documentable = @documentable
if @document.valid? if @document.valid?
@document.attachment_file_name = "#{Time.now.to_i} - #{@document.attachment_file_name}"
@document.attachment.save @document.attachment.save
@document.cached_attachment = @document.attachment.path @document.cached_attachment = @document.attachment.path
else else
@@ -88,7 +89,7 @@ class DocumentsController < ApplicationController
@document.user = current_user @document.user = current_user
end end
def recover_attachment_from_cache def recover_attachments_from_cache
if @document.attachment.blank? && @document.cached_attachment.present? if @document.attachment.blank? && @document.cached_attachment.present?
@document.attachment = File.open(@document.cached_attachment) @document.attachment = File.open(@document.cached_attachment)
end end

View File

@@ -20,6 +20,10 @@ class Document < ActiveRecord::Base
validates :documentable_id, presence: true, if: -> { persisted? } validates :documentable_id, presence: true, if: -> { persisted? }
validates :documentable_type, presence: true, if: -> { persisted? } validates :documentable_type, presence: true, if: -> { persisted? }
after_save :remove_cached_document, if: -> { valid? && persisted? && cached_attachment.present? }
private
def validate_attachment_size def validate_attachment_size
if documentable.present? && if documentable.present? &&
attachment_file_size > documentable.class.max_file_size attachment_file_size > documentable.class.max_file_size
@@ -44,4 +48,8 @@ class Document < ActiveRecord::Base
end end
end end
def remove_cached_document
File.delete(cached_attachment) if File.exists?(cached_attachment)
end
end end