File Coverage

blib/lib/Net/DRI/Protocol/Whois/Domain/CAT.pm
Criterion Covered Total %
statement 15 57 26.3
branch 0 14 0.0
condition n/a
subroutine 5 11 45.4
pod 0 6 0.0
total 20 88 22.7


line stmt bran cond sub pod time code
1             ## Domain Registry Interface, Whois commands for .CAT (RFC3912)
2             ##
3             ## Copyright (c) 2008,2009,2013 Patrick Mevzek . All rights reserved.
4             ##
5             ## This file is part of Net::DRI
6             ##
7             ## Net::DRI is free software; you can redistribute it and/or modify
8             ## it under the terms of the GNU General Public License as published by
9             ## the Free Software Foundation; either version 2 of the License, or
10             ## (at your option) any later version.
11             ##
12             ## See the LICENSE file that comes with this distribution for more details.
13             ####################################################################################################
14              
15             package Net::DRI::Protocol::Whois::Domain::CAT;
16              
17 1     1   682 use strict;
  1         1  
  1         23  
18 1     1   3 use warnings;
  1         1  
  1         19  
19              
20 1     1   3 use Net::DRI::Exception;
  1         1  
  1         18  
21 1     1   3 use Net::DRI::Util;
  1         1  
  1         13  
22 1     1   3 use Net::DRI::Protocol::Whois::Domain::common;
  1         1  
  1         442  
23              
24             =pod
25              
26             =head1 NAME
27              
28             Net::DRI::Protocol::Whois::Domain::CAT - .CAT Whois commands (RFC3912) for Net::DRI
29              
30             =head1 DESCRIPTION
31              
32             Please see the README file for details.
33              
34             =head1 SUPPORT
35              
36             For now, support questions should be sent to:
37              
38             Enetdri@dotandco.comE
39              
40             Please also see the SUPPORT file in the distribution.
41              
42             =head1 SEE ALSO
43              
44             Ehttp://www.dotandco.com/services/software/Net-DRI/E
45              
46             =head1 AUTHOR
47              
48             Patrick Mevzek, Enetdri@dotandco.comE
49              
50             =head1 COPYRIGHT
51              
52             Copyright (c) 2008,2009,2013 Patrick Mevzek .
53             All rights reserved.
54              
55             This program is free software; you can redistribute it and/or modify
56             it under the terms of the GNU General Public License as published by
57             the Free Software Foundation; either version 2 of the License, or
58             (at your option) any later version.
59              
60             See the LICENSE file that comes with this distribution for more details.
61              
62             =cut
63              
64             ####################################################################################################
65              
66             sub register_commands
67             {
68 0     0 0   my ($class,$version)=@_;
69 0           return { 'domain' => { info => [ \&info, \&info_parse ] } };
70             }
71              
72             sub info
73             {
74 0     0 0   my ($po,$domain,$rd)=@_;
75 0           my $mes=$po->message();
76 0 0         Net::DRI::Exception->die(1,'protocol/whois',10,'Invalid domain name: '.$domain) unless Net::DRI::Util::is_hostname($domain);
77 0           $mes->command(' -C US-ASCII ace '.lc($domain));
78 0           return;
79             }
80              
81             sub info_parse
82             {
83 0     0 0   my ($po,$otype,$oaction,$oname,$rinfo)=@_;
84 0           my $mes=$po->message();
85 0 0         return unless $mes->is_success();
86              
87 0           my $rr=$mes->response();
88 0           my $rd=$mes->response_raw();
89 0           my ($domain,$exist)=parse_domain($po,$rr,$rd,$rinfo);
90 0 0         $domain=lc($oname) unless defined($domain);
91 0           $rinfo->{domain}->{$domain}->{exist}=$exist;
92 0           $rinfo->{domain}->{$domain}->{action}='info';
93              
94 0 0         return unless $exist;
95              
96 0           parse_registrars($po,$domain,$rr,$rinfo);
97 0           parse_dates($po,$domain,$rr,$rinfo);
98 0           Net::DRI::Protocol::Whois::Domain::common::epp_parse_status($po,$domain,$rr,$rinfo);
99 0           Net::DRI::Protocol::Whois::Domain::common::epp_parse_contacts($po,$domain,$rr,$rinfo,{registrant => 'Registrant',admin => 'Admin', billing => 'Billing', tech => 'Tech'});
100 0           Net::DRI::Protocol::Whois::Domain::common::epp_parse_ns($po,$domain,$rr,$rinfo);
101 0           return;
102             }
103              
104             sub parse_domain
105             {
106 0     0 0   my ($po,$rr,$rd,$rinfo)=@_;
107 0           my ($dom,$e);
108 0 0         if (exists($rr->{'Domain Name'}))
109             {
110 0           $e=1;
111 0           $dom=lc($rr->{'Domain Name'}->[0]);
112 0           $rinfo->{domain}->{$dom}->{roid}=$rr->{'Domain ID'}->[0];
113 0 0         $rinfo->{domain}->{$dom}->{maintainer}=$rr->{'Maintainer'}->[0] if exists($rr->{'Maintainer'});
114             ## Domain Name ACE / Domain Language
115             } else
116             {
117 0           $e=0;
118             }
119 0           return ($dom,$e);
120             }
121              
122             sub parse_registrars
123             {
124 0     0 0   my ($po,$domain,$rr,$rinfo)=@_;
125 0 0         return unless exists($rr->{'Registrar ID'});
126 0           ($rinfo->{domain}->{$domain}->{clID},$rinfo->{domain}->{$domain}->{clName})=($rr->{'Registrar ID'}->[0]=~m/^(\S+) \((.+)\)\s*$/);
127 0           return;
128             }
129              
130             sub parse_dates
131             {
132 0     0 0   my ($po,$domain,$rr,$rinfo)=@_;
133 0           my $strp=$po->build_strptime_parser(pattern => '%Y-%m-%d %T GMT', time_zone => 'GMT');
134 0           $rinfo->{domain}->{$domain}->{crDate}=$strp->parse_datetime($rr->{'Created On'}->[0]);
135 0           $rinfo->{domain}->{$domain}->{upDate}=$strp->parse_datetime($rr->{'Last Updated On'}->[0]);
136 0           $rinfo->{domain}->{$domain}->{exDate}=$strp->parse_datetime($rr->{'Expiration Date'}->[0]);
137 0           return;
138             }
139              
140             ####################################################################################################
141             1;