FIX: surround the FROM alias with " in order to support the @ character

This commit is contained in:
Régis Hanol 2017-03-07 23:37:21 +01:00
parent 0c03ccb01e
commit ee9d621d9c
3 changed files with 19 additions and 19 deletions

View File

@ -7,15 +7,15 @@ require_dependency 'email/styles'
module Email module Email
def self.is_valid?(email) def self.is_valid?(email)
return false unless String === email return false unless String === email
parsed = Mail::Address.new(email) parsed = Mail::Address.new(email)
# Don't allow for a TLD by itself list (sam@localhost) # Don't allow for a TLD by itself list (sam@localhost)
# The Grammar is: (local_part "@" domain) / local_part ... need to discard latter # The Grammar is: (local_part "@" domain) / local_part ... need to discard latter
parsed.address == email && parsed.local != parsed.address && parsed.domain && parsed.domain.split(".").length > 1 parsed.address == email &&
parsed.local != parsed.address &&
parsed&.domain.split(".").size > 1
rescue Mail::Field::ParseError rescue Mail::Field::ParseError
false false
end end
@ -26,8 +26,7 @@ module Email
end end
def self.cleanup_alias(name) def self.cleanup_alias(name)
# TODO: I'm sure there are more, but I can't find a list name ? name.gsub(/[:<>,"]/, '') : name
name ? name.gsub(/[:<>,]/, '') : name
end end
end end

View File

@ -207,7 +207,7 @@ module Email
SiteSetting.title.blank? SiteSetting.title.blank?
if !@opts[:from_alias].blank? if !@opts[:from_alias].blank?
"#{Email.cleanup_alias(@opts[:from_alias])} <#{source}>" "\"#{Email.cleanup_alias(@opts[:from_alias])}\" <#{source}>"
elsif source == SiteSetting.notification_email || source == SiteSetting.reply_by_email_address elsif source == SiteSetting.notification_email || source == SiteSetting.reply_by_email_address
site_alias_email(source) site_alias_email(source)
else else
@ -216,7 +216,8 @@ module Email
end end
def site_alias_email(source) def site_alias_email(source)
"#{Email.cleanup_alias(SiteSetting.email_site_title.presence || SiteSetting.title)} <#{source}>" from_alias = SiteSetting.email_site_title.presence || SiteSetting.title
"\"#{Email.cleanup_alias(from_alias)}\" <#{source}>"
end end
end end

View File

@ -58,12 +58,12 @@ describe Email::MessageBuilder do
end end
it "returns a Reply-To header with the reply key" do it "returns a Reply-To header with the reply key" do
expect(reply_by_email_builder.header_args['Reply-To']).to eq(SiteSetting.title + " <r+#{reply_key}@reply.myforum.com>") expect(reply_by_email_builder.header_args['Reply-To']).to eq("\"#{SiteSetting.title}\" <r+#{reply_key}@reply.myforum.com>")
end end
it "cleans up the site title" do it "cleans up the site title" do
SiteSetting.stubs(:title).returns(">>>Obnoxious Title: Deal, With It<<<") SiteSetting.stubs(:title).returns(">>>Obnoxious Title: Deal, \"With\" It<<<")
expect(reply_by_email_builder.header_args['Reply-To']).to eq("Obnoxious Title Deal With It <r+#{reply_key}@reply.myforum.com>") expect(reply_by_email_builder.header_args['Reply-To']).to eq("\"Obnoxious Title Deal With It\" <r+#{reply_key}@reply.myforum.com>")
end end
end end
@ -98,7 +98,7 @@ describe Email::MessageBuilder do
end end
it "returns a Reply-To header with the reply key" do it "returns a Reply-To header with the reply key" do
expect(reply_by_email_builder.header_args['Reply-To']).to eq("Username <r+#{reply_key}@reply.myforum.com>") expect(reply_by_email_builder.header_args['Reply-To']).to eq("\"Username\" <r+#{reply_key}@reply.myforum.com>")
end end
end end
@ -243,7 +243,7 @@ describe Email::MessageBuilder do
it "title setting will be added if present" do it "title setting will be added if present" do
SiteSetting.title = "Dog Talk" SiteSetting.title = "Dog Talk"
expect(build_args[:from]).to eq("Dog Talk <#{SiteSetting.notification_email}>") expect(build_args[:from]).to eq("\"Dog Talk\" <#{SiteSetting.notification_email}>")
end end
let(:finn_email) { 'finn@adventuretime.ooo' } let(:finn_email) { 'finn@adventuretime.ooo' }
@ -256,7 +256,7 @@ describe Email::MessageBuilder do
let(:aliased_from) { Email::MessageBuilder.new(to_address, from_alias: "Finn the Dog") } let(:aliased_from) { Email::MessageBuilder.new(to_address, from_alias: "Finn the Dog") }
it "allows us to alias the from address" do it "allows us to alias the from address" do
expect(aliased_from.build_args[:from]).to eq("Finn the Dog <#{SiteSetting.notification_email}>") expect(aliased_from.build_args[:from]).to eq("\"Finn the Dog\" <#{SiteSetting.notification_email}>")
end end
let(:custom_aliased_from) { Email::MessageBuilder.new(to_address, let(:custom_aliased_from) { Email::MessageBuilder.new(to_address,
@ -264,28 +264,28 @@ describe Email::MessageBuilder do
from: finn_email) } from: finn_email) }
it "allows us to alias a custom from address" do it "allows us to alias a custom from address" do
expect(custom_aliased_from.build_args[:from]).to eq("Finn the Dog <#{finn_email}>") expect(custom_aliased_from.build_args[:from]).to eq("\"Finn the Dog\" <#{finn_email}>")
end end
it "email_site_title will be added if it's set" do it "email_site_title will be added if it's set" do
SiteSetting.email_site_title = "The Forum" SiteSetting.email_site_title = "The Forum"
expect(build_args[:from]).to eq("The Forum <#{SiteSetting.notification_email}>") expect(build_args[:from]).to eq("\"The Forum\" <#{SiteSetting.notification_email}>")
end end
it "email_site_title overrides title" do it "email_site_title overrides title" do
SiteSetting.title = "Dog Talk" SiteSetting.title = "Dog Talk"
SiteSetting.email_site_title = "The Forum" SiteSetting.email_site_title = "The Forum"
expect(build_args[:from]).to eq("The Forum <#{SiteSetting.notification_email}>") expect(build_args[:from]).to eq("\"The Forum\" <#{SiteSetting.notification_email}>")
end end
it "cleans up aliases in the from_alias arg" do it "cleans up aliases in the from_alias arg" do
builder = Email::MessageBuilder.new(to_address, from_alias: "Finn: the Dog, <3", from: finn_email) builder = Email::MessageBuilder.new(to_address, from_alias: "Finn: the Dog, <3", from: finn_email)
expect(builder.build_args[:from]).to eq("Finn the Dog 3 <#{finn_email}>") expect(builder.build_args[:from]).to eq("\"Finn the Dog 3\" <#{finn_email}>")
end end
it "cleans up the email_site_title" do it "cleans up the email_site_title" do
SiteSetting.stubs(:email_site_title).returns("::>>>Best Forum, EU: Award Winning<<<") SiteSetting.stubs(:email_site_title).returns("::>>>Best \"Forum\", EU: Award Winning<<<")
expect(build_args[:from]).to eq("Best Forum EU Award Winning <#{SiteSetting.notification_email}>") expect(build_args[:from]).to eq("\"Best Forum EU Award Winning\" <#{SiteSetting.notification_email}>")
end end
end end