diff options
| author | Louise Crow <louise.crow@gmail.com> | 2015-06-12 15:13:06 +0100 | 
|---|---|---|
| committer | Louise Crow <louise.crow@gmail.com> | 2015-06-22 17:43:22 +0100 | 
| commit | 78e73a009af36170213d77fee204718dc0d70cf0 (patch) | |
| tree | d03be4b86ac23c7759d9ff95c1df15545e4d5ce0 | |
| parent | 19c5e549b8529b10faa36307efceab207afd3224 (diff) | |
Remove redundant UTF-8 conversion.
body_as_text has already been converted and scrubbed if needed.
| -rw-r--r-- | app/models/incoming_message.rb | 66 | 
1 files changed, 1 insertions, 65 deletions
| diff --git a/app/models/incoming_message.rb b/app/models/incoming_message.rb index 749f27832..362866aa4 100644 --- a/app/models/incoming_message.rb +++ b/app/models/incoming_message.rb @@ -372,7 +372,6 @@ class IncomingMessage < ActiveRecord::Base      def _convert_part_body_to_text(part)          if part.nil?              text = "[ Email has no body, please see attachments ]" -            source_charset = "utf-8"          else              # whatever kind of attachment it is, get the UTF-8 encoded text              text = part.body_as_text.string @@ -381,26 +380,7 @@ class IncomingMessage < ActiveRecord::Base                  # TODO: This is a bit of a hack as it is calling a                  # convert to text routine.  Could instead call a                  # sanitize HTML one. - -                # If the text isn't UTF8, it means we had a problem -                # converting it (invalid characters, etc), and we -                # should instead tell elinks to respect the source -                # charset -                use_charset = "utf-8" -                if String.method_defined?(:encode) -                    begin -                        text.encode('utf-8') -                    rescue Encoding::UndefinedConversionError, Encoding::InvalidByteSequenceError -                        use_charset = source_charset -                    end -                else -                    begin -                        text = Iconv.conv('utf-8', 'utf-8', text) -                    rescue Iconv::IllegalSequence -                        use_charset = source_charset -                    end -                end -                text = MailHandler.get_attachment_text_one_file(part.content_type, text, use_charset) +                text = MailHandler.get_attachment_text_one_file(part.content_type, text, "UTF-8")              end          end @@ -420,50 +400,6 @@ class IncomingMessage < ActiveRecord::Base          return text      end -    def _sanitize_text(text) -        if String.method_defined?(:encode) -            begin -                # Test if it's good UTF-8 -                text.encode('utf-8') -            rescue Encoding::UndefinedConversionError, Encoding::InvalidByteSequenceError -                source_charset = 'utf-8' if source_charset.nil? -                # strip out anything that isn't UTF-8 -                begin -                    text = text.encode("utf-8", :invalid => :replace, -                                                :undef => :replace, -                                                :replace => "") + -                        _("\n\n[ {{site_name}} note: The above text was badly encoded, and has had strange characters removed. ]", -                          :site_name => MySociety::Config.get('SITE_NAME', 'Alaveteli')) -                rescue Encoding::UndefinedConversionError, Encoding::InvalidByteSequenceError -                    if source_charset != "utf-8" -                        source_charset = "utf-8" -                        retry -                    end -                end -            end -        else -            begin -                # Test if it's good UTF-8 -                text = Iconv.conv('utf-8', 'utf-8', text) -            rescue Iconv::IllegalSequence -                # Text looks like unlabelled nonsense, -                # strip out anything that isn't UTF-8 -                begin -                    source_charset = 'utf-8' if source_charset.nil? -                    text = Iconv.conv('utf-8//IGNORE', source_charset, text) + -                        _("\n\n[ {{site_name}} note: The above text was badly encoded, and has had strange characters removed. ]", -                          :site_name => AlaveteliConfiguration::site_name) -                rescue Iconv::InvalidEncoding, Iconv::IllegalSequence, Iconv::InvalidCharacter -                    if source_charset != "utf-8" -                        source_charset = "utf-8" -                        retry -                    end -                end -            end -        end -        text -    end -      # Returns part which contains main body text, or nil if there isn't one,      # from a set of foi_attachments. If the leaves parameter is empty or not      # supplied, uses its own foi_attachments. | 
