diff options
| author | Gareth Rees <gareth@mysociety.org> | 2015-06-04 14:21:31 +0100 | 
|---|---|---|
| committer | Gareth Rees <gareth@mysociety.org> | 2015-06-04 14:21:31 +0100 | 
| commit | c381a4ed104493b20d97e5a2e3d6ba111c719238 (patch) | |
| tree | 42d4e82dca13c56cb03544a9a7a5a7ddc51da7a9 /app/models/incoming_message.rb | |
| parent | d59a325de7cb43f114412a8ad62c60b331b8b19a (diff) | |
| parent | 305aab8701d9a398ad9dc9150e296c3badc0ee92 (diff) | |
Merge branch 'hotfix/0.21.0.36'0.21.0.36
Diffstat (limited to 'app/models/incoming_message.rb')
| -rw-r--r-- | app/models/incoming_message.rb | 16 | 
1 files changed, 5 insertions, 11 deletions
| diff --git a/app/models/incoming_message.rb b/app/models/incoming_message.rb index 4feee7637..3606c39c2 100644 --- a/app/models/incoming_message.rb +++ b/app/models/incoming_message.rb @@ -505,14 +505,9 @@ class IncomingMessage < ActiveRecord::Base          # Find any uudecoded things buried in it, yeuchly          uus = text.scan(/^begin.+^`\n^end\n/m)          attachments = [] -        for uu in uus +        uus.each do |uu|              # Decode the string -            content = nil -            tempfile = Tempfile.new('foiuu') -            tempfile.print uu -            tempfile.flush -            content = AlaveteliExternalCommand.run("uudecode", "-o", "/dev/stdout", tempfile.path) -            tempfile.close +            content = uu.sub(/\Abegin \d+ [^\n]*\n/, '').unpack('u').first              # Make attachment type from it, working out filename and mime type              filename = uu.match(/^begin\s+[0-9]+\s+(.*)$/)[1]              calc_mime = AlaveteliFileTypes.filename_and_content_to_mimetype(filename, content) @@ -523,15 +518,14 @@ class IncomingMessage < ActiveRecord::Base                  content_type = 'application/octet-stream'              end              hexdigest = Digest::MD5.hexdigest(content) -            attachment = self.foi_attachments.find_or_create_by_hexdigest(hexdigest) +            attachment = foi_attachments.find_or_create_by_hexdigest(hexdigest)              attachment.update_attributes(:filename => filename,                                           :content_type => content_type, -                                         :body => content, -                                         :display_size => "0K") +                                         :body => content)              attachment.save!              attachments << attachment          end -        return attachments +        attachments      end      def get_attachments_for_display | 
