mirror of
https://github.com/internetee/registry.git
synced 2025-06-11 23:24:48 +02:00
REPP: Fix bulk domain transfer
This commit is contained in:
parent
e9c0d09b9f
commit
03d940a695
3 changed files with 91 additions and 32 deletions
77
app/models/actions/domain_transfer.rb
Normal file
77
app/models/actions/domain_transfer.rb
Normal file
|
@ -0,0 +1,77 @@
|
|||
module Actions
|
||||
class DomainTransfer
|
||||
attr_reader :domain
|
||||
attr_reader :transfer_code
|
||||
attr_reader :legal_document
|
||||
attr_reader :ident
|
||||
attr_reader :user
|
||||
|
||||
def initialize(domain, transfer_code, user)
|
||||
@domain = domain
|
||||
@transfer_code = transfer_code
|
||||
@user = user
|
||||
end
|
||||
|
||||
def call
|
||||
return unless domain_exists?
|
||||
return unless run_validations
|
||||
|
||||
#return domain.pending_transfer if domain.pending_transfer
|
||||
#attach_legal_document(::Deserializers::Xml::LegalDocument.new(frame).call)
|
||||
|
||||
return if domain.errors[:epp_errors].any?
|
||||
|
||||
commit
|
||||
end
|
||||
|
||||
def domain_exists?
|
||||
return true if domain.persisted?
|
||||
|
||||
domain.add_epp_error('2303', nil, nil, 'Object does not exist')
|
||||
|
||||
false
|
||||
end
|
||||
|
||||
def run_validations
|
||||
return unless validate_transfer_code
|
||||
return unless validate_registrar
|
||||
return unless validate_eligilibty
|
||||
return unless validate_not_discarded
|
||||
|
||||
true
|
||||
end
|
||||
|
||||
def validate_transfer_code
|
||||
return true if transfer_code == domain.transfer_code
|
||||
|
||||
domain.add_epp_error('2202', nil, nil, 'Invalid authorization information')
|
||||
false
|
||||
end
|
||||
|
||||
def validate_registrar
|
||||
return true unless user == domain.registrar
|
||||
|
||||
domain.add_epp_error('2002', nil, nil, I18n.t(:domain_already_belongs_to_the_querying_registrar))
|
||||
false
|
||||
end
|
||||
|
||||
def validate_eligilibty
|
||||
return true unless domain.non_transferable?
|
||||
|
||||
domain.add_epp_error('2304', nil, nil, 'Domain is not transferable??')
|
||||
false
|
||||
end
|
||||
|
||||
def validate_not_discarded
|
||||
return true unless domain.discarded?
|
||||
|
||||
domain.add_epp_error('2106', nil, nil, 'Object is not eligible for transfer')
|
||||
false
|
||||
end
|
||||
|
||||
def commit
|
||||
bare_domain = Domain.find(domain.id)
|
||||
::DomainTransfer.request(bare_domain, user)
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue