mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 02:32:45 +08:00
FIX: surround the FROM alias with " in order to support the @ character
This commit is contained in:
parent
0c03ccb01e
commit
ee9d621d9c
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue
Block a user