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
To get started, you need to create a new instance of the Cpanel class. There are two ways to initialize the class:
- Without any parameters:
$cpanel = new Cpanel();
- 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
- search api in cpanel search bar
- click on
Manage api token
- Give token a name and click on create
- Copy the token you get
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');
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');
To create a POP email account, use the createPopEmailAccount()
method:
$cpanel->createPopEmailAccount('[email protected]', 'password');
To delete a POP email account, use the deletePopEmailAccount()
method:
$cpanel->deletePopEmailAccount('[email protected]');
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('[email protected]', 'account');
To get the POP email count, use the getPopEmailCount()
method:
$cpanel->getPopEmailCount();
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();
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.
composer test
Please see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.
This package was generated using the Laravel Package Boilerplate.