| Net-DRI documentation | Contained in the Net-DRI distribution. |
Net::DRI::DRD::CoCCA - CoCCA Registry driver for Net::DRI
Please see the README file for details.
This is only a prototype for testing purpose. Each TLD registry should have its own DRD module implementing local policies.
For now, support questions should be sent to:
<netdri@dotandco.com>
Please also see the SUPPORT file in the distribution.
<http://www.dotandco.com/services/software/Net-DRI/>
Patrick Mevzek, <netdri@dotandco.com>
Copyright (c) 2008,2009 Patrick Mevzek <netdri@dotandco.com>. 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, CoCCA Registry Driver for multiple TLDs ## ## Copyright (c) 2008,2009 Patrick Mevzek <netdri@dotandco.com>. 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::CoCCA; use strict; use warnings; use base qw/Net::DRI::DRD/; use DateTime::Duration; use DateTime; our $VERSION=do { my @r=(q$Revision: 1.4 $=~/\d+/g); sprintf("%d".".%02d" x $#r, @r); };
#################################################################################################### sub periods { return map { DateTime::Duration->new(years => $_) } (1..5); } sub name { return 'CoCCA'; } sub tlds { return (qw/cx gs tl ki mu nf ht na ng cc cm sb mg/); } sub object_types { return ('domain','ns','contact'); } sub profile_types { return qw/epp/; } sub transport_protocol_default { my ($self,$type)=@_; return ('Net::DRI::Transport::Socket',{remote_host => 'ote.epp.cocca.cx'},'Net::DRI::Protocol::EPP',{}) if $type eq 'epp'; return; } #################################################################################################### ## We can not start a transfer, if domain name has already been transfered less than 15 days ago. sub verify_duration_transfer { my ($self,$ndr,$duration,$domain,$op)=@_; ($duration,$domain,$op)=($ndr,$duration,$domain) unless (defined($ndr) && $ndr && (ref($ndr) eq 'Net::DRI::Registry')); return 0 unless ($op eq 'start'); ## we are not interested by other cases, they are always OK my $rc=$self->domain_info($ndr,$domain,{hosts=>'none'}); return 1 unless ($rc->is_success()); my $trdate=$ndr->get_info('trDate'); return 0 unless ($trdate && $trdate->isa('DateTime')); my $now=DateTime->now(time_zone => $trdate->time_zone()->name()); my $cmp=DateTime->compare($now,$trdate+DateTime::Duration->new(days => 15)); return ($cmp == 1)? 0 : 1; ## we must have : now > transferdate + 15days ## we return 0 if OK, anything else if not } #################################################################################################### 1;