LogicBoxes package provides most of the LogicBoxes API functionality and compatible company apis like resellerclub, whois.com and many more.
This package mainly developed for laravel package but you can use as a standalone package.
composer require netinternet/logicboxes
Package should be autodiscover by default but if you are using older versions of laravel you should change config/app.php with below;
Add this in providers array;
Netinternet\Logicboxes\LogicboxesServiceProvider::class,
Add this in aliases array;
'Logicboxes' => Netinternet\Logicboxes\Facades\Logicboxes::class,
Use command below and choose logicboxes option when asked. It will create logicboxes.php in config directory.
php artisan vendor:publish
You can also create this file manually and paste below content in file;
<?php
return [
'mode' => env('LOGICBOXES_ENV', 'test'),
'auth-userid' => env('LOGICBOXES_AUTHID'),
'api-key' => env('LOGICBOXES_APIKEY')
];
As you can see by default package uses environment variables. Be sure that use test mode when development mode. We strongly recommend to create LogicBox Demo Account
You can choose to use facade or helper function. We will use helper functions for examples in this documentation.
use Logicboxes;
// With Facade
public function myMethod()
{
return Logicboxes::domain('domain-name.tld')->ns();
}
or with helper
public function myMethod()
{
return logicboxes()->domain('domain-name.tld')->ns();
}
// get domain nameservers.
logicboxes()->domain('domain-name.tld')->nameservers();
// get domain nameservers short.
logicboxes()->domain('domain-name.tld')->ns();
// get domains all details.
logicboxes()->domain('domain-name.tld')->details();
// get domains status
logicboxes()->domain('domain-name.tld')->status();
// get domains order details
logicboxes()->domain('domain-name.tld')->order();
// get domains dnssec details
logicboxes()->domain('domain-name.tld')->dnssec();
// get domains contact id list.
logicboxes()->domain('domain-name.tld')->contact()->ids();
// get domains registrant contact details
logicboxes()->domain('domain-name.tld')->contact()->registrant();
// get domains admin contact details
logicboxes()->domain('domain-name.tld')->contact()->admin();
// get domains tech contact details
logicboxes()->domain('domain-name.tld')->contact()->tech();
// get domains billing contact details
logicboxes()->domain('domain-name.tld')->contact()->billing();
// check for domain
logicboxes()->domain('domain-name')->check(['com','net'])
// first parameter is array of tlds and second parameter domain suggessions as a boolean. Default is false.
// and you can also set domain index as third parameter for getting immediate domain status without result
//object ```logicboxes()->domain('domain-name')->check(['com','net'],false,1)```
// get domain order id
logicboxes()->domain('domain-name.tld')->orderId();
// set enable theft protection
logicboxes()->domain('domain-name.tld')->enableTheftProtection();
// set disable theft protection
logicboxes()->domain('domain-name.tld')->disableTheftProtection();
// modify domain nameservers
logicboxes()->domain('domain-name.tld')->modifyNameServers((array) $ns);
// delete this domain
logicboxes()->domain('domain-name.tld')->delete();
// cancel domain transfer process
logicboxes()->domain('domain-name.tld')->cancelTransfer();
// register domain
logicboxes()->domain('domain-name.tld')->register([
'years' => $years,
'ns' => (array) $ns,
'customer-id' => $customerId,
'reg-contact-id' => $regContactId,
'admin-contact-id' => $adminContactId,
'tech-contact-id' => $techContactId,
'billing-contact-id' => $billingContactId,
'invoice-option' => 'KeepInvoice',
'purchase-privacy' => $purchasePrivacy,
'protect-privacy' => $protectPrivacy,
]);
// Domain transfer
logicboxes()->domain('domain-name.tld')->transfer([
'auth-code' => $authCode,
'years' => $years,
'ns' => (array)$ns,
'customer-id' => $customerId,
'reg-contact-id' => $regContactId,
'admin-contact-id' => $adminContactId,
'tech-contact-id' => $techContactId,
'billing-contact-id' => $billingContactId,
'invoice-option' => $invoiceOption,
'purchase-privacy' => $purchasePrivacy,
'protect-privacy' => $protectPrivacy,
]);
// set Auth Code
logicboxes()->domain('domain-name.tld')->authCode('authcode');
// modify Auth Code
logicboxes()->domain('domain-name.tld')->modifyAuthCode('authcode');
// modify Auth Code
logicboxes()->domain('domain-name.tld')->validateTransferRequest();
// renew domain ($date => epochtime)
logicboxes()->domain('domain-name.tld')->renew($years, $date, $invoiceOption, true);
// $purchasePrivacy is default false
// deafult customer nameservers
logicboxes()->domain()->customerDefaultNameServers($customerId);
// Check premium
logicboxes()->domain('domain-name.tld')->isDomainPremium();
// add new child nameserver
logicboxes()->domain('domain-name.tld')->addChildNs('ns1.domain.com', ['0.0.0.0', '0.0.0.1']);
// get lock applied list
logicboxes()->domain('domain-name.tld')->getListLockApplied();
// set suspend
logicboxes()->domain('domain-name.tld')->suspend('reason text');
// set unsuspend
logicboxes()->domain('domain-name.tld')->unSuspend();
// Creating a customer
logicboxes()->customer()->create([
'username' => $this->faker->email,
'passwd' => 'Qs3jiA5fd8mq4',
'name' => $this->faker->name,
'company' => $this->faker->company,
'address-line-1' => $this->faker->streetAddress,
'city' => $this->faker->city,
'state' => $this->faker->state,
'country' => $this->faker->countryCode,
'zipcode' => $this->faker->postcode,
'phone-cc' => 90,
'phone' => 5555555555,
'lang-pref' => 'en'
]);
// getting a customer by email or id
logicboxes()->customer()->get('app@yourdomain.com')
//or by id
logicboxes()->customer()->get(17939294)
// Changing customers password
logicboxes()->customer()->get('app@yourdomain.com','myNew8CharPassword')
// Change customer
logicboxes()->customer()->moveProduct("app@yourdomain.com", 'old-customer-id', 'new-customer-id, 'old-contact');
- You should first open the LogicBox test account LogicBox Demo Account Link
- Copy example config file:
cp tests/config.ini.example tests/config.ini
- Change credentials in tests/config.ini file.
- Run phpunit:
$ vendor/phpunit/phpunit/phpunit
- Fork it ( https://github.com/netinternet/logicboxes-api/ )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request