NAME
WWW::Domain::Registry::Joker - an interface to the Joker.com DMAPI
SYNOPSIS
use WWW::Domain::Registry::Joker;
$reg = new WWW::Domain::Registry::Joker('username' => 'testuser',
'password' => 'secret', 'debug' => 1);
@res = $reg->result_list();
eval {
$procid = $reg->do_request('ns-create', 'Host' => 'a.ns.example.com',
'IP' => '192.168.13.1');
};
if ($@) {
warn("Joker request failed: $@\n");
}
DESCRIPTION
The WWW::Domain::Registry::Joker
module provides a Perl interface to the Domain Management API (DMAPI) used by the Joker.com DNS registrar. It is designed to help Joker.com resellers in automating the domain registration and all the other relevant actions.
The recommended usage of the WWW::Domain::Registry::Joker
class is to create an object, initialize it with the Joker.com reseller's username and password, and then use it to send all the DMAPI requests. This will take care of caching both login credentials and network connections (at least as far as LWP
takes care of caching connections to the same webserver).
In most cases it is not necessary to invoke the login()
method explicitly, since all the "real" action methods check for an authentication token and invoke login()
if there is none yet.
METHODS
The WWW::Domain::Registry::Joker
class defines the following methods:
new ( PARAMS )
Create a new Joker.com interface object with the specified parameters:
username
The Joker.com reseller authentication username.
password
The Joker.com reseller authentication password.
debug
The diagnostic output level, 0 for no diagnostic messages.
dmapi_url
The URL to use for Joker.com Domain Management API (DMAPI) requests; if not specified, the standard URL https://dmapi.joker.com/request is used.
lwp ( [OBJECT] )
Get or set the
LWP::UserAgent
object used for sending the actual requests to the Joker.com web API.This method should probably never interest any consumers of this class :)
build_request ( REQUEST, PARAMS )
Build a
HTTP::Request
object for submitting an actual request to the Joker.com API.This method should probably never interest any consumers of this class :)
login ()
Send a DMAPI login authentication request and obtain the auth SID for use in the follow-up actual requests. The username and password member variables must be initialized.
query_domain_list ( PATTERN )
Return information about the domains registered by this reseller whose names match the supplied pattern. Returns a hash indexed by domain name, each element of which is a hash:
domain
The domain name (yes, again :))
exp
The expiration date of the domain registration.
Invokes the
login()
method if necessary.do_request ( REQUEST, PARAMS )
Send a DMAPI request with the name specified in
REQUEST
and parameters in thePARAMS
hash. The request name string and the parameters (required and optional) are as specified by the DMAPI documentationNote that if a parameter is supplied with the empty string as a value, the
do_request()
method will send the "!@!" string instead, since the DMAPI considers empty values to mean no change requested.Invokes the
login()
method if necessary.result_list ()
Obtain the list of processed requests from the Joker.com DMAPI and the corresponding result status and object ID (where applicable). Returns a hash indexed by DMAPI Proc-Id values.
Invokes the
login()
method if necessary.
EXAMPLES
Initialize a WWW::Domain::Registry::Joker
object with your reseller's username and password:
$jreq = new WWW::Domain::Registry::Joker('username' => 'me@example.com',
'password' => 'somekindofsecret');
Fetch the list of pending and processed requests and their status:
%h = $jreq->result_list();
foreach (sort { $a->{'procid'} cmp $b->{'procid'} } values %h) {
print join("\t",
@{$_}{qw/tstamp svtrid procid reqtype reqobject status cltrid/}).
"\n";
}
Register a new nameserver:
eval {
$jreq->do_request('ns-create', 'Host' => 'a.ns.example.net',
'IP' => '192.168.13.7');
};
print STDERR "ns-create error: $@\n" if ($@);
Maybe some more examples are needed here :)
ERRORS
All the user-invoked methods die on any Joker.com errors with a suitable error message placed in $@.
SEE ALSO
https://joker.com/faq/category/39/22-dmapi.html - the Joker.com DMAPI documentation
BUGS
Reorder the methods placing the user-serviceable ones first.
Move
WWW::Domain::Registry::Loggish
to a separate distribution?Better error handling; exceptions? Error.pm? Something completely different? Croak?
Croak instead of die here and there.
HISTORY
The WWW::Domain::Registry::Joker
class was written by Peter Pentchev in 2007.
AUTHOR
Peter Pentchev, <roam@ringlet.net>
COPYRIGHT AND LICENSE
Copyright (C) 2007, 2008 by Peter Pentchev
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.