File manager - Edit - /usr/local/CyberCP/cyberpanel/cli/cyberPanel.py
Back
#!/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()
| ver. 1.4 |
Github
|
.
| PHP 8.2.28 | Generation time: 0.02 |
proxy
|
phpinfo
|
Settings