FEATURE: cap number of staged users (defaults to 10) created per incoming email

This commit is contained in:
Régis Hanol 2016-05-16 21:45:34 +02:00
parent 973f4ee699
commit 5f76287b18
4 changed files with 16 additions and 0 deletions

View File

@ -51,6 +51,7 @@ en:
incoming: incoming:
default_subject: "Incoming email from %{email}" default_subject: "Incoming email from %{email}"
show_trimmed_content: "Show trimmed content" show_trimmed_content: "Show trimmed content"
maximum_staged_user_per_email_reached: "Reached maximum number of staged users created per email."
errors: errors:
empty_email_error: "Happens when the raw mail we received was blank." empty_email_error: "Happens when the raw mail we received was blank."
no_message_id_error: "Happens when the mail has no 'Message-Id' header." no_message_id_error: "Happens when the mail has no 'Message-Id' header."
@ -1173,6 +1174,7 @@ en:
delete_email_logs_after_days: "Delete email logs after (N) days. 0 to keep indefinitely" delete_email_logs_after_days: "Delete email logs after (N) days. 0 to keep indefinitely"
max_emails_per_day_per_user: "Maximum number of emails to send users per day. 0 to disable the limit" max_emails_per_day_per_user: "Maximum number of emails to send users per day. 0 to disable the limit"
enable_staged_users: "Automatically create staged users when processing incoming emails." enable_staged_users: "Automatically create staged users when processing incoming emails."
maximum_staged_users_per_email: "Maximum number of staged users created when processing an incoming email."
auto_generated_whitelist: "List of email addresses that won't be checked for auto-generated content." auto_generated_whitelist: "List of email addresses that won't be checked for auto-generated content."
block_auto_generated_emails: "Block incoming emails identified as being auto generated." block_auto_generated_emails: "Block incoming emails identified as being auto generated."
bounce_score_threshold: "Max score before we will stop emailing a user. Soft bounce adds 1, hard bounce adds 2, score reset 30 days after last bounce." bounce_score_threshold: "Max score before we will stop emailing a user. Soft bounce adds 1, hard bounce adds 2, score reset 30 days after last bounce."

View File

@ -567,6 +567,7 @@ email:
min: 0 min: 0
max_emails_per_day_per_user: 100 max_emails_per_day_per_user: 100
enable_staged_users: true enable_staged_users: true
maximum_staged_users_per_email: 10
auto_generated_whitelist: auto_generated_whitelist:
default: '' default: ''
type: list type: list

View File

@ -31,6 +31,7 @@ module Email
def initialize(mail_string) def initialize(mail_string)
raise EmptyEmailError if mail_string.blank? raise EmptyEmailError if mail_string.blank?
@staged_users_created = 0
@raw_email = mail_string @raw_email = mail_string
@mail = Mail.new(@raw_email) @mail = Mail.new(@raw_email)
@message_id = @mail.message_id.presence || Digest::MD5.hexdigest(mail_string) @message_id = @mail.message_id.presence || Digest::MD5.hexdigest(mail_string)
@ -283,6 +284,7 @@ module Email
name: display_name.presence || User.suggest_name(email), name: display_name.presence || User.suggest_name(email),
staged: true staged: true
) )
@staged_users_created += 1
end end
rescue rescue
user = nil user = nil
@ -477,6 +479,11 @@ module Email
topic.topic_allowed_users.create!(user_id: user.id) topic.topic_allowed_users.create!(user_id: user.id)
topic.add_small_action(sender, "invited_user", user.username) topic.add_small_action(sender, "invited_user", user.username)
end end
# cap number of staged users created per email
if @staged_users_created > SiteSetting.maximum_staged_users_per_email
topic.add_moderator_post(sender, I18n.t("emails.incoming.maximum_staged_user_per_email_reached"))
return
end
end end
rescue ActiveRecord::RecordInvalid rescue ActiveRecord::RecordInvalid
# don't care if user already allowed # don't care if user already allowed

View File

@ -325,6 +325,12 @@ describe Email::Receiver do
expect(emails).to include("someone@else.com", "discourse@bar.com", "wat@bar.com") expect(emails).to include("someone@else.com", "discourse@bar.com", "wat@bar.com")
end end
it "cap the number of staged users created per email" do
SiteSetting.maximum_staged_users_per_email = 1
expect { process(:cc) }.to change(Topic, :count)
expect(Topic.last.ordered_posts[-1].post_type).to eq(Post.types[:moderator_action])
end
it "associates email replies using both 'In-Reply-To' and 'References' headers" do it "associates email replies using both 'In-Reply-To' and 'References' headers" do
expect { process(:email_reply_1) }.to change(Topic, :count) expect { process(:email_reply_1) }.to change(Topic, :count)