summaryrefslogtreecommitdiffstats
path: root/app/models/attachment.rb
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2008-05-17 11:03:43 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2008-05-17 11:03:43 +0000
commit439c697237224a5dde8fbe87a136239bfa0f99b6 (patch)
tree06ffc09f8df0d84fafad6b4155c127783893d4ad /app/models/attachment.rb
parent9e225cc63ff889d3dc6f2f904d8e0c33850073b6 (diff)
downloadredmine-439c697237224a5dde8fbe87a136239bfa0f99b6.tar.gz
redmine-439c697237224a5dde8fbe87a136239bfa0f99b6.zip
Fixed: possible error when attachment's filename is non-ASCII (#747, #1243, #1089).
git-svn-id: http://redmine.rubyforge.org/svn/trunk@1433 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/models/attachment.rb')
-rw-r--r--app/models/attachment.rb15
1 files changed, 14 insertions, 1 deletions
diff --git a/app/models/attachment.rb b/app/models/attachment.rb
index 08f440816..f44fe8b4d 100644
--- a/app/models/attachment.rb
+++ b/app/models/attachment.rb
@@ -40,7 +40,7 @@ class Attachment < ActiveRecord::Base
@temp_file = incoming_file
if @temp_file.size > 0
self.filename = sanitize_filename(@temp_file.original_filename)
- self.disk_filename = DateTime.now.strftime("%y%m%d%H%M%S") + "_" + self.filename
+ self.disk_filename = Attachment.disk_filename(filename)
self.content_type = @temp_file.content_type.to_s.chomp
self.filesize = @temp_file.size
end
@@ -100,4 +100,17 @@ private
# Finally, replace all non alphanumeric, hyphens or periods with underscore
@filename = just_filename.gsub(/[^\w\.\-]/,'_')
end
+
+ # Returns an ASCII or hashed filename
+ def self.disk_filename(filename)
+ df = DateTime.now.strftime("%y%m%d%H%M%S") + "_"
+ if filename =~ %r{^[a-zA-Z0-9_\.\-]*$}
+ df << filename
+ else
+ df << Digest::MD5.hexdigest(filename)
+ # keep the extension if any
+ df << $1 if filename =~ %r{(\.[a-zA-Z0-9]+)$}
+ end
+ df
+ end
end