mirror of
https://github.com/internetee/registry.git
synced 2025-06-08 05:34:46 +02:00
Merge pull request #1848 from internetee/1844-delete-domains-with-update-prohibited
Allow domain deletion on *UpdateProhibited statuses
This commit is contained in:
commit
f16143f170
4 changed files with 57 additions and 4 deletions
|
@ -109,14 +109,12 @@ class DomainStatus < ApplicationRecord
|
||||||
DELETE_PROHIBIT_STATES = [
|
DELETE_PROHIBIT_STATES = [
|
||||||
DomainStatus::CLIENT_DELETE_PROHIBITED,
|
DomainStatus::CLIENT_DELETE_PROHIBITED,
|
||||||
DomainStatus::SERVER_DELETE_PROHIBITED,
|
DomainStatus::SERVER_DELETE_PROHIBITED,
|
||||||
DomainStatus::CLIENT_UPDATE_PROHIBITED,
|
|
||||||
DomainStatus::SERVER_UPDATE_PROHIBITED,
|
|
||||||
DomainStatus::PENDING_CREATE,
|
DomainStatus::PENDING_CREATE,
|
||||||
DomainStatus::PENDING_RENEW,
|
DomainStatus::PENDING_RENEW,
|
||||||
DomainStatus::PENDING_TRANSFER,
|
DomainStatus::PENDING_TRANSFER,
|
||||||
DomainStatus::PENDING_UPDATE,
|
DomainStatus::PENDING_UPDATE,
|
||||||
DomainStatus::PENDING_DELETE
|
DomainStatus::PENDING_DELETE
|
||||||
]
|
].freeze
|
||||||
|
|
||||||
def epp_code_map
|
def epp_code_map
|
||||||
{
|
{
|
||||||
|
|
|
@ -465,7 +465,7 @@ class Epp::Domain < Domain
|
||||||
def update(frame, current_user, verify = true)
|
def update(frame, current_user, verify = true)
|
||||||
return super if frame.blank?
|
return super if frame.blank?
|
||||||
|
|
||||||
if discarded?
|
if discarded? || statuses_blocks_update?
|
||||||
add_epp_error('2304', nil, nil, 'Object status prohibits operation')
|
add_epp_error('2304', nil, nil, 'Object status prohibits operation')
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
|
@ -133,6 +133,40 @@ class EppDomainDeleteBaseTest < EppTestCase
|
||||||
assert_epp_response :completed_successfully
|
assert_epp_response :completed_successfully
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_deletes_on_update_prohibited
|
||||||
|
assert_equal 'shop.test', @domain.name
|
||||||
|
@domain.update(statuses: [DomainStatus::SERVER_UPDATE_PROHIBITED])
|
||||||
|
Setting.request_confirmation_on_domain_deletion_enabled = false
|
||||||
|
|
||||||
|
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>
|
||||||
|
<delete>
|
||||||
|
<domain:delete xmlns:domain="https://epp.tld.ee/schema/domain-eis-1.0.xsd">
|
||||||
|
<domain:name>shop.test</domain:name>
|
||||||
|
</domain:delete>
|
||||||
|
</delete>
|
||||||
|
<extension>
|
||||||
|
<eis:extdata xmlns:eis="https://epp.tld.ee/schema/eis-1.0.xsd">
|
||||||
|
<eis:legalDocument type="pdf">#{'test' * 2000}</eis:legalDocument>
|
||||||
|
</eis:extdata>
|
||||||
|
</extension>
|
||||||
|
</command>
|
||||||
|
</epp>
|
||||||
|
XML
|
||||||
|
|
||||||
|
perform_enqueued_jobs do
|
||||||
|
post epp_delete_path, params: { frame: request_xml }, headers: { 'HTTP_COOKIE' => 'session=api_bestnames' }
|
||||||
|
end
|
||||||
|
@domain.reload
|
||||||
|
|
||||||
|
assert_not @domain.registrant_verification_asked?
|
||||||
|
assert_not @domain.pending_delete_confirmation?
|
||||||
|
assert_no_emails
|
||||||
|
assert_epp_response :completed_successfully
|
||||||
|
end
|
||||||
|
|
||||||
def test_skips_registrant_confirmation_when_required_but_already_verified_by_registrar
|
def test_skips_registrant_confirmation_when_required_but_already_verified_by_registrar
|
||||||
assert_equal 'shop.test', @domain.name
|
assert_equal 'shop.test', @domain.name
|
||||||
Setting.request_confirmation_on_domain_deletion_enabled = true
|
Setting.request_confirmation_on_domain_deletion_enabled = true
|
||||||
|
|
|
@ -62,6 +62,27 @@ class EppDomainUpdateBaseTest < EppTestCase
|
||||||
assert_epp_response :object_status_prohibits_operation
|
assert_epp_response :object_status_prohibits_operation
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_prohibited_domain_cannot_be_updated
|
||||||
|
@domain.update!(statuses: [DomainStatus::SERVER_UPDATE_PROHIBITED])
|
||||||
|
|
||||||
|
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>
|
||||||
|
<domain:update xmlns:domain="https://epp.tld.ee/schema/domain-eis-1.0.xsd">
|
||||||
|
<domain:name>shop.test</domain:name>
|
||||||
|
</domain:update>
|
||||||
|
</update>
|
||||||
|
</command>
|
||||||
|
</epp>
|
||||||
|
XML
|
||||||
|
|
||||||
|
post epp_update_path, params: { frame: request_xml },
|
||||||
|
headers: { 'HTTP_COOKIE' => 'session=api_bestnames' }
|
||||||
|
assert_epp_response :object_status_prohibits_operation
|
||||||
|
end
|
||||||
|
|
||||||
def test_does_not_return_server_delete_prohibited_status_when_pending_update_status_is_set
|
def test_does_not_return_server_delete_prohibited_status_when_pending_update_status_is_set
|
||||||
@domain.update!(statuses: [DomainStatus::SERVER_DELETE_PROHIBITED,
|
@domain.update!(statuses: [DomainStatus::SERVER_DELETE_PROHIBITED,
|
||||||
DomainStatus::PENDING_UPDATE])
|
DomainStatus::PENDING_UPDATE])
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue