mhasnainjafri / cpanel
Laravel CPanel API Library for Managing cPanel Functionalities
Installs: 4 220
Dependents: 0
Suggesters: 0
Security: 0
Stars: 15
Watchers: 2
Forks: 1
Open Issues: 0
README
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:
- 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
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.