Laravel CPanel API Library for Managing cPanel Functionalities

v1.0.2 2023-07-23 13:11 UTC

This package is auto-updated.

Last update: 2024-12-16 06:13:25 UTC


README

License Open Issues Stars Forks

Library Name: Laravel CPanel API

This library provides a convenient way to interact with the cPanel API using Laravel. It allows you to perform various cPanel functions such as creating subdomains, managing databases, handling email accounts, and managing disk usage.

Installation

To use this library in your Laravel project, you can install it via Composer. Run the following command in your terminal:


composer require mhasnainjafri/cpanel

Usage

To get started, you need to create a new instance of the Cpanel class. There are two ways to initialize the class:

  1. Without any parameters:
$cpanel = new Cpanel();
  1. With parameters (if not defined in .env file):
$cpanel = new Cpanel($cpanel_domain, $cpanel_api_token, $cpanel_username, 'https', 2083);

Alternatively, you can set the cPanel credentials in the .env file:

CPANEL_DOMAIN=domain e.g : xyz.com
CPANEL_PORT=cpanel port (mostly is) 2083
CPANEL_API_TOKEN= Cpanel api token (To get api token view step 3)
CPANEL_USERNAME= Cpanel username
  1. Steps to get Cpanel Api

  • search api in cpanel search bar
  • click on Manage api token step 1
  • Give token a name and click on create step 2
  • Copy the token you get

Subdomain Functions

To create a subdomain, use the createSubDomain() method:

$cpanel->createSubDomain('Sub domain e.g: web', 'domain e.g: xyz.com', 'Path where subdomain points e.g: /home/domain/public_html/subdomain');

Database Functions

To list all databases, use the listDatabases() method:

$cpanel->listDatabases();

To create a new database, use the createDatabase() method:

$cpanel->createDatabase('Database Name');

To delete a database, use the deleteDatabase() method:

$cpanel->deleteDatabase('Database Name');

To create a database user, use the createDatabaseUser() method:

$cpanel->createDatabaseUser('Database username', 'password');

To delete a database user, use the deleteDatabaseUser() method:

$cpanel->deleteDatabaseUser('Database username');

To set all privileges on a database for a user, use the setAllPrivilegesOnDatabase() method:

$cpanel->setAllPrivilegesOnDatabase('Database username', 'Database Name');

Mail Functions

To create a POP email account, use the createPopEmailAccount() method:

$cpanel->createPopEmailAccount('mail@domain.com', 'password');

To delete a POP email account, use the deletePopEmailAccount() method:

$cpanel->deletePopEmailAccount('mail@domain.com');

To edit the mailbox quota for an email account, use the editMailboxQuota() method:

$cpanel->editMailboxQuota($email, $domain, $quota);

To dispatch client settings for an email account, use the dispatchClientSettings() method:

$cpanel->dispatchClientSettings('mail@domain.com', 'account');

To get the POP email count, use the getPopEmailCount() method:

$cpanel->getPopEmailCount();

cPanel Disk Management

To get cPanel statistics bar stats for bandwidth usage or disk usage, use the getCpanelStatsBarStats() method:

$cpanel->getCpanelStatsBarStats('bandwidthusage|diskusage');

To get cPanel disk quota information, use the getCpanelDiskQuotaInfo() method:

$cpanel->getCpanelDiskQuotaInfo();

Other API Functions

To call any other cPanel API function, use the callUAPI() method:

$cpanel->callUAPI($Module, $function, $parameters_array = array());

Replace $Module with the desired module, $function with the function name, and $parameters_array with any additional parameters required by the API function.

That's it! You can now leverage the power of the Laravel CPanel API library to interact with the cPanel API seamlessly in your Laravel applications.

Testing

composer test

Changelog

Please see CHANGELOG for more information what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email mhasnainjafri0099@gmail.com instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

Laravel Package Boilerplate

This package was generated using the Laravel Package Boilerplate.