mirror of
https://github.com/discourse/discourse.git
synced 2024-11-22 08:36:42 +08:00
FEATURE: add maximum limit for secondary emails (#12599)
This commit is contained in:
parent
8a36b91c2c
commit
6234d7455b
|
@ -883,6 +883,7 @@ en:
|
|||
error_staged: "There was an error changing your email address. The address is already in use by a staged user."
|
||||
already_done: "Sorry, this confirmation link is no longer valid. Perhaps your email was already changed?"
|
||||
confirm: "Confirm"
|
||||
max_secondary_emails_error: "You have reached the maximum allowed secondary emails limit."
|
||||
|
||||
authorizing_new:
|
||||
title: "Confirm your new email"
|
||||
|
|
|
@ -1769,6 +1769,9 @@ rate_limits:
|
|||
max: 1000000
|
||||
default: 10
|
||||
client: true
|
||||
max_allowed_secondary_emails:
|
||||
default: 10
|
||||
hidden: true
|
||||
|
||||
developer:
|
||||
force_hostname:
|
||||
|
|
|
@ -31,9 +31,16 @@ class EmailUpdater
|
|||
end
|
||||
end
|
||||
|
||||
return if errors.present? || existing_user.present?
|
||||
if add
|
||||
secondary_emails_count = @user.secondary_emails.count
|
||||
if secondary_emails_count >= SiteSetting.max_allowed_secondary_emails
|
||||
errors.add(:base, I18n.t("change_email.max_secondary_emails_error"))
|
||||
end
|
||||
else
|
||||
old_email = @user.email
|
||||
end
|
||||
|
||||
old_email = @user.email if !add
|
||||
return if errors.present? || existing_user.present?
|
||||
|
||||
if @guardian.is_staff? && @guardian.user != @user
|
||||
StaffActionLogger.new(@guardian.user).log_add_email(@user)
|
||||
|
|
|
@ -239,6 +239,23 @@ describe EmailUpdater do
|
|||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "max_allowed_secondary_emails" do
|
||||
let(:secondary_email_1) { "secondary_1@email.com" }
|
||||
let(:secondary_email_2) { "secondary_2@email.com" }
|
||||
|
||||
before do
|
||||
SiteSetting.max_allowed_secondary_emails = 2
|
||||
Fabricate(:secondary_email, user: user, primary: false, email: secondary_email_1)
|
||||
Fabricate(:secondary_email, user: user, primary: false, email: secondary_email_2)
|
||||
end
|
||||
|
||||
it "max secondary_emails limit reached" do
|
||||
updater.change_to(new_email, add: true)
|
||||
expect(updater.errors).to be_present
|
||||
expect(updater.errors.messages[:base].first).to be I18n.t("change_email.max_secondary_emails_error")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context 'as a staff user' do
|
||||
|
|
Loading…
Reference in New Issue
Block a user