| Net-DRI documentation | Contained in the Net-DRI distribution. |
Net::DRI::DRD::PRO - .PRO policies for Net::DRI
Please see the README file for details.
For now, support questions should be sent to:
<development@sygroup.ch>
Please also see the SUPPORT file in the distribution.
<http://www.bsdprojects.net/project/netdri/>
Tonnerre Lombard, <tonnerre.lombard@sygroup.ch>, Alexander Biehl, <info@hexonet.net>, HEXONET Support GmbH, <http://www.hexonet.net/>.
Copyright (c) 2008,2009 Tonnerre Lombard <tonnerre.lombard@sygroup.ch>. All rights reserved.
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
See the LICENSE file that comes with this distribution for more details.
| Net-DRI documentation | Contained in the Net-DRI distribution. |
## Domain Registry Interface, .PRO policies ## ## Copyright (c) 2008,2009 Tonnerre Lombard <tonnerre.lombard@sygroup.ch> ## All rights reserved. ## ## This file is part of Net::DRI ## ## Net::DRI is free software; you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published by ## the Free Software Foundation; either version 2 of the License, or ## (at your option) any later version. ## ## See the LICENSE file that comes with this distribution for more details. # # # #################################################################################################### package Net::DRI::DRD::PRO; use strict; use warnings; use base qw/Net::DRI::DRD/; use DateTime::Duration; our $VERSION=do { my @r=(q$Revision: 1.3 $=~/\d+/g); sprintf("%d".".%02d" x $#r, @r); };
#################################################################################################### sub new { my $class = shift; my $self = $class->SUPER::new(@_); $self->{info}->{host_as_attr} = 0; bless($self, $class); return $self; } sub periods { return map { DateTime::Duration->new(years => $_) } (1..10); } sub name { return 'RegistryPro'; } sub tlds { return qw/pro law.pro jur.pro bar.pro med.pro cpa.pro aca.pro eng.pro/; } sub object_types { return ('domain','contact','ns','av'); } sub profile_types { return qw/epp/; } sub transport_protocol_default { my ($self,$type)=@_; return ('Net::DRI::Transport::Socket',{},'Net::DRI::Protocol::EPP::Extensions::PRO',{}) if $type eq 'epp'; return; } #################################################################################################### sub verify_name_domain { my ($self, $ndr, $domain, $op) = @_; return $self->_verify_name_rules($domain,$op,{check_name => 1, my_tld => 1, icann_reserved => 1, }); } #################################################################################################### ## TODO : $av should be checked here to be syntaxically correct before doing process() sub av_create { my ($self,$ndr,$av,$ep)=@_; return $ndr->process('av','create',[$av,$ep]); } sub av_check { my ($self,$ndr,$av,$ep)=@_; return $ndr->process('av','check',[$av,$ep]); } sub av_info { my ($self,$ndr,$av,$ep)=@_; return $ndr->process('av','info',[$av,$ep]); } #################################################################################################### 1;