Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/burakboz/cyberlink
A php library to utilize CyberPanel without API.
https://github.com/burakboz/cyberlink
api automation controlpanel cyberpanel library php webserver
Last synced: about 2 months ago
JSON representation
A php library to utilize CyberPanel without API.
- Host: GitHub
- URL: https://github.com/burakboz/cyberlink
- Owner: BurakBoz
- License: mit
- Created: 2019-09-22T03:56:23.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-08-31T08:45:35.000Z (over 1 year ago)
- Last Synced: 2024-08-27T21:36:39.511Z (4 months ago)
- Topics: api, automation, controlpanel, cyberpanel, library, php, webserver
- Language: PHP
- Homepage:
- Size: 15.6 KB
- Stars: 8
- Watchers: 4
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.MD
- Changelog: CHANGELOG
- License: LICENSE
Awesome Lists containing this project
README
# CyberLink for CyberPanel
## A php library to utilize CyberPanel without API.
[Take a look](https://cyberpanel.docs.apiary.io/) to CyberPanel api documentation, yes almost nothing.
```
Currently CyberPanel doesn't have API functions fully described and implemented.
So I wrote this library.
```##Composer Install
`composer require burakboz/cyberlink:dev-master`##Example usage
```
// If you need public key auth on ssh connection provide private key string to $key parameter otherwise it should be null.
// $enableSecureFTP parameter should be true for using setCustomSSL method.
// If you don't need this don't set it true.
$ip = "127.0.0.1";
$user = "root"; // use only root user
$password = "TopSecretPassword"; // root password
$port = 22; // ssh port
$timeout = 20; // connection timeout
$enableSecureFTP = false; // set it true if you use $cyberlink->setCustomSSL() method.
$cyberlink = new \BurakBoz\CyberLink($ip, $user, $password, $key = null, $port = 22, $timeout = 10, $enableSecureFTP = false);
$phpVersion = "7.3";
$owner = "admin";
$package = "Default";
try
{
if($cyberlink->createWebsite("merhaba.com", "[email protected]", $package, $owner, $phpVersion))
{
echo "Host created.";
}
else
{
echo "Error: " . $cyberlink->getLastMessage();
}
}
catch (Exception $e)
{
echo "Error: " . $e->getMessage();
}
```### What is the magic of this library?
#### Website Functions
##### createWebsite
```
/**
* @param $domainName
* @param $email
* @param string $package
* @param string $owner
* @param string $phpVersion
* @return bool
* @throws Exception
*/
$cyberlink->createWebsite($domainName, $email, $package = self::package, $owner = self::owner, $phpVersion = self::phpVersion);
```##### deleteWebsite
```
/**
* @param $domainName
* @return bool
* @throws Exception
*/
$cyberlink->deleteWebsite($domainName);
```##### createChild
```
/**
* @param $masterDomain
* @param $childDomain
* @param string $owner
* @param string $phpVersion
* @return bool
* @throws Exception
*/
$cyberlink->createChild($masterDomain, $childDomain, $owner = self::owner, $phpVersion = self::phpVersion);
```##### deleteChild
```
/**
* @param $childDomain
* @return bool
* @throws Exception
*/
$cyberlink->deleteChild($childDomain);
```##### listWebsites
```
/**
* @return mixed
*/
$cyberlink->listWebsites();
```##### changePHP
```
/**
* @param $domainName
* @param string $phpVersion
* @return bool
* @throws Exception
*/
$cyberlink->changePHP($domainName, $phpVersion = self::phpVersion);
```##### changePackage
```
/**
* @param $domainName
* @param string $packageName
* @return bool
* @throws Exception
*/
$cyberlink->changePackage($domainName, $packageName = self::package);
```
#### DNS Functions
###### Not Implemented yet.#### Backup Functions
##### createBackup
```
/**
* @param $domainName
* @return bool
* @throws Exception
*/
$cyberlink->createBackup($domainName);
```
##### restoreBackup
```
/**
* @param $domainName
* @param $fileName
* @return bool
* @throws Exception
*/
$cyberlink->restoreBackup($domainName, $fileName);
```#### Package Functions
##### createPackage
```
/**
* @param $packageName
* @param int $diskSpace
* @param int $bandwidth
* @param int $emailAccounts
* @param int $dataBases
* @param int $ftpAccounts
* @param int $allowedDomains
* @param string $owner
* @return bool
* @throws Exception
*/
$cyberlink->createPackage($packageName, $diskSpace = 1000, $bandwidth = 10000, $emailAccounts = 100, $dataBases = 100, $ftpAccounts = 100, $allowedDomains = 100, $owner = self::owner);
```
##### deletePackage
```
/**
* @param $packageName
* @return bool
* @throws Exception
*/
$cyberlink->deletePackage($packageName);
```
##### listPackages
```
/**
* @return mixed
*/
$cyberlink->listPackages();
```#### Database Functions
##### createDatabase
```
/**
* @param $databaseWebsite
* @param $dbName
* @param $dbUsername
* @param $dbPassword
* @return bool
* @throws Exception
*/
$cyberlink->createDatabase($databaseWebsite, $dbName, $dbUsername, $dbPassword);
```
##### deleteDatabase
```
/**
* @param $dbName
* @return bool
* @throws Exception
*/
$cyberlink->deleteDatabase($dbName);
```
##### listDatabases
```
/**
* @param $databaseWebsite
* @return mixed
*/
$cyberlink->listDatabases($databaseWebsite);
```
#### Email Functions
###### Not Implemented yet.
#### FTP Functions
##### createFTPAccount
```
/**
* @param $domainName
* @param $userName
* @param $password
* @param string $owner
* @return bool
* @throws Exception
*/
$cyberlink->createFTPAccount($domainName, $userName, $password, $owner = self::owner);
```
##### deleteFTPAccount
```
/**
* @param $userName
* @return bool
* @throws Exception
*/
$cyberlink->deleteFTPAccount($userName);
```
##### changeFTPPassword
```
/**
* @param $userName
* @param $password
* @return bool
* @throws Exception
*/
$cyberlink->changeFTPPassword($userName, $password);
```
##### listFTP
```
/**
* @param $domainName
* @return mixed
*/
$cyberlink->listFTP($domainName);
```
#### SSL Functions
##### issueSSL
```
/**
* @param $domainName
* @return bool
* @throws Exception
*/
$cyberlink->issueSSL($domainName);
```
##### hostNameSSL
```
/**
* @param $domainName
* @return bool
* @throws Exception
*/
$cyberlink->hostNameSSL($domainName);
```
##### mailServerSSL
```
/**
* @param $domainName
* @return bool
* @throws Exception
*/
$cyberlink->mailServerSSL($domainName);
```
#### Extra Functions##### Set Custom SSL
```
/**
* Warning! This method shouldn't be trusted. In future versions of CyberPanel (Currently 1.9) and LiteSpeed may cause system failure. Use at your own risk.
* @param $domain
* @param $publicKey
* @param $privateKey
* @return bool
* @throws Exception
*/
$cyberlink->setCustomSSL($domain, $publicKey, $privateKey);
```
##### Reset CyberPanel Admin Password
```
/**
* @param $password
* @return string
*/
$cyberlink->resetAdminPassword($password);
```
##### Upgrade CyberPanel
```
/**
* @return string
*/
$cyberlink->upgradeCyberPanel();
```
##### Restart LiteSpeed
```
/**
* @return string
*/
$cyberlink->restartLiteSpeed();
```
##### Reboot Server
```
/**
* @return string
*/
$cyberlink->rebootServer();
```
##### Server Uptime
```
/**
* @return string
*/
$cyberlink->uptime();
```