Deny contact ident modification on EPP contact:update

#569
This commit is contained in:
Artur Beljajev 2017-07-21 02:29:54 +03:00
parent 729a9b00d2
commit 06e080ed43
2 changed files with 53 additions and 2 deletions

View file

@ -174,6 +174,10 @@ class Epp::Contact < Contact
self.ident_updated_at ||= Time.zone.now self.ident_updated_at ||= Time.zone.now
ident_frame = frame.css('ident').first ident_frame = frame.css('ident').first
if ident_frame.text.present?
deny_ident_update
end
if ident_frame && ident_attr_valid?(ident_frame) if ident_frame && ident_attr_valid?(ident_frame)
org_priv = %w(org priv).freeze org_priv = %w(org priv).freeze
if ident_country_code.blank? && org_priv.include?(ident_type) && org_priv.include?(ident_frame.attr('type')) if ident_country_code.blank? && org_priv.include?(ident_type) && org_priv.include?(ident_frame.attr('type'))
@ -187,10 +191,10 @@ class Epp::Contact < Contact
at.merge!(ident_type: ident_frame.attr('type')) at.merge!(ident_type: ident_frame.attr('type'))
at.merge!(ident_country_code: ident_frame.attr('cc')) if ident_frame.attr('cc').present? at.merge!(ident_country_code: ident_frame.attr('cc')) if ident_frame.attr('cc').present?
else else
throw :epp_error, {code: '2306', msg: I18n.t(:ident_update_error)} deny_ident_update
end end
else else
throw :epp_error, {code: '2306', msg: I18n.t(:ident_update_error)} deny_ident_update
end end
end end
@ -259,4 +263,9 @@ class Epp::Contact < Contact
self.legal_document_id = doc.id self.legal_document_id = doc.id
end end
private
def deny_ident_update
throw :epp_error, { code: '2306', msg: I18n.t(:ident_update_error) }
end
end end

View file

@ -0,0 +1,42 @@
require 'rails_helper'
RSpec.describe 'EPP contact:update' do
let(:request) { post '/epp/command/update', frame: request_xml }
let(:request_xml) { <<-XML
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<epp xmlns="https://epp.tld.ee/schema/epp-ee-1.0.xsd">
<command>
<update>
<contact:update xmlns:contact="https://epp.tld.ee/schema/contact-ee-1.1.xsd">
<contact:id>TEST</contact:id>
<contact:chg>
<contact:postalInfo>
<contact:name>test</contact:name>
</contact:postalInfo>
</contact:chg>
</contact:update>
</update>
<extension>
<eis:extdata xmlns:eis="https://epp.tld.ee/schema/eis-1.0.xsd">
<eis:ident cc="US" type="org">test</eis:ident>
</eis:extdata>
</extension>
</command>
</epp>
XML
}
before do
sign_in_to_epp_area
end
context 'when :ident tag is given and a contact has been imported from legacy software' do
let(:contact) { build(:contact, code: 'TEST', ident: nil, ident_type: nil, ident_country_code: nil) }
specify do
contact.save(validate: false)
request
expect(response).to have_code_of(2306)
end
end
end