mirror of
https://github.com/discourse/discourse.git
synced 2025-05-22 16:11:08 +08:00
FEATURE: backport a minimal String#scrub
BUGFIX: invalid byte sequence in email would explode all processing
This commit is contained in:
@ -25,14 +25,7 @@ module ApplicationHelper
|
||||
|
||||
def escape_unicode(javascript)
|
||||
if javascript
|
||||
javascript = javascript.dup.force_encoding("utf-8")
|
||||
|
||||
unless javascript.valid_encoding?
|
||||
# work around bust string with a double conversion
|
||||
javascript.encode!("utf-16","utf-8",:invalid => :replace)
|
||||
javascript.encode!("utf-8","utf-16")
|
||||
end
|
||||
|
||||
javascript = javascript.scrub
|
||||
javascript.gsub!(/\342\200\250/u, '
')
|
||||
javascript.gsub!(/(<\/)/u, '\u003C/')
|
||||
javascript.html_safe
|
||||
|
Reference in New Issue
Block a user