Cpanel/WHM API for PHP

dev-master 2018-01-01 19:10 UTC



Installation Guide

To install this package, you can run this code via your terminal

	composer require furkankulaber/cpanel-php:dev-master

Or update your composer.json by adding this line


Then, run this code

	composer update


For example, if you would like to get list accounts of your whm server, you can do this.

  $cpanel = new \Clemury\CpanelPhp\Cpanel([
      'host'        =>  'https://123.456.789.123:2087', // ip or domain complete with its protocol and port
      'username'    =>  'root', // username of your server, it usually root.
      'auth_type'   =>  'hash', // set 'hash' or 'password'
      'password'    =>  'password', // long hash or your user's password

  $accounts = $cpanel->listaccts(); // it will returned as array


Defining Configuration on constructor

This is the example when you want to define your configuration while creating new object

  $cpanel = new \Clemury\CpanelPhp\Cpanel([
      'host'        =>  'https://123.456.789.123:2087', // required
      'username'    =>  'root', // required
      'auth_type'   =>  'hash', // optional, default 'hash'
      'password'    =>  'password', // required


For example, you would like to get some list accounts from cPanel/WHM


	$accounts = $cpanel->listaccts();

	// passing parameters
	$accounts = $cpanel->listaccts(['searchtype'=>'domain', 'search'=>'', 'exact', 'search'=>'helloworld.com']);
	// create account (Domain Name, Username, Password, Plan Slug)
	createAccount(www.domain_name.com.br, 'user', 'pass', 'plan_basic');

For accessing cPanel API 2, you can use this.

	// get bandwidth data of specific cPanel's user
	$data = $cpanel->cpanel('Bandwidth', 'getbwdata', 'username');

	// removing cron line
	$data = $cpanel->cpanel('Cron', 'remove_line', 'username', ['line'=>1]);

The first parameter must be Module you would like to get, second is function name, and the third is username of cPanel's user. There is fourth arguments, when function has some additional arguments, you can pass it there.

For accessing to cPanel API 1 or cPanel API 2 or UAPI, you can use this.

	// get bandwidth data of specific cPanel's user (using cPanel API 2)
	$data = $cpanel->execute_action('2', 'Bandwidth', 'getbwdata', 'username');

	// removing email address (using UAPI)
	$data = $cpanel->execute_action('3', 'Email', 'delete_pop', 'username', ['email'=>'peter@griffin.com']);

This function is similar to the above, the only difference is that it has added a parameter which indicates the API you want to use (1 = cPanel API 1, 2 = cPanel API 2, 3 = UAPI), the other arguments are the same.

Overriding current configuration

Somehow, you want to override your current configuration. To do this, here is the code

  // change username andd (password or hash)
  $cpanel->setAuthorization($username, $password);

  // change host

  // change authentication type

Get defined configuration

After you define some of your configuration, you can get it again by calling this functions

  // get username

  // get password

  // get authentication type

  // get host

Feedback and contribution

This package is free and open source, feel free to fork and report some issue to this package. :-). Have fun