neto737 / hestiacp-api
HestiaCP API SDK written in PHP
Fund package maintenance!
Liberapay
Requires
- php: >=7.3
- guzzlehttp/guzzle: ^7.3
- nette/utils: ^3.2
Requires (Dev)
- phpunit/phpunit: 9.5.9
- roave/security-advisories: dev-latest
- tracy/tracy: v3.0.x-dev
README
How to use
- Installation
$ composer require neto737/hestiacp-api
- Create Client
a) Easy way
use neto737\HestiaCP\Client; // Easy way to create Client // Using API Key $client = Client::simpleFactory('https://someHost', 'API_Key'); // Using username and password $client = Client::simpleFactory('https://someHost', 'someUser', 'somePass');
b) For some reasons (more hosts, etc) you may need create objects alone
use neto737\HestiaCP\Client; use neto737\HestiaCP\Authorization\Credentials; use neto737\HestiaCP\Authorization\Host; // You can choose to use an API Key or username and password // API Key $credentials = new Credentials('API_Key'); // Username and Password $credentials = new Credentials('someUser', 'somePassword'); $host = new Host('https://someHost', $credentials); $client = new Client($host);
- Usage
// verify login $client->testAuthorization(); // bool
You can simply send one of prepared commands (or you can write own command - must implements \neto737\HestiaCP\Command\ICommand
)
$command = new SomeCommand(); $response = $client->send($command); echo $response->getResponseText();
Or you can use prepared modules
a) user module
$userModule = $client->getModuleUser(); $userModule->list(); // returns all users with data $userModule->detail('admin'); // returns selected user with data $userModule->changePassword('admin', 'otherPa$$word'); $userModule->add('other_user', 'pa$$word', 'some@email.com'); $userModule->suspend('other_user'); $userModule->unsuspend('other_user'); $userModule->delete('other_user');
b) web module
$webModule = $client->getModuleWeb('admin'); // web module needs user $webModule->listDomains(); $webModule->addDomain('domain.com'); $webModule->addDomainLetsEncrypt('domain.com', 'www.domain.com'); // needs longer timeout $webModule->deleteDomainLetsEncrypt('domain.com'); $webModule->addDomainFtp('domain.com', 'test', 'pa$$word'); $webModule->changeDomainFtpPassword('domain.com', 'admin_test', 'otherPa$$word'); $webModule->changeDomainFtpPath('domain.com', 'admin_test', 'path/other'); $webModule->deleteDomainFtp('domain.com', 'admin_test'); $webModule->suspendDomain('domain.com'); $webModule->unsuspendDomain('domain.com'); $webModule->deleteDomain('domain.com');
c) mail module
$mailModule = $client->getModuleMail('admin'); // mail module needs user $mailModule->listDomains(); // returns mail domains from selected user $mailModule->addDomain('domain.com'); // add domain $mailModule->listAccounts('domain.com'); // returns accounts from selected user and domain $mailModule->listDomainDkim('domain.com'); $mailModule->listDomainDkimDns('domain.com'); $mailModule->addAccount('domain.com', 'info', 'pa$$word'); // add info@domain.com account $mailModule->changeAccountPassword('domain.com', 'info', 'otherPa$$word'); // change info@domain.com password $mailModule->suspendAccount('domain.com', 'info'); // suspend info@domain.com account $mailModule->unsuspendAccount('domain.com', 'info'); // unsuspend info@domain.com account $mailModule->deleteAccount('domain.com', 'info'); $mailModule->suspendDomain('domain.com'); $mailModule->unsuspendDomain('domain.com'); $mailModule->deleteDomain('domain.com');
d) db module
$dbModule = $client->getModuleDatabase('admin'); $dbModule->add('database', 'dbuser', 'dbpass'); $dbModule->delete('admin_database'); $dbModule->deleteDatabases(); $dbModule->listDatabase('database'); $dbModule->listDatabases(); // todo // ... etc
e) cron module
$cronModule = $client->getModuleCron(); // todo // ... etc
f) backup module
$backupModule = $client->getModuleBackup('admin'); // backup module needs user $backupModule->backup(); // create a new backup $backupModule->delete('admin.2021-10-13_18-12-53.tar'); // delete an user backup $backupModule->deleteExclusions(); // delete all backup exclusions $backupModule->listBackups(); // returns the backups list $backupModule->listBackup('admin.2021-10-13_18-12-53.tar'); // returns backup parameters list $backupModule->listBackupExclusions(); // returns the backup exclusions list
Donate ❤️
BTC: bc1q89ntljt5lk7g9z68f5cjs83qfm2xme7g4hkur7
ETH: 0xeef9220639F14E7A0FD825AAAd0574e5a8aD7A4B
LTC: ltc1q508qfkd09vyya6c5zkfx4r248pf3ezj9ngjdr2