mirror of
https://github.com/internetee/registry.git
synced 2025-05-16 17:37:17 +02:00
1104 lines
40 KiB
Ruby
1104 lines
40 KiB
Ruby
require 'rails_helper'
|
|
|
|
describe 'EPP Domain', epp: true do
|
|
let(:server_zone) { Epp::Server.new({ server: 'localhost', tag: 'zone', password: 'ghyt9e4fu', port: 701 }) }
|
|
let(:server_elkdata) { Epp::Server.new({ server: 'localhost', tag: 'elkdata', password: 'ghyt9e4fu', port: 701 }) }
|
|
let(:elkdata) { Fabricate(:registrar, { name: 'Elkdata', reg_no: '123' }) }
|
|
let(:zone) { Fabricate(:registrar) }
|
|
|
|
before(:each) { create_settings }
|
|
|
|
context 'with valid user' do
|
|
before(:each) do
|
|
Fabricate(:epp_user, username: 'zone', registrar: zone)
|
|
Fabricate(:epp_user, username: 'elkdata', registrar: elkdata)
|
|
end
|
|
|
|
it 'returns error if contact does not exists' do
|
|
Fabricate(:contact, code: 'jd1234')
|
|
|
|
response = epp_request(domain_create_xml, :xml)
|
|
|
|
expect(response[:results][0][:result_code]).to eq('2303')
|
|
expect(response[:results][0][:msg]).to eq('Contact was not found')
|
|
expect(response[:results][0][:value]).to eq('sh8013')
|
|
|
|
expect(response[:results][1][:result_code]).to eq('2303')
|
|
expect(response[:results][1][:msg]).to eq('Contact was not found')
|
|
expect(response[:results][1][:value]).to eq('sh801333')
|
|
|
|
expect(response[:clTRID]).to eq('ABC-12345')
|
|
end
|
|
|
|
context 'with two epp users' do
|
|
let(:domain) { Domain.first }
|
|
|
|
before(:each) do
|
|
Fabricate(:domain, name: 'example.ee', registrar: zone)
|
|
end
|
|
|
|
it 'can not see other registrar domains' do
|
|
response = epp_request(domain_info_xml, :xml, :elkdata)
|
|
expect(response[:result_code]).to eq('2302')
|
|
expect(response[:msg]).to eq('Domain exists but belongs to other registrar')
|
|
end
|
|
|
|
it 'transfers a domain' do
|
|
pw = domain.auth_info
|
|
xml = domain_transfer_xml(pw: pw)
|
|
response = epp_request(xml, :xml, :elkdata)
|
|
|
|
domain.reload
|
|
dtl = domain.domain_transfers.last
|
|
|
|
trn_data = response[:parsed].css('trnData')
|
|
expect(trn_data.css('name').text).to eq('example.ee')
|
|
expect(trn_data.css('trStatus').text).to eq('serverApproved')
|
|
expect(trn_data.css('reID').text).to eq('123')
|
|
expect(trn_data.css('reDate').text).to eq(dtl.transfer_requested_at.to_time.utc.to_s)
|
|
expect(trn_data.css('acID').text).to eq('10577829')
|
|
expect(trn_data.css('acDate').text).to eq(dtl.transferred_at.to_time.utc.to_s)
|
|
expect(trn_data.css('exDate').text).to eq(domain.valid_to.to_time.utc.to_s)
|
|
|
|
expect(domain.registrar).to eq(elkdata)
|
|
|
|
Setting.transfer_wait_time = 1
|
|
|
|
domain.reload
|
|
pw = domain.auth_info
|
|
xml = domain_transfer_xml(pw: pw) # request with new password
|
|
|
|
response = epp_request(xml, :xml, :zone)
|
|
trn_data = response[:parsed].css('trnData')
|
|
|
|
domain.reload
|
|
dtl = domain.domain_transfers.last
|
|
|
|
expect(domain.domain_transfers.count).to eq(2)
|
|
|
|
expect(trn_data.css('name').text).to eq('example.ee')
|
|
expect(trn_data.css('trStatus').text).to eq('pending')
|
|
expect(trn_data.css('reID').text).to eq('10577829')
|
|
expect(trn_data.css('reDate').text).to eq(dtl.transfer_requested_at.to_time.utc.to_s)
|
|
expect(trn_data.css('acDate').text).to eq(dtl.wait_until.to_time.utc.to_s)
|
|
expect(trn_data.css('acID').text).to eq('123')
|
|
expect(trn_data.css('exDate').text).to eq(domain.valid_to.to_time.utc.to_s)
|
|
|
|
expect(domain.registrar).to eq(elkdata)
|
|
|
|
# should return same data if pending already
|
|
response = epp_request(xml, :xml, :zone)
|
|
trn_data = response[:parsed].css('trnData')
|
|
|
|
expect(domain.domain_transfers.count).to eq(2)
|
|
expect(trn_data.css('name').text).to eq('example.ee')
|
|
expect(trn_data.css('trStatus').text).to eq('pending')
|
|
expect(trn_data.css('reID').text).to eq('10577829')
|
|
expect(trn_data.css('reDate').text).to eq(dtl.transfer_requested_at.to_time.utc.to_s)
|
|
expect(trn_data.css('acDate').text).to eq(dtl.wait_until.to_time.utc.to_s)
|
|
expect(trn_data.css('acID').text).to eq('123')
|
|
expect(trn_data.css('exDate').text).to eq(domain.valid_to.to_time.utc.to_s)
|
|
|
|
expect(domain.registrar).to eq(elkdata)
|
|
end
|
|
|
|
it 'prohibits wrong registrar from approving transfer' do
|
|
domain.domain_transfers.create({
|
|
status: DomainTransfer::PENDING,
|
|
transfer_requested_at: Time.zone.now,
|
|
transfer_to: elkdata,
|
|
transfer_from: zone
|
|
})
|
|
|
|
xml = domain_transfer_xml(pw: domain.auth_info, op: 'approve')
|
|
response = epp_request(xml, :xml, :elkdata)
|
|
expect(response[:result_code]).to eq('2304')
|
|
expect(response[:msg]).to eq('Transfer can be approved only by current domain registrar')
|
|
end
|
|
|
|
it 'approves the transfer request' do
|
|
domain.domain_transfers.create({
|
|
status: DomainTransfer::PENDING,
|
|
transfer_requested_at: Time.zone.now,
|
|
transfer_to: elkdata,
|
|
transfer_from: zone
|
|
})
|
|
|
|
xml = domain_transfer_xml(pw: domain.auth_info, op: 'approve')
|
|
response = epp_request(xml, :xml, :zone)
|
|
domain.reload
|
|
dtl = domain.domain_transfers.last
|
|
|
|
trn_data = response[:parsed].css('trnData')
|
|
|
|
expect(trn_data.css('name').text).to eq('example.ee')
|
|
expect(trn_data.css('trStatus').text).to eq('clientApproved')
|
|
expect(trn_data.css('reID').text).to eq('123')
|
|
expect(trn_data.css('reDate').text).to eq(dtl.transfer_requested_at.to_time.utc.to_s)
|
|
expect(trn_data.css('acID').text).to eq('10577829')
|
|
expect(trn_data.css('exDate').text).to eq(domain.valid_to.to_time.utc.to_s)
|
|
end
|
|
|
|
it 'does not transfer with invalid pw' do
|
|
response = epp_request(domain_transfer_xml(pw: 'test'), :xml)
|
|
expect(response[:result_code]).to eq('2200')
|
|
expect(response[:msg]).to eq('Authentication error')
|
|
end
|
|
|
|
it 'ignores transfer when owner registrar requests transfer' do
|
|
pw = domain.auth_info
|
|
xml = domain_transfer_xml(pw: pw)
|
|
response = epp_request(xml, :xml, :zone)
|
|
|
|
expect(response[:result_code]).to eq('2002')
|
|
expect(response[:msg]).to eq('Domain already belongs to the querying registrar')
|
|
end
|
|
|
|
it 'returns an error for incorrect op attribute' do
|
|
response = epp_request(domain_transfer_xml(op: 'bla'), :xml, :zone)
|
|
expect(response[:result_code]).to eq('2306')
|
|
expect(response[:msg]).to eq('Attribute op is invalid')
|
|
end
|
|
|
|
it 'creates new pw after successful transfer' do
|
|
pw = domain.auth_info
|
|
xml = domain_transfer_xml(pw: pw)
|
|
epp_request(xml, :xml, :elkdata) # transfer domain
|
|
response = epp_request(xml, :xml, :elkdata) # attempt second transfer
|
|
expect(response[:result_code]).to eq('2200')
|
|
expect(response[:msg]).to eq('Authentication error')
|
|
end
|
|
end
|
|
|
|
context 'with citizen as an owner' do
|
|
before(:each) do
|
|
Fabricate(:contact, code: 'jd1234')
|
|
Fabricate(:contact, code: 'sh8013')
|
|
Fabricate(:contact, code: 'sh801333')
|
|
end
|
|
|
|
it 'creates a domain' do
|
|
response = epp_request(domain_create_xml, :xml)
|
|
d = Domain.first
|
|
|
|
expect(response[:result_code]).to eq('1000')
|
|
expect(response[:msg]).to eq('Command completed successfully')
|
|
|
|
cre_data = response[:parsed].css('creData')
|
|
|
|
expect(cre_data.css('name').text).to eq('example.ee')
|
|
expect(cre_data.css('crDate').text).to eq(d.created_at.to_time.utc.to_s)
|
|
expect(cre_data.css('exDate').text).to eq(d.valid_to.to_time.utc.to_s)
|
|
|
|
expect(response[:clTRID]).to eq('ABC-12345')
|
|
|
|
expect(d.registrar.name).to eq('Zone Media OÜ')
|
|
expect(d.tech_contacts.count).to eq 2
|
|
expect(d.admin_contacts.count).to eq 1
|
|
|
|
expect(d.nameservers.count).to eq(2)
|
|
expect(d.auth_info).not_to be_empty
|
|
|
|
expect(d.dnskeys.count).to eq(1)
|
|
|
|
key = d.dnskeys.first
|
|
|
|
expect(key.ds_alg).to eq(3)
|
|
expect(key.ds_key_tag).to_not be_blank
|
|
|
|
expect(key.ds_digest_type).to eq(Setting.ds_algorithm)
|
|
expect(key.flags).to eq(257)
|
|
expect(key.protocol).to eq(3)
|
|
expect(key.alg).to eq(5)
|
|
expect(key.public_key).to eq('AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8')
|
|
end
|
|
|
|
it 'creates ria.ee with valid ds record' do
|
|
xml = domain_create_xml({
|
|
name: { value: 'ria.ee' }
|
|
}, {
|
|
_other: [
|
|
{ keyData: {
|
|
flags: { value: '257' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '8' },
|
|
pubKey: { value: 'AwEAAaOf5+lz3ftsL+0CCvfJbhUF/NVsNh8BKo61oYs5fXVbuWDiH872 '\
|
|
'LC8uKDO92TJy7Q4TF9XMAKMMlf1GMAxlRspD749SOCTN00sqfWx1OMTu '\
|
|
'a28L1PerwHq7665oDJDKqR71btcGqyLKhe2QDvCdA0mENimF1NudX1BJ '\
|
|
'DDFi6oOZ0xE/0CuveB64I3ree7nCrwLwNs56kXC4LYoX3XdkOMKiJLL/ '\
|
|
'MAhcxXa60CdZLoRtTEW3z8/oBq4hEAYMCNclpbd6y/exScwBxFTdUfFk '\
|
|
'KsdNcmvai1lyk9vna0WQrtpYpHKMXvY9LFHaJxCOLR4umfeQ42RuTd82 lqfU6ClMeXs=' }
|
|
}
|
|
}
|
|
]
|
|
})
|
|
|
|
epp_request(xml, :xml)
|
|
d = Domain.first
|
|
ds = d.dnskeys.first
|
|
expect(ds.ds_digest).to eq('0B62D1BC64EFD1EE652FB102BDF1011BF514CCD9A1A0CFB7472AEA3B01F38C92')
|
|
end
|
|
|
|
it 'validates nameserver ipv4 when in same zone as domain' do
|
|
xml = domain_create_xml({
|
|
ns: [
|
|
{ hostObj: { value: 'ns1.example.ee' } },
|
|
{ hostObj: { value: 'ns2.example.ee' } }
|
|
]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2306')
|
|
expect(response[:msg]).to eq('IPv4 is missing')
|
|
end
|
|
|
|
it 'does not create duplicate domain' do
|
|
epp_request(domain_create_xml, :xml)
|
|
response = epp_request(domain_create_xml, :xml)
|
|
expect(response[:result_code]).to eq('2302')
|
|
expect(response[:msg]).to eq('Domain name already exists')
|
|
expect(response[:clTRID]).to eq('ABC-12345')
|
|
end
|
|
|
|
it 'does not create reserved domain' do
|
|
Fabricate(:reserved_domain)
|
|
|
|
xml = domain_create_xml(name: { value: '1162.ee' })
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2302')
|
|
expect(response[:msg]).to eq('Domain name is reserved or restricted')
|
|
expect(response[:clTRID]).to eq('ABC-12345')
|
|
end
|
|
|
|
it 'does not create domain without contacts and registrant' do
|
|
xml = domain_create_xml(contacts: [], registrant: false)
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2003')
|
|
expect(response[:results][0][:msg]).to eq('Required parameter missing: registrant')
|
|
end
|
|
|
|
it 'does not create domain without nameservers' do
|
|
xml = domain_create_xml(ns: [])
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2003')
|
|
expect(response[:msg]).to eq('Required parameter missing: ns')
|
|
end
|
|
|
|
it 'does not create domain with too many nameservers' do
|
|
nameservers = []
|
|
14.times { |i| nameservers << { hostObj: { value: "ns#{i}.example.net" } } }
|
|
xml = domain_create_xml(ns: nameservers)
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2004')
|
|
expect(response[:msg]).to eq('Nameservers count must be between 2-11')
|
|
end
|
|
|
|
it 'returns error when invalid nameservers are present' do
|
|
xml = domain_create_xml({
|
|
ns: [
|
|
{ hostObj: { value: 'invalid1-' } },
|
|
{ hostObj: { value: '-invalid2' } }
|
|
]
|
|
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2005')
|
|
expect(response[:msg]).to eq('Hostname is invalid')
|
|
end
|
|
|
|
it 'creates domain with nameservers with ips' do
|
|
epp_request('domains/create_w_host_attrs.xml')
|
|
expect(Domain.first.nameservers.count).to eq(2)
|
|
ns = Domain.first.nameservers.first
|
|
expect(ns.ipv4).to eq('192.0.2.2')
|
|
expect(ns.ipv6).to eq('1080:0:0:0:8:800:200C:417A')
|
|
end
|
|
|
|
it 'returns error when nameserver has invalid ips' do
|
|
response = epp_request('domains/create_w_invalid_ns_ip.xml')
|
|
expect(response[:results][0][:result_code]).to eq '2005'
|
|
expect(response[:results][0][:msg]).to eq 'IPv4 is invalid'
|
|
expect(response[:results][0][:value]).to eq '192.0.2.2.invalid'
|
|
expect(response[:results][1][:result_code]).to eq '2005'
|
|
expect(response[:results][1][:msg]).to eq 'IPv6 is invalid'
|
|
expect(response[:results][1][:value]).to eq 'invalid_ipv6'
|
|
expect(Domain.count).to eq(0)
|
|
expect(Nameserver.count).to eq(0)
|
|
end
|
|
|
|
it 'creates a domain with period in days' do
|
|
xml = domain_create_xml(period_value: 365, period_unit: 'd')
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('1000')
|
|
expect(response[:msg]).to eq('Command completed successfully')
|
|
expect(Domain.first.valid_to).to eq(Date.today + 1.year)
|
|
end
|
|
|
|
it 'does not create a domain with invalid period' do
|
|
xml = domain_create_xml({
|
|
period: { value: '367', attrs: { unit: 'd' } }
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2004')
|
|
expect(response[:results][0][:msg]).to eq('Period must add up to 1, 2 or 3 years')
|
|
expect(response[:results][0][:value]).to eq('367')
|
|
end
|
|
|
|
it 'creates a domain with multiple dnskeys' do
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
{ keyData: {
|
|
flags: { value: '257' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '3' },
|
|
pubKey: { value: 'AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8' }
|
|
}
|
|
},
|
|
{
|
|
keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
},
|
|
{
|
|
keyData: {
|
|
flags: { value: '256' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '254' },
|
|
pubKey: { value: '841936717ae427ace63c28d04918569a841936717ae427ace63c28d0' }
|
|
}
|
|
}
|
|
]
|
|
})
|
|
|
|
epp_request(xml, :xml)
|
|
d = Domain.first
|
|
|
|
expect(d.dnskeys.count).to eq(3)
|
|
|
|
key_1 = d.dnskeys[0]
|
|
expect(key_1.ds_key_tag).to_not be_blank
|
|
expect(key_1.ds_alg).to eq(3)
|
|
expect(key_1.ds_digest_type).to eq(Setting.ds_algorithm)
|
|
|
|
expect(d.dnskeys.pluck(:flags)).to match_array([257, 0, 256])
|
|
expect(d.dnskeys.pluck(:protocol)).to match_array([3, 3, 3])
|
|
expect(d.dnskeys.pluck(:alg)).to match_array([3, 5, 254])
|
|
expect(d.dnskeys.pluck(:public_key)).to match_array(%w(
|
|
AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8
|
|
700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f
|
|
841936717ae427ace63c28d04918569a841936717ae427ace63c28d0
|
|
))
|
|
end
|
|
|
|
it 'does not create a domain when dnskeys are invalid' do
|
|
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
{ keyData: {
|
|
flags: { value: '250' },
|
|
protocol: { value: '4' },
|
|
alg: { value: '9' },
|
|
pubKey: { value: 'AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8' }
|
|
}
|
|
},
|
|
{
|
|
keyData: {
|
|
flags: { value: '1' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '10' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
},
|
|
{
|
|
keyData: {
|
|
flags: { value: '256' },
|
|
protocol: { value: '5' },
|
|
alg: { value: '254' },
|
|
pubKey: { value: '' }
|
|
}
|
|
}
|
|
]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
|
|
expect(response[:results][0][:msg]).to eq('Valid algorithms are: 3, 5, 6, 7, 8, 252, 253, 254, 255')
|
|
expect(response[:results][0][:value]).to eq('9')
|
|
|
|
expect(response[:results][1][:msg]).to eq('Valid protocols are: 3')
|
|
expect(response[:results][1][:value]).to eq('4')
|
|
|
|
expect(response[:results][2][:msg]).to eq('Valid flags are: 0, 256, 257')
|
|
expect(response[:results][2][:value]).to eq('250')
|
|
|
|
expect(response[:results][3][:msg]).to eq('Valid algorithms are: 3, 5, 6, 7, 8, 252, 253, 254, 255')
|
|
expect(response[:results][3][:value]).to eq('10')
|
|
|
|
expect(response[:results][4][:msg]).to eq('Valid flags are: 0, 256, 257')
|
|
expect(response[:results][4][:value]).to eq('1')
|
|
|
|
expect(response[:results][5][:msg]).to eq('Public key is missing')
|
|
|
|
expect(response[:results][6][:msg]).to eq('Valid protocols are: 3')
|
|
expect(response[:results][6][:value]).to eq('5')
|
|
end
|
|
|
|
it 'does not create a domain with two identical dnskeys' do
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
{ keyData: {
|
|
flags: { value: '257' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '3' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
},
|
|
{
|
|
keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
}]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
|
|
expect(response[:result_code]).to eq('2302')
|
|
expect(response[:msg]).to eq('Public key already exists')
|
|
expect(response[:results][0][:value]).to eq('700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f')
|
|
end
|
|
|
|
it 'validated dnskeys count' do
|
|
Setting.dnskeys_max_count = 1
|
|
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
{ keyData: {
|
|
flags: { value: '257' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '3' },
|
|
pubKey: { value: 'AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8' }
|
|
}
|
|
},
|
|
{
|
|
keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
}]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
|
|
expect(response[:result_code]).to eq('2004')
|
|
expect(response[:msg]).to eq('DNS keys count must be between 0-1')
|
|
end
|
|
|
|
it 'creates domain with ds data' do
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
{ dsData: {
|
|
keyTag: { value: '12345' },
|
|
alg: { value: '3' },
|
|
digestType: { value: '1' },
|
|
digest: { value: '49FD46E6C4B45C55D4AC' }
|
|
}
|
|
}]
|
|
})
|
|
|
|
epp_request(xml, :xml)
|
|
|
|
d = Domain.first
|
|
ds = d.dnskeys.first
|
|
expect(ds.ds_key_tag).to eq('12345')
|
|
expect(ds.ds_alg).to eq(3)
|
|
expect(ds.ds_digest_type).to eq(1)
|
|
expect(ds.ds_digest).to eq('49FD46E6C4B45C55D4AC')
|
|
expect(ds.flags).to be_nil
|
|
expect(ds.protocol).to be_nil
|
|
expect(ds.alg).to be_nil
|
|
expect(ds.public_key).to be_nil
|
|
end
|
|
|
|
it 'creates domain with ds data with key' do
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
{ dsData: {
|
|
keyTag: { value: '12345' },
|
|
alg: { value: '3' },
|
|
digestType: { value: '1' },
|
|
digest: { value: '49FD46E6C4B45C55D4AC' },
|
|
keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
}
|
|
}]
|
|
})
|
|
|
|
epp_request(xml, :xml)
|
|
|
|
d = Domain.first
|
|
ds = d.dnskeys.first
|
|
expect(ds.ds_key_tag).to eq('12345')
|
|
expect(ds.ds_alg).to eq(3)
|
|
expect(ds.ds_digest_type).to eq(1)
|
|
expect(ds.ds_digest).to eq('49FD46E6C4B45C55D4AC')
|
|
expect(ds.flags).to eq(0)
|
|
expect(ds.protocol).to eq(3)
|
|
expect(ds.alg).to eq(5)
|
|
expect(ds.public_key).to eq('700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f')
|
|
end
|
|
|
|
it 'prohibits dsData with key' do
|
|
Setting.ds_data_with_key_allowed = false
|
|
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
{ dsData: {
|
|
keyTag: { value: '12345' },
|
|
alg: { value: '3' },
|
|
digestType: { value: '1' },
|
|
digest: { value: '49FD46E6C4B45C55D4AC' },
|
|
keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
}
|
|
}]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2306')
|
|
expect(response[:msg]).to eq('dsData object with key data is not allowed')
|
|
end
|
|
|
|
it 'prohibits dsData' do
|
|
Setting.ds_data_allowed = false
|
|
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
{ dsData: {
|
|
keyTag: { value: '12345' },
|
|
alg: { value: '3' },
|
|
digestType: { value: '1' },
|
|
digest: { value: '49FD46E6C4B45C55D4AC' },
|
|
keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
}
|
|
}]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2306')
|
|
expect(response[:msg]).to eq('dsData object is not allowed')
|
|
end
|
|
|
|
it 'prohibits keyData' do
|
|
Setting.key_data_allowed = false
|
|
|
|
xml = domain_create_xml({}, {
|
|
_other: [
|
|
keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2306')
|
|
expect(response[:msg]).to eq('keyData object is not allowed')
|
|
end
|
|
end
|
|
|
|
context 'with juridical persion as an owner' do
|
|
before(:each) do
|
|
Fabricate(:contact, code: 'jd1234', ident_type: 'ico')
|
|
Fabricate(:contact, code: 'sh8013')
|
|
Fabricate(:contact, code: 'sh801333')
|
|
end
|
|
|
|
it 'creates a domain with contacts' do
|
|
xml = domain_create_xml({
|
|
_other: [
|
|
{ contact: { value: 'sh8013', attrs: { type: 'admin' } } }
|
|
]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('1000')
|
|
expect(response[:msg]).to eq('Command completed successfully')
|
|
expect(response[:clTRID]).to eq('ABC-12345')
|
|
|
|
expect(Domain.first.tech_contacts.count).to eq 1
|
|
expect(Domain.first.admin_contacts.count).to eq 1
|
|
|
|
tech_contact = Domain.first.tech_contacts.first
|
|
expect(tech_contact.code).to eq('jd1234')
|
|
end
|
|
|
|
it 'does not create a domain without admin contact' do
|
|
xml = domain_create_xml({
|
|
_other: [
|
|
{ contact: { value: 'sh8013', attrs: { type: 'tech' } } }
|
|
]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('2306')
|
|
expect(response[:msg]).to eq('Admin contacts count must be between 1 - infinity')
|
|
expect(response[:clTRID]).to eq('ABC-12345')
|
|
|
|
expect(Domain.count).to eq 0
|
|
expect(DomainContact.count).to eq 0
|
|
end
|
|
end
|
|
|
|
context 'with valid domain' do
|
|
before(:each) { Fabricate(:domain, name: 'example.ee', registrar: EppUser.first.registrar, dnskeys: []) }
|
|
|
|
it 'renews a domain' do
|
|
exp_date = (Date.today + 1.year)
|
|
xml = domain_renew_xml(curExpDate: exp_date.to_s)
|
|
response = epp_request(xml, :xml)
|
|
ex_date = response[:parsed].css('renData exDate').text
|
|
name = response[:parsed].css('renData name').text
|
|
expect(ex_date).to eq("#{(exp_date + 1.year)} 00:00:00 UTC")
|
|
expect(name).to eq('example.ee')
|
|
end
|
|
|
|
it 'returns an error when given and current exp dates do not match' do
|
|
xml = domain_renew_xml(curExpDate: '2016-08-07')
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2306')
|
|
expect(response[:results][0][:msg]).to eq('Given and current expire dates do not match')
|
|
end
|
|
|
|
it 'returns an error when period is invalid' do
|
|
exp_date = (Date.today + 1.year)
|
|
xml = domain_renew_xml(period_value: 4, curExpDate: exp_date.to_s)
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2004')
|
|
expect(response[:results][0][:msg]).to eq('Period must add up to 1, 2 or 3 years')
|
|
expect(response[:results][0][:value]).to eq('4')
|
|
end
|
|
|
|
it 'sets ok status by default' do
|
|
response = epp_request(domain_info_xml, :xml)
|
|
inf_data = response[:parsed].css('resData infData')
|
|
expect(inf_data.css('status').first[:s]).to eq('ok')
|
|
end
|
|
|
|
it 'returns domain info' do
|
|
d = Domain.first
|
|
d.domain_statuses.build(value: DomainStatus::CLIENT_HOLD, description: 'Payment overdue.')
|
|
d.nameservers.build(hostname: 'ns1.example.com', ipv4: '192.168.1.1', ipv6: '1080:0:0:0:8:800:200C:417A')
|
|
|
|
d.dnskeys.build(
|
|
ds_key_tag: '123',
|
|
ds_alg: 3,
|
|
ds_digest_type: 1,
|
|
ds_digest: 'abc',
|
|
flags: 257,
|
|
protocol: 3,
|
|
alg: 3,
|
|
public_key: 'AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8'
|
|
)
|
|
|
|
d.dnskeys.build(
|
|
ds_key_tag: '123',
|
|
ds_alg: 3,
|
|
ds_digest_type: 1,
|
|
ds_digest: 'abc',
|
|
flags: 0,
|
|
protocol: 3,
|
|
alg: 5,
|
|
public_key: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f'
|
|
)
|
|
|
|
d.save
|
|
|
|
response = epp_request(domain_info_xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('1000')
|
|
expect(response[:results][0][:msg]).to eq('Command completed successfully')
|
|
|
|
inf_data = response[:parsed].css('resData infData')
|
|
expect(inf_data.css('name').text).to eq('example.ee')
|
|
expect(inf_data.css('status').text).to eq('Payment overdue.')
|
|
expect(inf_data.css('status').first[:s]).to eq('clientHold')
|
|
expect(inf_data.css('registrant').text).to eq(d.owner_contact_code)
|
|
|
|
admin_contacts_from_request = inf_data.css('contact[type="admin"]').map(&:text)
|
|
admin_contacts_existing = d.admin_contacts.pluck(:code)
|
|
|
|
expect(admin_contacts_from_request).to eq(admin_contacts_existing)
|
|
|
|
hosts_from_request = inf_data.css('hostObj').map(&:text)
|
|
hosts_existing = d.nameservers.where(ipv4: nil).pluck(:hostname)
|
|
|
|
expect(hosts_from_request).to eq(hosts_existing)
|
|
|
|
expect(inf_data.css('hostName').first.text).to eq('ns1.example.com')
|
|
expect(inf_data.css('hostAddr').first.text).to eq('192.168.1.1')
|
|
expect(inf_data.css('hostAddr').last.text).to eq('1080:0:0:0:8:800:200C:417A')
|
|
expect(inf_data.css('crDate').text).to eq(d.created_at.to_time.utc.to_s)
|
|
expect(inf_data.css('exDate').text).to eq(d.valid_to.to_time.utc.to_s)
|
|
expect(inf_data.css('pw').text).to eq(d.auth_info)
|
|
|
|
ds_data_1 = response[:parsed].css('dsData')[0]
|
|
|
|
expect(ds_data_1.css('keyTag').first.text).to eq('123')
|
|
expect(ds_data_1.css('alg').first.text).to eq('3')
|
|
expect(ds_data_1.css('digestType').first.text).to eq('1')
|
|
expect(ds_data_1.css('digest').first.text).to eq('abc')
|
|
|
|
dnskey_1 = ds_data_1.css('keyData')[0]
|
|
expect(dnskey_1.css('flags').first.text).to eq('257')
|
|
expect(dnskey_1.css('protocol').first.text).to eq('3')
|
|
expect(dnskey_1.css('alg').first.text).to eq('3')
|
|
expect(dnskey_1.css('pubKey').first.text).to eq('AwEAAddt2AkLfYGKgiEZB5SmIF8EvrjxNMH6HtxWEA4RJ9Ao6LCWheg8')
|
|
|
|
ds_data_2 = response[:parsed].css('dsData')[1]
|
|
|
|
dnskey_2 = ds_data_2.css('keyData')[0]
|
|
expect(dnskey_2.css('flags').first.text).to eq('0')
|
|
expect(dnskey_2.css('protocol').first.text).to eq('3')
|
|
expect(dnskey_2.css('alg').first.text).to eq('5')
|
|
expect(dnskey_2.css('pubKey').first.text).to eq('700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f')
|
|
|
|
d.touch
|
|
|
|
response = epp_request(domain_info_xml, :xml)
|
|
inf_data = response[:parsed].css('resData infData')
|
|
|
|
expect(inf_data.css('upDate').text).to eq(d.updated_at.to_time.utc.to_s)
|
|
end
|
|
|
|
it 'returns error when domain can not be found' do
|
|
response = epp_request(domain_info_xml(name_value: 'test.ee'), :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2303')
|
|
expect(response[:results][0][:msg]).to eq('Domain not found')
|
|
end
|
|
|
|
it 'updates domain and adds objects' do
|
|
xml = domain_update_xml({
|
|
add: [
|
|
{
|
|
ns: [
|
|
{ hostObj: { value: 'ns1.example.com' } },
|
|
{ hostObj: { value: 'ns2.example.com' } }
|
|
]
|
|
},
|
|
_other: [
|
|
{ contact: { value: 'mak21', attrs: { type: 'tech' } } },
|
|
{ status: { value: 'Payment overdue.', attrs: { s: 'clientHold', lang: 'en' } } },
|
|
{ status: { value: '', attrs: { s: 'clientUpdateProhibited' } } }
|
|
]
|
|
]
|
|
}, {
|
|
add: [
|
|
{ keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
},
|
|
{
|
|
keyData: {
|
|
flags: { value: '256' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '254' },
|
|
pubKey: { value: '841936717ae427ace63c28d04918569a841936717ae427ace63c28d0' }
|
|
}
|
|
}
|
|
]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2303')
|
|
expect(response[:results][0][:msg]).to eq('Contact was not found')
|
|
|
|
Fabricate(:contact, code: 'mak21')
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('1000')
|
|
|
|
d = Domain.first
|
|
|
|
new_ns_count = d.nameservers.where(hostname: ['ns1.example.com', 'ns2.example.com']).count
|
|
expect(new_ns_count).to eq(2)
|
|
|
|
new_contact = d.tech_contacts.find_by(code: 'mak21')
|
|
expect(new_contact).to be_truthy
|
|
|
|
expect(d.domain_statuses.count).to eq(2)
|
|
expect(d.domain_statuses.first.description).to eq('Payment overdue.')
|
|
expect(d.domain_statuses.first.value).to eq('clientHold')
|
|
|
|
expect(d.domain_statuses.last.value).to eq('clientUpdateProhibited')
|
|
expect(d.dnskeys.count).to eq(2)
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2302')
|
|
expect(response[:results][0][:msg]).to eq('Nameserver already exists on this domain')
|
|
expect(response[:results][0][:value]).to eq('ns1.example.com')
|
|
|
|
expect(response[:results][1][:result_code]).to eq('2302')
|
|
expect(response[:results][1][:msg]).to eq('Nameserver already exists on this domain')
|
|
expect(response[:results][1][:value]).to eq('ns2.example.com')
|
|
|
|
expect(response[:results][2][:result_code]).to eq('2302')
|
|
expect(response[:results][2][:msg]).to eq('Contact already exists on this domain!')
|
|
expect(response[:results][2][:value]).to eq('mak21')
|
|
|
|
expect(response[:results][3][:msg]).to eq('Status already exists on this domain')
|
|
expect(response[:results][3][:value]).to eq('clientHold')
|
|
|
|
expect(response[:results][4][:msg]).to eq('Status already exists on this domain')
|
|
expect(response[:results][4][:value]).to eq('clientUpdateProhibited')
|
|
expect(d.domain_statuses.count).to eq(2)
|
|
end
|
|
|
|
it 'updates a domain and removes objects' do
|
|
Fabricate(:contact, code: 'mak21')
|
|
|
|
xml = domain_update_xml({
|
|
add: [
|
|
{
|
|
ns: [
|
|
{ hostObj: { value: 'ns1.example.com' } },
|
|
{ hostObj: { value: 'ns2.example.com' } }
|
|
]
|
|
},
|
|
_other: [
|
|
{ contact: { value: 'mak21', attrs: { type: 'tech' } } },
|
|
{ status: { value: 'Payment overdue.', attrs: { s: 'clientHold', lang: 'en' } } },
|
|
{ status: { value: '', attrs: { s: 'clientUpdateProhibited' } } }
|
|
]
|
|
]
|
|
}, {
|
|
add: [
|
|
{ keyData: {
|
|
flags: { value: '0' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '5' },
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
},
|
|
{
|
|
keyData: {
|
|
flags: { value: '256' },
|
|
protocol: { value: '3' },
|
|
alg: { value: '254' },
|
|
pubKey: { value: '841936717ae427ace63c28d04918569a841936717ae427ace63c28d0' }
|
|
}
|
|
}
|
|
]
|
|
})
|
|
|
|
epp_request(xml, :xml)
|
|
d = Domain.last
|
|
expect(d.dnskeys.count).to eq(2)
|
|
|
|
xml = domain_update_xml({
|
|
rem: [
|
|
{
|
|
ns: [
|
|
{ hostObj: { value: 'ns1.example.com' } }
|
|
]
|
|
},
|
|
_other: [
|
|
{ contact: { value: 'mak21', attrs: { type: 'tech' } } },
|
|
{ status: { value: '', attrs: { s: 'clientHold' } } }
|
|
]
|
|
]
|
|
}, {
|
|
rem: [
|
|
{ keyData: {
|
|
pubKey: { value: '700b97b591ed27ec2590d19f06f88bba700b97b591ed27ec2590d19f' }
|
|
}
|
|
}
|
|
]
|
|
})
|
|
|
|
epp_request(xml, :xml)
|
|
|
|
expect(d.dnskeys.count).to eq(1)
|
|
|
|
expect(d.domain_statuses.count).to eq(1)
|
|
expect(d.domain_statuses.first.value).to eq('clientUpdateProhibited')
|
|
|
|
rem_ns = d.nameservers.find_by(hostname: 'ns1.example.com')
|
|
expect(rem_ns).to be_falsey
|
|
|
|
rem_cnt = d.tech_contacts.find_by(code: 'mak21')
|
|
expect(rem_cnt).to be_falsey
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2303')
|
|
expect(response[:results][0][:msg]).to eq('Contact was not found')
|
|
expect(response[:results][0][:value]).to eq('mak21')
|
|
|
|
expect(response[:results][1][:result_code]).to eq('2303')
|
|
expect(response[:results][1][:msg]).to eq('Nameserver was not found')
|
|
expect(response[:results][1][:value]).to eq('ns1.example.com')
|
|
|
|
expect(response[:results][2][:result_code]).to eq('2303')
|
|
expect(response[:results][2][:msg]).to eq('Status was not found')
|
|
expect(response[:results][2][:value]).to eq('clientHold')
|
|
end
|
|
|
|
it 'does not add duplicate objects to domain' do
|
|
Fabricate(:contact, code: 'mak21')
|
|
|
|
xml = domain_update_xml({
|
|
add: [
|
|
ns: [
|
|
{ hostObj: { value: 'ns1.example.com' } }
|
|
]
|
|
]
|
|
})
|
|
|
|
epp_request(xml, :xml)
|
|
response = epp_request(xml, :xml)
|
|
|
|
expect(response[:results][0][:result_code]).to eq('2302')
|
|
expect(response[:results][0][:msg]).to eq('Nameserver already exists on this domain')
|
|
expect(response[:results][0][:value]).to eq('ns1.example.com')
|
|
end
|
|
|
|
it 'updates a domain' do
|
|
Fabricate(:contact, code: 'mak21')
|
|
existing_pw = Domain.first.auth_info
|
|
|
|
xml_params = {
|
|
chg: [
|
|
registrant: { value: 'mak21' }
|
|
]
|
|
}
|
|
|
|
response = epp_request(domain_update_xml(xml_params), :xml)
|
|
expect(response[:results][0][:result_code]).to eq('1000')
|
|
|
|
d = Domain.last
|
|
|
|
expect(d.owner_contact_code).to eq('mak21')
|
|
expect(d.auth_info).to eq(existing_pw)
|
|
end
|
|
|
|
it 'does not assign invalid status to domain' do
|
|
xml = domain_update_xml({
|
|
add: [
|
|
status: { value: '', attrs: { s: 'invalidStatus' } }
|
|
]
|
|
})
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:results][0][:result_code]).to eq('2303')
|
|
expect(response[:results][0][:msg]).to eq('Status was not found')
|
|
expect(response[:results][0][:value]).to eq('invalidStatus')
|
|
end
|
|
|
|
it 'deletes domain' do
|
|
expect(DomainContact.count).to eq(2)
|
|
response = epp_request(domain_delete_xml, :xml)
|
|
expect(response[:result_code]).to eq('1000')
|
|
|
|
expect(Domain.first).to eq(nil)
|
|
expect(DomainContact.count).to eq(0)
|
|
end
|
|
|
|
it 'does not delete domain with specific status' do
|
|
d = Domain.first
|
|
d.domain_statuses.create(value: DomainStatus::CLIENT_DELETE_PROHIBITED)
|
|
response = epp_request(domain_delete_xml, :xml)
|
|
expect(response[:result_code]).to eq('2304')
|
|
expect(response[:msg]).to eq('Domain status prohibits operation')
|
|
end
|
|
end
|
|
|
|
it 'checks a domain' do
|
|
response = epp_request(domain_check_xml, :xml)
|
|
expect(response[:result_code]).to eq('1000')
|
|
expect(response[:msg]).to eq('Command completed successfully')
|
|
|
|
domain = response[:parsed].css('resData chkData cd name').first
|
|
expect(domain.text).to eq('example.ee')
|
|
expect(domain[:avail]).to eq('1')
|
|
|
|
Fabricate(:domain, name: 'example.ee', registrar: zone)
|
|
|
|
response = epp_request(domain_check_xml, :xml)
|
|
domain = response[:parsed].css('resData chkData cd').first
|
|
name = domain.css('name').first
|
|
reason = domain.css('reason').first
|
|
|
|
expect(name.text).to eq('example.ee')
|
|
expect(name[:avail]).to eq('0')
|
|
expect(reason.text).to eq('in use')
|
|
end
|
|
|
|
it 'checks multiple domains' do
|
|
xml = domain_check_xml(names: ['one.ee', 'two.ee', 'three.ee'])
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('1000')
|
|
expect(response[:msg]).to eq('Command completed successfully')
|
|
|
|
domain = response[:parsed].css('resData chkData cd name').first
|
|
expect(domain.text).to eq('one.ee')
|
|
expect(domain[:avail]).to eq('1')
|
|
|
|
domain = response[:parsed].css('resData chkData cd name').last
|
|
expect(domain.text).to eq('three.ee')
|
|
expect(domain[:avail]).to eq('1')
|
|
end
|
|
|
|
it 'checks invalid format domain' do
|
|
xml = domain_check_xml(names: ['one.ee', 'notcorrectdomain'])
|
|
|
|
response = epp_request(xml, :xml)
|
|
expect(response[:result_code]).to eq('1000')
|
|
expect(response[:msg]).to eq('Command completed successfully')
|
|
|
|
domain = response[:parsed].css('resData chkData cd name').first
|
|
expect(domain.text).to eq('one.ee')
|
|
expect(domain[:avail]).to eq('1')
|
|
|
|
domain = response[:parsed].css('resData chkData cd').last
|
|
name = domain.css('name').first
|
|
reason = domain.css('reason').first
|
|
|
|
expect(name.text).to eq('notcorrectdomain')
|
|
expect(name[:avail]).to eq('0')
|
|
expect(reason.text).to eq('invalid format')
|
|
end
|
|
|
|
end
|
|
end
|