mirror of
https://github.com/internetee/registry.git
synced 2025-06-07 13:15:40 +02:00
Merge branch 'master' of https://github.com/internetee/registry into 1857-covered-registry-by-tests
This commit is contained in:
commit
ad391e1b8c
13 changed files with 207 additions and 24 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
11.02.2021
|
||||||
|
* Poll messages on locking and unlocking a domain [#1828](https://github.com/internetee/registry/issues/1828)
|
||||||
|
* Registrar's prefix is now checked and added to contact id for info and check requests [#1832](https://github.com/internetee/registry/issues/1832)
|
||||||
|
|
||||||
10.02.2021
|
10.02.2021
|
||||||
* Admin contact bulk change option for registrars [#1764](https://github.com/internetee/registry/issues/1764)
|
* Admin contact bulk change option for registrars [#1764](https://github.com/internetee/registry/issues/1764)
|
||||||
* Option to remove email addresses from AWS SES Supression list [#1839](https://github.com/internetee/registry/issues/1839)
|
* Option to remove email addresses from AWS SES Supression list [#1839](https://github.com/internetee/registry/issues/1839)
|
||||||
|
|
|
@ -14,7 +14,7 @@ module Epp
|
||||||
authorize! :check, Epp::Contact
|
authorize! :check, Epp::Contact
|
||||||
|
|
||||||
ids = params[:parsed_frame].css('id').map(&:text)
|
ids = params[:parsed_frame].css('id').map(&:text)
|
||||||
@results = Epp::Contact.check_availability(ids)
|
@results = Epp::Contact.check_availability(ids, reg: current_user.registrar.code)
|
||||||
render_epp_response '/epp/contacts/check'
|
render_epp_response '/epp/contacts/check'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -93,7 +93,11 @@ module Epp
|
||||||
|
|
||||||
def find_contact
|
def find_contact
|
||||||
code = params[:parsed_frame].css('id').text.strip.upcase
|
code = params[:parsed_frame].css('id').text.strip.upcase
|
||||||
@contact = Epp::Contact.find_by!(code: code)
|
reg_code = current_user.registrar.code.upcase
|
||||||
|
arr = [code, "#{reg_code}:#{code}", "CID:#{code}", "CID:#{reg_code}:#{code}"]
|
||||||
|
|
||||||
|
contact = arr.find { |c| Epp::Contact.find_by(code: c).present? }
|
||||||
|
@contact = Epp::Contact.find_by!(code: contact || code)
|
||||||
end
|
end
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -12,6 +12,7 @@ module Concerns
|
||||||
statuses << DomainStatus::SERVER_DELETE_PROHIBITED
|
statuses << DomainStatus::SERVER_DELETE_PROHIBITED
|
||||||
statuses << DomainStatus::SERVER_TRANSFER_PROHIBITED
|
statuses << DomainStatus::SERVER_TRANSFER_PROHIBITED
|
||||||
self.locked_by_registrant_at = Time.zone.now
|
self.locked_by_registrant_at = Time.zone.now
|
||||||
|
alert_registrar_lock_changes!(lock: true)
|
||||||
|
|
||||||
save!
|
save!
|
||||||
end
|
end
|
||||||
|
@ -42,10 +43,21 @@ module Concerns
|
||||||
statuses.delete(DomainStatus::SERVER_DELETE_PROHIBITED)
|
statuses.delete(DomainStatus::SERVER_DELETE_PROHIBITED)
|
||||||
statuses.delete(DomainStatus::SERVER_TRANSFER_PROHIBITED)
|
statuses.delete(DomainStatus::SERVER_TRANSFER_PROHIBITED)
|
||||||
self.locked_by_registrant_at = nil
|
self.locked_by_registrant_at = nil
|
||||||
|
alert_registrar_lock_changes!(lock: false)
|
||||||
|
|
||||||
save!
|
save!
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def alert_registrar_lock_changes!(lock: true)
|
||||||
|
translation = lock ? 'locked' : 'unlocked'
|
||||||
|
registrar.notifications.create!(
|
||||||
|
text: I18n.t("notifications.texts.registrar_#{translation}",
|
||||||
|
domain_name: name),
|
||||||
|
attached_obj_id: name,
|
||||||
|
attached_obj_type: self.class.name
|
||||||
|
)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -42,17 +42,12 @@ class Epp::Contact < Contact
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
def check_availability(codes)
|
def check_availability(codes, reg:)
|
||||||
codes = [codes] if codes.is_a?(String)
|
codes = [codes] if codes.is_a?(String)
|
||||||
|
|
||||||
res = []
|
res = []
|
||||||
codes.each do |x|
|
codes.map { |c| c.include?(':') ? c : "#{reg}:#{c}" }.map { |c| c.strip.upcase }.each do |x|
|
||||||
contact = find_by_epp_code(x)
|
c = find_by_epp_code(x)
|
||||||
if contact
|
res << (c ? { code: c.code, avail: 0, reason: 'in use' } : { code: x, avail: 1 })
|
||||||
res << { code: contact.code, avail: 0, reason: 'in use' }
|
|
||||||
else
|
|
||||||
res << { code: x, avail: 1 }
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
res
|
res
|
||||||
|
|
|
@ -25,6 +25,10 @@ class Notification < ApplicationRecord
|
||||||
''
|
''
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def registry_lock?
|
||||||
|
text.include?('has been locked') || text.include?('has been unlocked')
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def set_defaults
|
def set_defaults
|
||||||
|
|
|
@ -97,7 +97,9 @@ class WhoisRecord < ApplicationRecord
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy_whois_record
|
def destroy_whois_record
|
||||||
Whois::Record.without_auctions.where(name: name).delete_all
|
return if Auction.find_by(domain: name).present?
|
||||||
|
|
||||||
|
Whois::Record.where(name: name).delete_all
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
|
@ -15,12 +15,22 @@ xml.epp_head do
|
||||||
end if @object
|
end if @object
|
||||||
end
|
end
|
||||||
|
|
||||||
if @notification.action&.contact
|
if @notification.action&.contact || @notification.registry_lock?
|
||||||
render(partial: 'epp/poll/action',
|
if @notification.registry_lock?
|
||||||
locals: {
|
state = @notification.text.include?('unlocked') ? 'unlock' : 'lock'
|
||||||
builder: xml,
|
xml.extension do
|
||||||
action: @notification.action
|
xml.tag!('changePoll:changeData',
|
||||||
})
|
'xmlns:changePoll': 'https://epp.tld.ee/schema/changePoll-1.0.xsd') do
|
||||||
|
xml.tag!('changePoll:operation', state)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else
|
||||||
|
render(partial: 'epp/poll/action',
|
||||||
|
locals: {
|
||||||
|
builder: xml,
|
||||||
|
action: @notification.action,
|
||||||
|
})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
render('epp/shared/trID', builder: xml)
|
render('epp/shared/trID', builder: xml)
|
||||||
|
|
|
@ -6,3 +6,5 @@ en:
|
||||||
It was associated with registrant %{old_registrant_code}
|
It was associated with registrant %{old_registrant_code}
|
||||||
and contacts %{old_contacts_codes}.
|
and contacts %{old_contacts_codes}.
|
||||||
contact_update: Contact %{contact} has been updated by registrant
|
contact_update: Contact %{contact} has been updated by registrant
|
||||||
|
registrar_locked: Domain %{domain_name} has been locked by registrant
|
||||||
|
registrar_unlocked: Domain %{domain_name} has been unlocked by registrant
|
||||||
|
|
30
doc/repp/v1/admin_contacts.md
Normal file
30
doc/repp/v1/admin_contacts.md
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
# Admin domain contacts
|
||||||
|
|
||||||
|
## PATCH https://repp.internet.ee/v1/domains/admin_contacts
|
||||||
|
Replaces admin domain contacts of the current registrar.
|
||||||
|
|
||||||
|
### Example request
|
||||||
|
```
|
||||||
|
PATCH /repp/v1/domains/admin_contacts HTTP/1.1
|
||||||
|
Accept: application/json
|
||||||
|
Content-Type: application/json
|
||||||
|
Authorization: Basic dGVzdDp0ZXN0dGVzdA==
|
||||||
|
|
||||||
|
{
|
||||||
|
"current_contact_id": "ATSAA:749AA80F",
|
||||||
|
"new_contact_id": "ATSAA:E36957D7"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
### Example response
|
||||||
|
```
|
||||||
|
{
|
||||||
|
"code": 1000,
|
||||||
|
"message": "Command completed successfully",
|
||||||
|
"data": {
|
||||||
|
"affected_domains": [
|
||||||
|
"private.ee",
|
||||||
|
],
|
||||||
|
"skipped_domains": []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
|
@ -1,7 +1,7 @@
|
||||||
# Domain contacts
|
# Tech domain contacts
|
||||||
|
|
||||||
## PATCH https://repp.internet.ee/v1/domains/contacts
|
## PATCH https://repp.internet.ee/v1/domains/contacts
|
||||||
Replaces all domain contacts of the current registrar.
|
Replaces technical domain contacts of the current registrar.
|
||||||
|
|
||||||
### Example request
|
### Example request
|
||||||
```
|
```
|
||||||
|
|
|
@ -26,7 +26,7 @@ class EppContactCheckBaseTest < EppTestCase
|
||||||
|
|
||||||
response_xml = Nokogiri::XML(response.body)
|
response_xml = Nokogiri::XML(response.body)
|
||||||
assert_epp_response :completed_successfully
|
assert_epp_response :completed_successfully
|
||||||
assert_equal 'john-001', response_xml.at_xpath('//contact:id', contact: xml_schema).text
|
assert_equal "#{@contact.registrar.code}:JOHN-001".upcase, response_xml.at_xpath('//contact:id', contact: xml_schema).text
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_contact_is_available
|
def test_contact_is_available
|
||||||
|
@ -52,7 +52,8 @@ class EppContactCheckBaseTest < EppTestCase
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_contact_is_unavailable
|
def test_contact_is_unavailable
|
||||||
assert_equal 'john-001', @contact.code
|
@contact.update_columns(code: "#{@contact.registrar.code}:JOHN-001".upcase)
|
||||||
|
assert @contact.code, "#{@contact.registrar.code}:JOHN-001".upcase
|
||||||
|
|
||||||
request_xml = <<-XML
|
request_xml = <<-XML
|
||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
@ -98,6 +99,58 @@ class EppContactCheckBaseTest < EppTestCase
|
||||||
assert_equal 3, response_xml.xpath('//contact:cd', contact: xml_schema).size
|
assert_equal 3, response_xml.xpath('//contact:cd', contact: xml_schema).size
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_check_contact_with_prefix
|
||||||
|
@contact.update_columns(code: "#{@contact.registrar.code}:JOHN-001".upcase)
|
||||||
|
assert @contact.code, "#{@contact.registrar.code}:JOHN-001".upcase
|
||||||
|
|
||||||
|
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>
|
||||||
|
<check>
|
||||||
|
<contact:check xmlns:contact="https://epp.tld.ee/schema/contact-ee-1.1.xsd">
|
||||||
|
<contact:id>BESTNAMES:JOHN-001</contact:id>
|
||||||
|
</contact:check>
|
||||||
|
</check>
|
||||||
|
</command>
|
||||||
|
</epp>
|
||||||
|
XML
|
||||||
|
|
||||||
|
post epp_check_path, params: { frame: request_xml },
|
||||||
|
headers: { 'HTTP_COOKIE' => 'session=api_bestnames' }
|
||||||
|
|
||||||
|
response_xml = Nokogiri::XML(response.body)
|
||||||
|
assert_epp_response :completed_successfully
|
||||||
|
assert_equal "#{@contact.registrar.code}:JOHN-001".upcase, response_xml.at_xpath('//contact:id', contact: xml_schema).text
|
||||||
|
assert_equal 'in use', response_xml.at_xpath('//contact:reason', contact: xml_schema).text
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_check_contact_without_prefix
|
||||||
|
@contact.update_columns(code: "#{@contact.registrar.code}:JOHN-001".upcase)
|
||||||
|
assert @contact.code, "#{@contact.registrar.code}:JOHN-001".upcase
|
||||||
|
|
||||||
|
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>
|
||||||
|
<check>
|
||||||
|
<contact:check xmlns:contact="https://epp.tld.ee/schema/contact-ee-1.1.xsd">
|
||||||
|
<contact:id>JOHN-001</contact:id>
|
||||||
|
</contact:check>
|
||||||
|
</check>
|
||||||
|
</command>
|
||||||
|
</epp>
|
||||||
|
XML
|
||||||
|
|
||||||
|
post epp_check_path, params: { frame: request_xml },
|
||||||
|
headers: { 'HTTP_COOKIE' => 'session=api_bestnames' }
|
||||||
|
|
||||||
|
response_xml = Nokogiri::XML(response.body)
|
||||||
|
assert_epp_response :completed_successfully
|
||||||
|
assert_equal "#{@contact.registrar.code}:JOHN-001".upcase, response_xml.at_xpath('//contact:id', contact: xml_schema).text
|
||||||
|
assert_equal 'in use', response_xml.at_xpath('//contact:reason', contact: xml_schema).text
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def xml_schema
|
def xml_schema
|
||||||
|
|
|
@ -44,6 +44,58 @@ class EppContactInfoBaseTest < EppTestCase
|
||||||
contact: xml_schema).text
|
contact: xml_schema).text
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_get_info_about_contact_with_prefix
|
||||||
|
@contact.update_columns(code: 'TEST:JOHN-001')
|
||||||
|
assert @contact.code, 'TEST:JOHN-001'
|
||||||
|
|
||||||
|
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>
|
||||||
|
<info>
|
||||||
|
<contact:info xmlns:contact="https://epp.tld.ee/schema/contact-ee-1.1.xsd">
|
||||||
|
<contact:id>TEST:JOHN-001</contact:id>
|
||||||
|
</contact:info>
|
||||||
|
</info>
|
||||||
|
</command>
|
||||||
|
</epp>
|
||||||
|
XML
|
||||||
|
|
||||||
|
post epp_info_path, params: { frame: request_xml },
|
||||||
|
headers: { 'HTTP_COOKIE' => 'session=api_bestnames' }
|
||||||
|
|
||||||
|
response_xml = Nokogiri::XML(response.body)
|
||||||
|
assert_epp_response :completed_successfully
|
||||||
|
assert_equal 'TEST:JOHN-001', response_xml.at_xpath('//contact:id', contact: xml_schema).text
|
||||||
|
assert_equal '+555.555', response_xml.at_xpath('//contact:voice', contact: xml_schema).text
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_get_info_about_contact_without_prefix
|
||||||
|
@contact.update_columns(code: "#{@contact.registrar.code}:JOHN-001".upcase)
|
||||||
|
assert @contact.code, "#{@contact.registrar.code}:JOHN-001".upcase
|
||||||
|
|
||||||
|
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>
|
||||||
|
<info>
|
||||||
|
<contact:info xmlns:contact="https://epp.tld.ee/schema/contact-ee-1.1.xsd">
|
||||||
|
<contact:id>JOHN-001</contact:id>
|
||||||
|
</contact:info>
|
||||||
|
</info>
|
||||||
|
</command>
|
||||||
|
</epp>
|
||||||
|
XML
|
||||||
|
|
||||||
|
post epp_info_path, params: { frame: request_xml },
|
||||||
|
headers: { 'HTTP_COOKIE' => 'session=api_bestnames' }
|
||||||
|
|
||||||
|
response_xml = Nokogiri::XML(response.body)
|
||||||
|
assert_epp_response :completed_successfully
|
||||||
|
assert_equal "#{@contact.registrar.code}:JOHN-001".upcase, response_xml.at_xpath('//contact:id', contact: xml_schema).text
|
||||||
|
assert_equal '+555.555', response_xml.at_xpath('//contact:voice', contact: xml_schema).text
|
||||||
|
end
|
||||||
|
|
||||||
def test_hides_password_and_name_when_current_registrar_is_not_sponsoring
|
def test_hides_password_and_name_when_current_registrar_is_not_sponsoring
|
||||||
non_sponsoring_registrar = registrars(:goodnames)
|
non_sponsoring_registrar = registrars(:goodnames)
|
||||||
@contact.update!(registrar: non_sponsoring_registrar)
|
@contact.update!(registrar: non_sponsoring_registrar)
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
require "test_helper"
|
require "test_helper"
|
||||||
|
|
||||||
class DomainUpdateConfirmJobTest < ActiveSupport::TestCase
|
class DomainUpdateConfirmJobTest < ActiveSupport::TestCase
|
||||||
def setup
|
def setup
|
||||||
super
|
super
|
||||||
|
@ -19,6 +18,22 @@ class DomainUpdateConfirmJobTest < ActiveSupport::TestCase
|
||||||
super
|
super
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_registrant_locked_domain
|
||||||
|
refute @domain.locked_by_registrant?
|
||||||
|
@domain.apply_registry_lock
|
||||||
|
assert @domain.locked_by_registrant?
|
||||||
|
assert_equal(@domain.registrar.notifications.last.text, "Domain #{@domain.name} has been locked by registrant")
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_registrant_unlocked_domain
|
||||||
|
refute @domain.locked_by_registrant?
|
||||||
|
@domain.apply_registry_lock
|
||||||
|
assert @domain.locked_by_registrant?
|
||||||
|
@domain.remove_registry_lock
|
||||||
|
refute @domain.locked_by_registrant?
|
||||||
|
assert_equal(@domain.registrar.notifications.last.text, "Domain #{@domain.name} has been unlocked by registrant")
|
||||||
|
end
|
||||||
|
|
||||||
def test_rejected_registrant_verification_notifies_registrar
|
def test_rejected_registrant_verification_notifies_registrar
|
||||||
DomainUpdateConfirmJob.perform_now(@domain.id, RegistrantVerification::REJECTED)
|
DomainUpdateConfirmJob.perform_now(@domain.id, RegistrantVerification::REJECTED)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue