| Net-DRI documentation | Contained in the Net-DRI distribution. |
Net::DRI::Protocol::AdamsNames::WS::Domain - AdamsNames Web Services Domain commands for Net::DRI
Please see the README file for details.
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) 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, AdamsNames Web Services Domain commands ## ## Copyright (c) 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::Protocol::AdamsNames::WS::Domain; use strict; use warnings; use Net::DRI::Exception; use Net::DRI::Util; our $VERSION=do { my @r=(q$Revision: 1.1 $=~/\d+/g); sprintf("%d".".%02d" x $#r, @r); };
#################################################################################################### sub register_commands { my ($class,$version)=@_; my %tmp=( info => [\&info, \&info_parse ], ); return { 'domain' => \%tmp }; } sub build_msg { my ($msg,$command,$domain)=@_; Net::DRI::Exception->die(1,'protocol/adamsnames/ws',2,'Domain name needed') unless defined($domain) && $domain; Net::DRI::Exception->die(1,'protocol/adamsnames/ws',10,'Invalid domain name') unless Net::DRI::Util::is_hostname($domain); $msg->method($command) if defined($command); } sub info { my ($po,$domain)=@_; my $msg=$po->message(); build_msg($msg,'domquery',$domain); $msg->params([$domain]); } sub info_parse { my ($po,$otype,$oaction,$oname,$rinfo)=@_; my $mes=$po->message(); return unless $mes->is_success(); my $r=$mes->result(); Net::DRI::Exception->die(1,'protocol/adamsnames/ws',1,'Unexpected reply for domain_info: '.$r) unless (ref($r) eq 'HASH'); $rinfo->{domain}->{$oname}->{action}='info'; $rinfo->{domain}->{$oname}->{exist}=$r->{'found'}; return unless $r->{'found'}; my %r=%{$r->{domain}}; $rinfo->{domain}->{$oname}->{crDate}=$po->{dt_parse}->parse_datetime($r{'registered'}); my %c=(org => 'registrant', admin => 'admin', tech => 'tech', bill => 'billing'); my $cs=$po->create_local_object('contactset'); while (my ($k,$v)=each(%c)) { next unless exists($r{$k}); my $c=$po->create_local_object('contact')->srid($r{$k}); $cs->add($c,$v); } $rinfo->{domain}->{$oname}->{contact}=$cs; my $h=$po->create_local_object('hosts'); foreach my $rr (@{$r{rr}}) { next unless $rr->{rclass} eq 'ns'; $h->add($rr->{rdata}); } $rinfo->{domain}->{$oname}->{ns}=$h; $rinfo->{domain}->{$oname}->{roid}=$r{id}; } #################################################################################################### 1;