mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 11:02:46 +08:00
FIX: error when trying to block an IP address. Return a message when IP address matches an existing screened IP address, including ranges.
This commit is contained in:
parent
6ca71e1319
commit
4d44024c82
|
@ -48,13 +48,17 @@ export default Ember.Component.extend({
|
|||
action_name: this.get('actionName')
|
||||
});
|
||||
screenedIpAddress.save().then(result => {
|
||||
this.setProperties({ ip_address: '', formSubmitted: false });
|
||||
this.sendAction('action', ScreenedIpAddress.create(result.screened_ip_address));
|
||||
Ember.run.schedule('afterRender', () => this.$('.ip-address-input').focus());
|
||||
if (result.success) {
|
||||
this.setProperties({ ip_address: '', formSubmitted: false });
|
||||
this.sendAction('action', ScreenedIpAddress.create(result.screened_ip_address));
|
||||
Ember.run.schedule('afterRender', () => this.$('.ip-address-input').focus());
|
||||
} else {
|
||||
bootbox.alert(result.errors);
|
||||
}
|
||||
}).catch(e => {
|
||||
this.set('formSubmitted', false);
|
||||
const msg = (e.responseJSON && e.responseJSON.errors) ?
|
||||
I18n.t("generic_error_with_reason", {error: e.responseJSON.errors.join('. ')}) :
|
||||
const msg = (e.jqXHR.responseJSON && e.jqXHR.responseJSON.errors) ?
|
||||
I18n.t("generic_error_with_reason", {error: e.jqXHR.responseJSON.errors.join('. ')}) :
|
||||
I18n.t("generic_error");
|
||||
bootbox.alert(msg, () => this.$('.ip-address-input').focus());
|
||||
});
|
||||
|
|
|
@ -10,11 +10,21 @@ class ScreenedIpAddress < ActiveRecord::Base
|
|||
default_action :block
|
||||
|
||||
validates :ip_address, ip_address_format: true, presence: true
|
||||
after_validation :check_for_match
|
||||
|
||||
def self.watch(ip_address, opts = {})
|
||||
match_for_ip_address(ip_address) || create(opts.slice(:action_type).merge(ip_address: ip_address))
|
||||
end
|
||||
|
||||
def check_for_match
|
||||
unless self.errors[:ip_address].present?
|
||||
matched = self.class.match_for_ip_address(self.ip_address)
|
||||
if matched && matched.action_type == self.action_type
|
||||
self.errors.add(:ip_address, :ip_address_already_screened)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
# In Rails 4.0.0, validators are run to handle invalid assignments to inet columns (as they should).
|
||||
# In Rails 4.0.1, an exception is raised before validation happens, so we need this hack for
|
||||
# inet/cidr columns:
|
||||
|
|
|
@ -132,6 +132,7 @@ en:
|
|||
odd: must be odd
|
||||
record_invalid: ! 'Validation failed: %{errors}'
|
||||
max_emojis: "can't have more than %{max_emojis_count} emoji"
|
||||
ip_address_already_screened: "is already included in an existing rule"
|
||||
restrict_dependent_destroy:
|
||||
one: "Cannot delete record because a dependent %{record} exists"
|
||||
many: "Cannot delete record because dependent %{record} exist"
|
||||
|
|
|
@ -31,6 +31,13 @@ describe ScreenedIpAddress do
|
|||
described_class.new(valid_params.merge(action_name: nil))
|
||||
}.to raise_error(ArgumentError)
|
||||
end
|
||||
|
||||
it 'returns a useful error if ip address matches an existing record' do
|
||||
ScreenedIpAddress.create(ip_address: '2600:387:b:f::7a/128', action_name: :block)
|
||||
r = ScreenedIpAddress.new(ip_address: '2600:387:b:f::7a', action_name: :block)
|
||||
expect(r.save).to eq(false)
|
||||
expect(r.errors[:ip_address]).to be_present
|
||||
end
|
||||
end
|
||||
|
||||
describe "ip_address_with_mask" do
|
||||
|
|
Loading…
Reference in New Issue
Block a user