Files
CyberPanel/cli/cyberPanel.py
2025-08-01 14:56:30 +05:00

1603 lines
56 KiB
Python

#!/usr/local/CyberCP/bin/python
import os, sys
sys.path.append('/usr/local/CyberCP')
import django
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "CyberCP.settings")
django.setup()
from inspect import stack
from cli.cliLogger import cliLogger as logger
import json
from plogical.virtualHostUtilities import virtualHostUtilities
import re
from websiteFunctions.models import Websites, ChildDomains
from plogical.dnsUtilities import DNS
import time
import plogical.backupUtilities as backupUtilities
import requests
from loginSystem.models import Administrator
from packages.models import Package
from plogical.mysqlUtilities import mysqlUtilities
from cli.cliParser import cliParser
from plogical.vhost import vhost
from plogical.mailUtilities import mailUtilities
from plogical.ftpUtilities import FTPUtilities
from plogical.sslUtilities import sslUtilities
from plogical.processUtilities import ProcessUtilities
from plogical.backupSchedule import backupSchedule
# All that we see or seem is but a dream within a dream.
def get_cyberpanel_version():
with open('/usr/local/CyberCP/version.txt') as version:
version_file = version.read()
version = json.loads(str(version_file))
return f"{version['version']}.{version['build']}"
class cyberPanel:
def printStatus(self, operationStatus, errorMessage):
data = json.dumps({'success': operationStatus,
'errorMessage': errorMessage
})
print(data)
## Website Functions
def createWebsite(self, package, owner, domainName, email, php, ssl, dkim, openBasedir):
try:
from random import randint
externalApp = "".join(re.findall("[a-zA-Z]+", domainName))[:5] + str(randint(1000, 9999))
phpSelection = 'PHP ' + php
try:
counter = 0
_externalApp = externalApp
while True:
tWeb = Websites.objects.get(externalApp=externalApp)
externalApp = '%s%s' % (_externalApp, str(counter))
counter = counter + 1
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
time.sleep(2)
result = virtualHostUtilities.createVirtualHost(domainName, email, phpSelection, externalApp, ssl, dkim,
openBasedir, owner, package, 0)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(0, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def createDomain(self, masterDomain, domainName, owner, php, ssl, dkim, openBasedir, path):
try:
complete_path = '/home/' + masterDomain + '/' + path
phpSelection = 'PHP ' + php
result = virtualHostUtilities.createDomain(masterDomain, domainName, phpSelection, complete_path, ssl, dkim, openBasedir, owner, 0)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(0, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def deleteWebsite(self, domainName):
try:
vhost.deleteVirtualHostConfigurations(domainName)
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def deleteChild(self, childDomain):
try:
result = virtualHostUtilities.deleteDomain(childDomain)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(0, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listWebsitesJson(self):
try:
websites = Websites.objects.all()
ipFile = "/etc/cyberpanel/machineIP"
with open(ipFile, 'r') as f:
ipData = f.read()
ipAddress = ipData.split('\n', 1)[0]
json_data = []
for items in websites:
if items.state == 0:
state = "Suspended"
else:
state = "Active"
dic = {'domain': items.domain, 'adminEmail': items.adminEmail, 'ipAddress': ipAddress,
'admin': items.admin.userName, 'package': items.package.packageName, 'state': state}
json_data.append(dic)
final_json = json.dumps(json_data)
print(final_json)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listWebsitesPretty(self):
try:
from prettytable import PrettyTable
websites = Websites.objects.all()
ipFile = "/etc/cyberpanel/machineIP"
f = open(ipFile)
ipData = f.read()
ipAddress = ipData.split('\n', 1)[0]
table = PrettyTable(['ID', 'Domain', 'IP Address', 'Package', 'Owner', 'State', 'Email'])
for items in websites:
if items.state == 0:
state = "Suspended"
else:
state = "Active"
table.add_row(
[items.id, items.domain, ipAddress, items.package.packageName, items.admin.userName, state,
items.adminEmail])
print(table)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def changePHP(self, virtualHostName, phpVersion):
try:
phpVersion = 'PHP ' + phpVersion
confPath = virtualHostUtilities.Server_root + "/conf/vhosts/" + virtualHostName
completePathToConfigFile = confPath + "/vhost.conf"
result = vhost.changePHP(completePathToConfigFile, phpVersion)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(0, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def changePackage(self, virtualHostName, packageName):
try:
if Websites.objects.filter(domain=virtualHostName).count() == 0:
self.printStatus(0, 'This website does not exists.')
if Package.objects.filter(packageName=packageName).count() == 0:
self.printStatus(0, 'This package does not exists.')
website = Websites.objects.get(domain=virtualHostName)
package = Package.objects.get(packageName=packageName)
website.package = package
website.save()
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
## DNS Functions
def listDNSJson(self, virtualHostName):
try:
records = DNS.getDNSRecords(virtualHostName)
json_data = "["
checker = 0
for items in records:
dic = {'id': items.id,
'type': items.type,
'name': items.name,
'content': items.content,
'priority': items.prio,
'ttl': items.ttl
}
if checker == 0:
json_data = json_data + json.dumps(dic)
checker = 1
else:
json_data = json_data + ',' + json.dumps(dic)
json_data = json_data + ']'
final_json = json.dumps(json_data)
print(final_json)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listDNSPretty(self, virtualHostName):
try:
from prettytable import PrettyTable
records = DNS.getDNSRecords(virtualHostName)
table = PrettyTable(['ID', 'TYPE', 'Name', 'Value', 'Priority', 'TTL'])
for items in records:
if len(items.content) >= 30:
content = items.content[0:30] + " ..."
else:
content = items.content
table.add_row([items.id, items.type, items.name, content, items.prio, items.ttl])
print(table)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listDNSZonesJson(self):
try:
records = DNS.getDNSZones()
json_data = "["
checker = 0
for items in records:
dic = {'id': items.id,
'name': items.name,
}
if checker == 0:
json_data = json_data + json.dumps(dic)
checker = 1
else:
json_data = json_data + ',' + json.dumps(dic)
json_data = json_data + ']'
final_json = json.dumps(json_data)
print(final_json)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listDNSZonesPretty(self):
try:
from prettytable import PrettyTable
records = records = DNS.getDNSZones()
table = PrettyTable(['ID', 'Name'])
for items in records:
table.add_row([items.id, items.name])
print(table)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def createDNSZone(self, virtualHostName, owner):
try:
admin = Administrator.objects.get(userName=owner)
DNS.dnsTemplate(virtualHostName, admin)
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def createDNSRecord(self, virtualHostName, name, recordType, value, priority, ttl):
try:
import tldextract
no_cache_extract = tldextract.TLDExtract(cache_dir=None)
extractDomain = no_cache_extract(virtualHostName)
topLevelDomain = extractDomain.domain + '.' + extractDomain.suffix
zone = DNS.getZoneObject(topLevelDomain)
DNS.createDNSRecord(zone, name, recordType, value, int(priority), int(ttl))
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def deleteDNSZone(self, virtualHostName):
try:
DNS.deleteDNSZone(virtualHostName)
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def deleteDNSRecord(self, recordID):
try:
DNS.deleteDNSRecord(recordID)
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
## Backup Functions
def createBackup(self, virtualHostName, backupPath=None):
try:
# Setup default backup path to /home/<domain name>/backup if not passed in
if backupPath is None:
backupPath = '/home/' + virtualHostName + '/backup'
# remove trailing slash in path
backupPath = backupPath.rstrip("/")
backuptime = time.strftime("%m.%d.%Y_%H-%M-%S")
backupLogPath = "/usr/local/lscp/logs/backup_log." + backuptime
print('Backup logs to be generated in %s' % (backupLogPath))
tempStoragePath = backupPath + '/backup-' + virtualHostName + '-' + backuptime
backupName = 'backup-' + virtualHostName + '-' + backuptime
backupDomain = virtualHostName
backupUtilities.submitBackupCreation(tempStoragePath, backupName, backupPath, backupDomain)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def restoreBackup(self, fileName):
try:
if os.path.exists('/home/backup/' + fileName):
dir = "CyberPanelRestore"
else:
dir = 'CLI'
backupUtilities.submitRestore(fileName, dir)
while (1):
time.sleep(1)
finalData = json.dumps({'backupFile': fileName, "dir": dir})
r = requests.post("http://localhost:5003/backup/restoreStatus", data=finalData,
verify=False)
data = json.loads(r.text)
if data['abort'] == 1 and data['running'] == "Error":
print('Failed to restore backup, Error message : ' + data['status'] + '\n')
break
elif data['abort'] == 1 and data['running'] == "Completed":
print('\n\n')
print('Backup restore completed.\n')
break
else:
print('Waiting for restore to complete. Current status: ' + data['status'])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
## Packages
def createPackage(self, owner, packageName, diskSpace, bandwidth, emailAccounts, dataBases, ftpAccounts,
allowedDomains):
try:
admin = Administrator.objects.get(userName=owner)
newPack = Package(admin=admin, packageName=packageName, diskSpace=diskSpace, bandwidth=bandwidth,
emailAccounts=emailAccounts, dataBases=dataBases, ftpAccounts=ftpAccounts,
allowedDomains=allowedDomains)
newPack.save()
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def deletePackage(self, packageName):
try:
delPack = Package.objects.get(packageName=packageName)
delPack.delete()
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def listPackagesJson(self):
try:
records = Package.objects.all()
json_data = "["
checker = 0
for items in records:
dic = {'id': items.id,
'packageName': items.packageName,
'domains': items.allowedDomains,
'diskSpace': items.diskSpace,
'bandwidth': items.bandwidth,
'ftpAccounts ': items.ftpAccounts,
'dataBases': items.dataBases,
'emailAccounts': items.emailAccounts
}
if checker == 0:
json_data = json_data + json.dumps(dic)
checker = 1
else:
json_data = json_data + ',' + json.dumps(dic)
json_data = json_data + ']'
final_json = json.dumps(json_data)
print(final_json)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listPackagesPretty(self):
try:
from prettytable import PrettyTable
records = Package.objects.all()
table = PrettyTable(
['Name', 'Domains', 'Disk Space', 'Bandwidth', 'FTP Accounts', 'Databases', 'Email Accounts'])
for items in records:
table.add_row(
[items.packageName, items.allowedDomains, items.diskSpace, items.bandwidth, items.ftpAccounts,
items.dataBases, items.emailAccounts])
print(table)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
## Database functions
def createDatabase(self, dbName, dbUsername, dbPassword, databaseWebsite):
try:
result = mysqlUtilities.submitDBCreation(dbName, dbUsername, dbPassword, databaseWebsite)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def deleteDatabase(self, dbName):
try:
result = mysqlUtilities.submitDBDeletion(dbName)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def listDatabasesJson(self, virtualHostName):
try:
records = mysqlUtilities.getDatabases(virtualHostName)
json_data = "["
checker = 0
for items in records:
dic = {'id': items.id,
'dbName': items.dbName,
'dbUser': items.dbUser,
}
if checker == 0:
json_data = json_data + json.dumps(dic)
checker = 1
else:
json_data = json_data + ',' + json.dumps(dic)
json_data = json_data + ']'
final_json = json.dumps(json_data)
print(final_json)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listDatabasesPretty(self, virtualHostName):
try:
from prettytable import PrettyTable
records = mysqlUtilities.getDatabases(virtualHostName)
table = PrettyTable(['ID', 'Database Name', 'Database User'])
for items in records:
table.add_row([items.id, items.dbName, items.dbUser])
print(table)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
## Email functions
def createEmail(self, domain, userName, password):
try:
result = mailUtilities.createEmailAccount(domain, userName, password)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def deleteEmail(self, email):
try:
result = mailUtilities.deleteEmailAccount(email)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def changeEmailPassword(self, email, password):
try:
result = mailUtilities.changeEmailPassword(email, password)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def listEmailsJson(self, virtualHostName):
try:
records = mailUtilities.getEmailAccounts(virtualHostName)
json_data = "["
checker = 0
for items in records:
dic = {
'email': items.email,
}
if checker == 0:
json_data = json_data + json.dumps(dic)
checker = 1
else:
json_data = json_data + ',' + json.dumps(dic)
json_data = json_data + ']'
final_json = json.dumps(json_data)
print(final_json)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listEmailsPretty(self, virtualHostName):
try:
from prettytable import PrettyTable
records = mailUtilities.getEmailAccounts(virtualHostName)
table = PrettyTable(['Email'])
for items in records:
table.add_row([items.email])
print(table)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
## FTP Functions
## FTP Functions
# FTP Functions
def createFTPAccount(self, domain, userName, password, owner):
try:
result = FTPUtilities.submitFTPCreation(domain, userName, password, 'None', owner)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def deleteFTPAccount(self, userName):
try:
result = FTPUtilities.submitFTPDeletion(userName)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def changeFTPPassword(self, userName, password):
try:
result = FTPUtilities.changeFTPPassword(userName, password)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def listFTPJson(self, virtualHostName):
try:
records = FTPUtilities.getFTPRecords(virtualHostName)
json_data = "["
checker = 0
for items in records:
dic = {'id': items.id,
'username': items.user,
'path': items.dir
}
if checker == 0:
json_data = json_data + json.dumps(dic)
checker = 1
else:
json_data = json_data + ',' + json.dumps(dic)
json_data = json_data + ']'
final_json = json.dumps(json_data)
print(final_json)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
def listFTPPretty(self, virtualHostName):
try:
from prettytable import PrettyTable
records = FTPUtilities.getFTPRecords(virtualHostName)
table = PrettyTable(['ID', 'User', 'Path'])
for items in records:
table.add_row([items.id, items.user, items.dir])
print(table)
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
print(0)
## FTP Functions
## SSL Functions
def issueSSL(self, virtualHost):
try:
path = ''
adminEmail = ''
try:
website = ChildDomains.objects.get(domain=virtualHost)
adminEmail = website.master.adminEmail
path = website.path
except:
website = Websites.objects.get(domain=virtualHost)
adminEmail = website.adminEmail
path = "/home/" + virtualHost + "/public_html"
result = virtualHostUtilities.issueSSL(virtualHost, path, adminEmail)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def issueSSLForHostName(self, virtualHost):
try:
path = ''
adminEmail = ''
try:
website = ChildDomains.objects.get(domain=virtualHost)
adminEmail = website.master.adminEmail
path = website.path
except:
website = Websites.objects.get(domain=virtualHost)
adminEmail = website.adminEmail
path = "/home/" + virtualHost + "/public_html"
result = virtualHostUtilities.issueSSLForHostName(virtualHost, path)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def issueSSLForMailServer(self, virtualHost):
try:
path = ''
adminEmail = ''
try:
website = ChildDomains.objects.get(domain=virtualHost)
adminEmail = website.master.adminEmail
path = website.path
except:
website = Websites.objects.get(domain=virtualHost)
adminEmail = website.adminEmail
path = "/home/" + virtualHost + "/public_html"
result = virtualHostUtilities.issueSSLForMailServer(virtualHost, path)
if result[0] == 1:
self.printStatus(1, 'None')
else:
self.printStatus(1, result[1])
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def issueSelfSignedSSL(self, virtualHost):
try:
try:
website = ChildDomains.objects.get(domain=virtualHost)
adminEmail = website.master.adminEmail
except:
website = Websites.objects.get(domain=virtualHost)
adminEmail = website.adminEmail
pathToStoreSSL = "/etc/letsencrypt/live/" + virtualHost
command = 'mkdir -p ' + pathToStoreSSL
ProcessUtilities.executioner(command)
pathToStoreSSLPrivKey = "/etc/letsencrypt/live/" + virtualHost + "/privkey.pem"
pathToStoreSSLFullChain = "/etc/letsencrypt/live/" + virtualHost + "/fullchain.pem"
command = 'openssl req -newkey rsa:2048 -new -nodes -x509 -days 3650 -subj "/C=US/ST=Denial/L=Springfield/O=Dis/CN=www.example.com" -keyout ' + pathToStoreSSLPrivKey + ' -out ' + pathToStoreSSLFullChain
ProcessUtilities.executioner(command)
sslUtilities.installSSLForDomain(virtualHost, adminEmail)
ProcessUtilities.restartLitespeed()
self.printStatus(1, 'None')
except BaseException as msg:
logger.writeforCLI(str(msg), "Error", stack()[0][3])
self.printStatus(0, str(msg))
def main():
parser = cliParser()
args = parser.prepareArguments()
cyberpanel = cyberPanel()
## Website functions
if args.function == "createWebsite":
completeCommandExample = 'cyberpanel createWebsite --package Detault --owner admin --domainName cyberpanel.net --email support@cyberpanel.net --php 5.6'
if not args.package:
print("\n\nPlease enter the package name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.owner:
print("\n\nPlease enter the owner name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.domainName:
print("\n\nPlease enter the domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.email:
print("\n\nPlease enter the email. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.php:
print("\n\nPlease enter the PHP version such as 5.6 for PHP version 5.6. For example:\n\n" + completeCommandExample + "\n\n")
return
if args.ssl:
ssl = int(args.ssl)
else:
ssl = 0
if args.dkim:
dkim = int(args.dkim)
else:
dkim = 0
if args.openBasedir:
openBasedir = int(args.openBasedir)
else:
openBasedir = 0
cyberpanel.createWebsite(args.package, args.owner, args.domainName, args.email, args.php, ssl, dkim,
openBasedir)
elif args.function == "deleteWebsite":
completeCommandExample = 'cyberpanel deleteWebsite --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter the domain to delete. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.deleteWebsite(args.domainName)
elif args.function == "createChild":
completeCommandExample = 'cyberpanel createChild --masterDomain cyberpanel.net --childDomain child.cyberpanel.net' \
' --owner admin --php 5.6'
if not args.masterDomain:
print("\n\nPlease enter Master domain. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.childDomain:
print("\n\nPlease enter the Child Domain. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.owner:
print("\n\nPlease enter owner for this domain DNS records. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.php:
print("\n\nPlease enter required PHP version. For example:\n\n" + completeCommandExample + "\n\n")
return
if args.ssl:
ssl = int(args.ssl)
else:
ssl = 0
if args.dkim:
dkim = int(args.dkim)
else:
dkim = 0
if args.openBasedir:
openBasedir = int(args.openBasedir)
else:
openBasedir = 0
if args.path:
path = args.path
else:
path = "public_html/" + args.childDomain
cyberpanel.createDomain(args.masterDomain, args.childDomain, args.owner, args.php, ssl, dkim, openBasedir, path)
elif args.function == "deleteChild":
completeCommandExample = 'cyberpanel deleteChild --childDomain cyberpanel.net'
if not args.childDomain:
print("\n\nPlease enter the child domain to delete. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.deleteChild(args.childDomain)
elif args.function == "listWebsitesJson":
cyberpanel.listWebsitesJson()
elif args.function == "listWebsitesPretty":
cyberpanel.listWebsitesPretty()
elif args.function == "changePHP":
completeCommandExample = 'cyberpanel changePHP --domainName cyberpanel.net --php 5.6'
if not args.domainName:
print("\n\nPlease enter Domain. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.php:
print("\n\nPlease enter required PHP version. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.changePHP(args.domainName, args.php)
elif args.function == "changePackage":
completeCommandExample = 'cyberpanel changePackage --domainName cyberpanel.net --packageName CLI'
if not args.domainName:
print("\n\nPlease enter the Domain. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.packageName:
print("\n\nPlease enter the package name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.changePackage(args.domainName, args.packageName)
## DNS Functions
elif args.function == "listDNSJson":
completeCommandExample = 'cyberpanel listDNSJson --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter the domain. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.listDNSJson(args.domainName)
elif args.function == "listDNSPretty":
completeCommandExample = 'cyberpanel listDNSPretty --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter the domain. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.listDNSPretty(args.domainName)
elif args.function == "listDNSZonesJson":
cyberpanel.listDNSZonesJson()
elif args.function == "listDNSZonesPretty":
cyberpanel.listDNSZonesPretty()
elif args.function == "createDNSZone":
completeCommandExample = 'cyberpanel createDNSZone --owner admin --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter the domain. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.owner:
print("\n\nPlease enter the owner name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.createDNSZone(args.domainName, args.owner)
elif args.function == "deleteDNSZone":
completeCommandExample = 'cyberpanel deleteDNSZone --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter the domain. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.deleteDNSZone(args.domainName)
elif args.function == "createDNSRecord":
completeCommandExample = 'cyberpanel createDNSRecord --domainName cyberpanel.net --name cyberpanel.net' \
' --recordType A --value 192.168.100.1 --priority 0 --ttl 3600'
if not args.domainName:
print("\n\nPlease enter the domain. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.name:
print("\n\nPlease enter the record name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.recordType:
print("\n\nPlease enter the record type. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.value:
print("\n\nPlease enter the record value. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.priority:
print("\n\nPlease enter the priority. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.ttl:
print("\n\nPlease enter the ttl. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.createDNSRecord(args.domainName, args.name, args.recordType, args.value, args.priority, args.ttl)
elif args.function == "deleteDNSRecord":
completeCommandExample = 'cyberpanel deleteDNSRecord --recordID 200'
if not args.recordID:
print("\n\nPlease enter the record ID to be deleted, you can find record ID by listing the current DNS records. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.deleteDNSRecord(args.recordID)
## Backup Functions.
elif args.function == "createBackup":
completeCommandExample = 'cyberpanel createBackup --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter the domain. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.createBackup(args.domainName)
elif args.function == "restoreBackup":
completeCommandExample = 'cyberpanel restoreBackup --fileName /home/talkshosting.com/backup/backup-talksho-01-30-53-Fri-Jun-2018.tar.gz'
if not args.fileName:
print("\n\nPlease enter the file name or complete path to file. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.restoreBackup(args.fileName)
## Package functions.
elif args.function == "createPackage":
completeCommandExample = 'cyberpanel createPackage --owner admin --packageName CLI --diskSpace 1000 --bandwidth 10000 --emailAccounts 100' \
' --dataBases 100 --ftpAccounts 100 --allowedDomains 100'
if not args.owner:
print("\n\nPlease enter the owner name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.packageName:
print("\n\nPlease enter the package name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.diskSpace:
print("\n\nPlease enter value for Disk Space. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.bandwidth:
print("\n\nPlease enter value for Bandwidth. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.emailAccounts:
print("\n\nPlease enter value for Email accounts. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.dataBases:
print("\n\nPlease enter value for Databases. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.ftpAccounts:
print("\n\nPlease enter value for Ftp accounts. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.allowedDomains:
print("\n\nPlease enter value for Allowed Child Domains. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.createPackage(args.owner, args.packageName, args.diskSpace, args.bandwidth, args.emailAccounts,
args.dataBases, args.ftpAccounts, args.allowedDomains)
elif args.function == "deletePackage":
completeCommandExample = 'cyberpanel deletePackage --packageName CLI'
if not args.packageName:
print("\n\nPlease enter the package name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.deletePackage(args.packageName)
elif args.function == "listPackagesJson":
cyberpanel.listPackagesJson()
elif args.function == "listPackagesPretty":
cyberpanel.listPackagesPretty()
## Database functions.
elif args.function == "createDatabase":
completeCommandExample = 'cyberpanel createDatabase --databaseWebsite cyberpanel.net --dbName cyberpanel ' \
'--dbUsername cyberpanel --dbPassword cyberpanel'
if not args.databaseWebsite:
print("\n\nPlease enter database website. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.dbName:
print("\n\nPlease enter the database name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.dbUsername:
print("\n\nPlease enter the database username. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.dbPassword:
print("\n\nPlease enter the password for database. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.createDatabase(args.dbName, args.dbUsername, args.dbPassword, args.databaseWebsite)
elif args.function == "deleteDatabase":
completeCommandExample = 'cyberpanel deleteDatabase --dbName cyberpanel'
if not args.dbName:
print("\n\nPlease enter the database name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.deleteDatabase(args.dbName)
elif args.function == "listDatabasesJson":
completeCommandExample = 'cyberpanel listDatabasesJson --databaseWebsite cyberpanel.net'
if not args.databaseWebsite:
print("\n\nPlease enter database website. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.listDatabasesJson(args.databaseWebsite)
elif args.function == "listDatabasesPretty":
completeCommandExample = 'cyberpanel listDatabasesPretty --databaseWebsite cyberpanel.net'
if not args.databaseWebsite:
print("\n\nPlease enter database website. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.listDatabasesPretty(args.databaseWebsite)
## Email Functions
elif args.function == "createEmail":
completeCommandExample = 'cyberpanel createEmail --domainName cyberpanel.net --userName cyberpanel ' \
'--password cyberpanel'
if not args.domainName:
print("\n\nPlease enter Domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.userName:
print("\n\nPlease enter the user name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.password:
print("\n\nPlease enter the password for database. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.createEmail(args.domainName, args.userName, args.password)
elif args.function == "deleteEmail":
completeCommandExample = 'cyberpanel deleteEmail --email cyberpanel@cyberpanel.net'
if not args.email:
print("\n\nPlease enter the email. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.deleteEmail(args.email)
elif args.function == "changeEmailPassword":
completeCommandExample = 'cyberpanel changeEmailPassword --email cyberpanel@cyberpanel.net --password cyberpanel'
if not args.email:
print("\n\nPlease enter email. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.password:
print("\n\nPlease enter the password. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.changeEmailPassword(args.email, args.password)
elif args.function == "listEmailsJson":
completeCommandExample = 'cyberpanel listEmailsJson --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.listEmailsJson(args.domainName)
elif args.function == "listEmailsPretty":
completeCommandExample = 'cyberpanel listEmailsPretty --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.listEmailsPretty(args.domainName)
## FTP Functions
elif args.function == "createFTPAccount":
completeCommandExample = 'cyberpanel createFTPAccount --domainName cyberpanel.net --userName cyberpanel ' \
'--password cyberpanel --owner admin'
if not args.domainName:
print("\n\nPlease enter Domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.userName:
print("\n\nPlease enter the user name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.password:
print("\n\nPlease enter the password for database. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.owner:
print("\n\nPlease enter the owner name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.createFTPAccount(args.domainName, args.userName, args.password, args.owner)
elif args.function == "deleteFTPAccount":
completeCommandExample = 'cyberpanel deleteFTPAccount --userName cyberpanel'
if not args.userName:
print("\n\nPlease enter the user name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.deleteFTPAccount(args.userName)
elif args.function == "changeFTPPassword":
completeCommandExample = 'cyberpanel changeFTPPassword --userName cyberpanel --password cyberpanel'
if not args.userName:
print("\n\nPlease enter the user name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.password:
print("\n\nPlease enter the password for database. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.changeFTPPassword(args.userName, args.password)
elif args.function == "listFTPJson":
completeCommandExample = 'cyberpanel listFTPJson --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.listFTPJson(args.domainName)
elif args.function == "listFTPPretty":
completeCommandExample = 'cyberpanel listFTPPretty --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.listFTPPretty(args.domainName)
## SSL Functions
elif args.function == "issueSSL":
completeCommandExample = 'cyberpanel issueSSL --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter Domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.issueSSL(args.domainName)
elif args.function == "hostNameSSL":
completeCommandExample = 'cyberpanel hostNameSSL --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter Domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.issueSSLForHostName(args.domainName)
elif args.function == "mailServerSSL":
completeCommandExample = 'cyberpanel mailServerSSL --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter Domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.issueSSLForMailServer(args.domainName)
elif args.function == "issueSelfSignedSSL":
completeCommandExample = 'cyberpanel issueSelfSignedSSL --domainName cyberpanel.net'
if not args.domainName:
print("\n\nPlease enter Domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
cyberpanel.issueSelfSignedSSL(args.domainName)
elif args.function == 'utility':
if not os.path.exists('/usr/bin/cyberpanel_utility'):
command = 'wget -q -O /usr/bin/cyberpanel_utility https://cyberpanel.sh/misc/cyberpanel_utility.sh'
ProcessUtilities.executioner(command)
command = 'chmod 700 /usr/bin/cyberpanel_utility'
ProcessUtilities.executioner(command)
command = '/usr/bin/cyberpanel_utility'
ProcessUtilities.executioner(command)
elif args.function == 'upgrade' or args.function == 'update':
if not os.path.exists('/usr/bin/cyberpanel_utility'):
command = 'wget -q -O /usr/bin/cyberpanel_utility https://cyberpanel.sh/misc/cyberpanel_utility.sh'
ProcessUtilities.executioner(command)
command = 'chmod 700 /usr/bin/cyberpanel_utility'
ProcessUtilities.executioner(command)
command = '/usr/bin/cyberpanel_utility --upgrade'
ProcessUtilities.executioner(command)
elif args.function == 'help':
if not os.path.exists('/usr/bin/cyberpanel_utility'):
command = 'wget -q -O /usr/bin/cyberpanel_utility https://cyberpanel.sh/misc/cyberpanel_utility.sh'
ProcessUtilities.executioner(command)
command = 'chmod 700 /usr/bin/cyberpanel_utility'
ProcessUtilities.executioner(command)
command = '/usr/bin/cyberpanel_utility --help'
ProcessUtilities.executioner(command)
elif args.function == 'version' or args.function == 'v' or args.function == 'V':
## Get CurrentVersion
print(get_cyberpanel_version())
### User Functions
elif args.function == "createUser":
completeCommandExample = 'cyberpanel createUser --firstName Cyber --lastName Panel --email email@cyberpanel.net --userName cyberpanel --password securepassword --websitesLimit 10 --selectedACL user --securityLevel HIGH'
if not args.firstName:
print("\n\nPlease enter First Name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.lastName:
print("\n\nPlease enter Last Name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.email:
print("\n\nPlease enter Email. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.userName:
print("\n\nPlease enter User name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.password:
print("\n\nPlease enter password. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.websitesLimit:
print("\n\nPlease enter website limit. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.selectedACL:
print("\n\nPlease enter select acl. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.securityLevel:
print("\n\nPlease set security level. For example:\n\n" + completeCommandExample + "\n\n")
return
from userManagment.views import submitUserCreation
data = {}
data['firstName'] = args.firstName
data['lastName'] = args.lastName
data['email'] = args.email
data['userName'] = args.userName
data['password'] = args.password
data['websitesLimit'] = args.websitesLimit
data['selectedACL'] = args.selectedACL
data['securityLevel'] = args.securityLevel
data['userID'] = 1
response = submitUserCreation(data)
print(response.content.decode())
elif args.function == "deleteUser":
completeCommandExample = 'cyberpanel deleteUser --userName cyberpanel'
if not args.userName:
print("\n\nPlease enter User Name. For example:\n\n" + completeCommandExample + "\n\n")
return
from userManagment.views import submitUserDeletion
data = {}
data['accountUsername'] = args.userName
data['userID'] = 1
response = submitUserDeletion(data)
print(response.content.decode())
elif args.function == "listUsers":
from userManagment.views import fetchTableUsers
data = {}
data['userID'] = 1
response = fetchTableUsers(data)
print(response.content.decode())
elif args.function == "suspendUser":
completeCommandExample = 'cyberpanel suspendUser --userName cyberpanel --state SUSPEND'
if not args.userName:
print("\n\nPlease enter User Name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.state:
print("\n\nPlease enter state value i.e SUSPEND/UnSuspend. For example:\n\n" + completeCommandExample + "\n\n")
return
from userManagment.views import controlUserState
data = {}
data['accountUsername'] = args.userName
data['state'] = args.state
data['userID'] = 1
response = controlUserState(data)
print(response.content.decode())
elif args.function == "editUser":
completeCommandExample = 'cyberpanel editUser --userName cyberpanel --firstName Cyber --lastName Panel --email email@cyberpanel.net --password securepassword --securityLevel HIGH'
if not args.firstName:
print("\n\nPlease enter First Name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.lastName:
print("\n\nPlease enter Last Name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.email:
print("\n\nPlease enter Email. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.userName:
print("\n\nPlease enter User name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.password:
print("\n\nPlease enter password. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.securityLevel:
print("\n\nPlease set security level. For example:\n\n" + completeCommandExample + "\n\n")
return
from userManagment.views import saveModifications
data = {}
data['accountUsername'] = args.userName
data['firstName'] = args.firstName
data['lastName'] = args.lastName
data['email'] = args.email
data['passwordByPass'] = args.password
data['securityLevel'] = args.securityLevel
data['userID'] = 1
response = saveModifications(data)
print(response.content.decode())
### Application installers
elif args.function == "installWordPress":
completeCommandExample = 'cyberpanel installWordPress --domainName cyberpanel.net --email support@cyberpanel.net --userName cyberpanel --password helloworld --siteTitle "WordPress Site" --path helloworld (this is optional)'
if not args.domainName:
print("\n\nPlease enter Domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.email:
print("\n\nPlease enter email. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.userName:
print("\n\nPlease enter User name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.password:
print("\n\nPlease enter password. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.siteTitle:
print("\n\nPlease enter site title. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.path:
home = '1'
path = ''
else:
home = '0'
path = args.path
from websiteFunctions.website import WebsiteManager
data = {}
data['adminUser'] = args.userName
data['blogTitle'] = args.siteTitle
data['domain'] = args.domainName
data['adminEmail'] = args.email
data['passwordByPass'] = args.password
data['home'] = home
data['path'] = path
wm = WebsiteManager()
wm.installWordpress(1, data)
elif args.function == "installJoomla":
completeCommandExample = 'cyberpanel installJoomla --domainName cyberpanel.net --password helloworld --siteTitle "WordPress Site" --path helloworld (this is optional)'
if not args.domainName:
print("\n\nPlease enter Domain name. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.password:
print("\n\nPlease enter password. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.siteTitle:
print("\n\nPlease enter site title. For example:\n\n" + completeCommandExample + "\n\n")
return
if not args.path:
home = '1'
path = ''
else:
home = '0'
path = args.path
from websiteFunctions.website import WebsiteManager
data = {}
data['prefix'] = 'jm_'
data['siteName'] = args.siteTitle
data['domain'] = args.domainName
data['passwordByPass'] = args.password
data['home'] = home
data['path'] = path
wm = WebsiteManager()
wm.installJoomla(1, data)
elif args.function == "switchTOLSWS":
completeCommandExample = 'cyberpanel switchTOLSWS --licenseKey <Your lsws key here or you can enter TRIAL)'
if not args.licenseKey:
print("\n\nPlease enter LiteSpeed License key. For example:\n\n" + completeCommandExample + "\n\n")
return
from serverStatus.serverStatusUtil import ServerStatusUtil
ServerStatusUtil.switchTOLSWSCLI(args.licenseKey)
if __name__ == "__main__":
main()