| Net-DRI documentation | Contained in the Net-DRI distribution. |
Net::DRI::Protocol::OpenSRS::XCP::Connection - OpenSRS XCP Connection handling 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) 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, OpenSRS XCP Connection handling ## ## 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::Protocol::OpenSRS::XCP::Connection; use strict; use Digest::MD5 (); use HTTP::Request (); use Net::DRI::Util; use Net::DRI::Exception; use Net::DRI::Data::Raw; use Net::DRI::Protocol::ResultStatus; our $VERSION=do { my @r=(q$Revision: 1.2 $=~/\d+/g); sprintf("%d".".%02d" x $#r, @r); };
#################################################################################################### sub init { my ($class,$to)=@_; my $t=$to->transport_data(); foreach my $p (qw/client_login client_password remote_url/) { Net::DRI::Exception::usererr_insufficient_parameters($p.' must be defined') unless (exists($t->{$p}) && $t->{$p}); } } ## From Protocol Message object to something suitable for transport (various types) sub write_message { my ($class,$to,$msg)=@_; my $t=$to->transport_data(); my $req=HTTP::Request->new('POST',$t->{remote_url}); $req->header('Content-Type','text/xml'); $req->header('X-Username',$t->{client_login}); my $body=$msg->get_body(); $req->header('X-Signature',Digest::MD5::md5_hex(Digest::MD5::md5_hex($body,$t->{client_password}),$t->{client_password})); ## client_password is in fact the reseller key $req->content(Net::DRI::Util::encode_utf8($body)); ## Content-Length will be automatically computed during Transport by LWP::UserAgent return $req; } ## From transport (various types) to Net::DRI::Data::Raw object (which will be parsed inside Protocol::reaction) sub read_data { my ($class,$to,$res)=@_; die(Net::DRI::Protocol::ResultStatus->new_error('COMMAND_FAILED_CLOSING',sprintf('Got unsuccessfull HTTP response: %d %s',$res->code(),$res->message()),'en')) unless $res->is_success(); return Net::DRI::Data::Raw->new_from_xmlstring($res->decoded_content()); } #################################################################################################### 1;