NAME WWW::LogicBoxes - Interact with LogicBoxes Reseller API

SYNOPSIS

use strict;
use warnings;
use WWW::LogicBoxes;

my $logic_boxes = WWW::LogicBoxes->new(
	username	=> "resellid",
	password	=> "resellpw",
	response_type	=> "xml",
	sandbox		=> 1
);

my $response = $logic_boxes->domains__available(
	{
		'domain-name' 	=> ["google", "cnn"],
		'tlds'		=> ["com","net"]
	}
);
...

METHODS

new

Constructs a new object for interacting with the LogicBoxes API. If the "sandbox" parameter is specified then the API calls are made against the LogicBoxes test server instead of the production server.

response_type is also an object argument that dictates the format in which the responses from LogicBoxes' API will be in. The default is XML, all supported protocols are:

  • xml

  • json

  • xml_simple

Suggest Domains (and many others)

my $response = $logic_boxes->domains__suggest_names(
	{
		'keyword'	=> 'car',
		'tlds'		=> ['com', 'net', 'org'],
		'no-of-results'	=> 10,
		'hypehn-allowed'=> 'false',
		'add-related'	=> 'true',
	}
);

This module implements all of the API methods available using the LogicBoxes API by abstracting out the need to specify the HTTP method (POST or GET) and automagically building the request URI according to the documentation provided by Logic Boxes (see the Logic Boxes API user guide at http://manage.logicboxes.com/kb/answer/744). To fully understand the method names it's best to take a specific example (in this case the suggestion of domain names).

Logic Boxes' API states that this method is part of their HTTP API, specifically the Domain Category and more specifically the Suggest Names method. The sample URI for this request would then be:

https://test.httpapi.com/api/domains/suggest-names.json?auth-userid=0&auth-password=password&keyword=domain&tlds=com&tlds=net&no-of-results=0&hyphen-allowed=true&add-related=true

The method name is built using the URI that the request is expected at in a logical way. Since this method is a member of the Domains Category and is specifically Suggest Names we end up:

$logic_boxes->domains__suggest_names

Where everything before the first "__" is the category and everything following it is the specific method (with - replaced with _ and / replaced with __).

Arguments Passed to Methods

The specific arguments each method requires is not enforced by this module, rather I leave it to the developer to reference the LogicBoxes API (again at http://manage.logicboxes.com/kb/answer/744) and to pass the correct arguments to each method as a hash. There are two "odd" cases that you should be aware of with respect to the way arguments must be passed.

Repeated Elements

For methods such as domains__check that accept the same "key" multiple times:

https://test.httpapi.com/api/domains/available.json?auth-userid=0&auth-password=password&domain-name=domain1&domain-name=domain2&tlds=com&tlds=net

This module accepts a hash where the key is the name of the argument (such as domain-name) and the value is an array of values you wish to pass:

$logic_boxes->domains__available(
	{
		'domain-name' 	=> ["google", "cnn"],
		'tlds'		=> ["com","net"]
	}
);

This is interpreted for you automagically into the repeating elements when the API's URI is built.

Array of Numbered Elements

For methods such as contacts__set_details that accep the same key multiple times except an incrementing digit is appended:

https://test.httpapi.com/api/contacts/set-details.json?auth-userid=0&auth-password=password&contact-id=0&attr-name1=sponsor1&attr-value1=0&product-key=dotcoop

This module still accepts a hash and leaves it to the developer to handle the appending of the incrementing digit to the keys of the hash:

$logic_boxes->contacts__set_details(
	{
		'contact-id'	=> 1337,
		'attr-name1'	=> 'sponsor',
		'attr-value1'	=> '0',
		'attr-name2'	=> 'CPR',
		'attr-value2'	=> 'COO',
		'product-key'	=> 'dotcoop'
	}
);

In this way you are able to overcome the need for unique keys and still pass the needed values onto LogicBoxes' API.

AUTHORS

Robert Stone, <drzigman AT cpan DOT org >

ACKNOWLEDGMENTS

Thanks to Richard Simoes for his assistance in putting this module together and for writing the WWW::eNom module that much of this is based on. Also thanks to HostGator.com for funding the development of this module and providing test resources.

COPYRIGHT & LICENSE

Copyright 2012 Robert Stone This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU Lesser General Public License as published by the Free Software Foundation; or any compatible license.

See http://dev.perl.org/licenses/ for more information.