2017-10-24 19:16:36 +05:00
|
|
|
import os
|
2018-07-19 22:38:37 +05:00
|
|
|
import os.path
|
|
|
|
|
import sys
|
|
|
|
|
import django
|
|
|
|
|
sys.path.append('/usr/local/CyberCP')
|
|
|
|
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "CyberCP.settings")
|
|
|
|
|
django.setup()
|
2017-10-24 19:16:36 +05:00
|
|
|
import shlex
|
|
|
|
|
import subprocess
|
2018-04-23 19:23:03 +05:00
|
|
|
import shutil
|
2017-10-24 19:16:36 +05:00
|
|
|
import requests
|
2018-04-23 19:23:03 +05:00
|
|
|
import json
|
2018-05-14 22:26:25 +05:00
|
|
|
import time
|
2018-07-19 22:38:37 +05:00
|
|
|
from baseTemplate.models import version
|
2018-12-14 05:01:10 +05:00
|
|
|
import MySQLdb as mysql
|
2018-12-20 16:18:16 +05:00
|
|
|
from CyberCP import settings
|
2017-10-24 19:16:36 +05:00
|
|
|
|
|
|
|
|
class Upgrade:
|
|
|
|
|
logPath = "/usr/local/lscp/logs/upgradeLog"
|
|
|
|
|
|
2018-07-19 22:38:37 +05:00
|
|
|
@staticmethod
|
2018-12-14 05:01:10 +05:00
|
|
|
def stdOut(message, do_exit = 0):
|
2018-07-19 22:38:37 +05:00
|
|
|
print("\n\n")
|
|
|
|
|
print ("[" + time.strftime(
|
|
|
|
|
"%I-%M-%S-%a-%b-%Y") + "] #########################################################################\n")
|
|
|
|
|
print("[" + time.strftime("%I-%M-%S-%a-%b-%Y") + "] " + message + "\n")
|
|
|
|
|
print ("[" + time.strftime(
|
|
|
|
|
"%I-%M-%S-%a-%b-%Y") + "] #########################################################################\n")
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
if do_exit:
|
|
|
|
|
os._exit(0)
|
|
|
|
|
|
2018-11-14 13:36:34 +05:00
|
|
|
@staticmethod
|
2018-12-14 05:01:10 +05:00
|
|
|
def executioner(command, component, do_exit = 0):
|
2018-11-14 13:36:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
count = 0
|
|
|
|
|
while True:
|
|
|
|
|
res = subprocess.call(shlex.split(command))
|
|
|
|
|
if res != 0:
|
|
|
|
|
count = count + 1
|
|
|
|
|
Upgrade.stdOut(component + ' failed, trying again, try number: ' + str(count), 0)
|
|
|
|
|
if count == 3:
|
|
|
|
|
Upgrade.stdOut(component + ' failed.', do_exit)
|
|
|
|
|
return False
|
|
|
|
|
else:
|
|
|
|
|
Upgrade.stdOut(component + ' successful.', 0)
|
|
|
|
|
break
|
|
|
|
|
return True
|
2018-11-14 13:36:34 +05:00
|
|
|
except:
|
|
|
|
|
return 0
|
|
|
|
|
|
2017-10-24 19:16:36 +05:00
|
|
|
@staticmethod
|
2018-04-23 19:23:03 +05:00
|
|
|
def downloadLink():
|
2018-07-19 22:38:37 +05:00
|
|
|
try:
|
|
|
|
|
url = "https://cyberpanel.net/version.txt"
|
|
|
|
|
r = requests.get(url, verify=True)
|
|
|
|
|
data = json.loads(r.text)
|
|
|
|
|
version_number = str(data['version'])
|
2018-08-21 13:10:40 +05:00
|
|
|
version_build = str(data['build'])
|
2018-07-19 22:38:37 +05:00
|
|
|
return (version_number + "." + version_build + ".tar.gz")
|
|
|
|
|
except BaseException, msg:
|
|
|
|
|
Upgrade.stdOut(str(msg) + ' [downloadLink]')
|
|
|
|
|
os._exit(0)
|
|
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def setupVirtualEnv():
|
|
|
|
|
try:
|
2018-11-14 13:36:34 +05:00
|
|
|
Upgrade.stdOut('Setting up virtual environment for CyberPanel.')
|
2018-07-19 22:38:37 +05:00
|
|
|
##
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = "yum install -y libattr-devel xz-devel gpgme-devel mariadb-devel curl-devel"
|
|
|
|
|
Upgrade.executioner(command, 'VirtualEnv Pre-reqs', 0)
|
|
|
|
|
|
2018-07-19 22:38:37 +05:00
|
|
|
|
|
|
|
|
##
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = "pip install virtualenv"
|
|
|
|
|
Upgrade.executioner(command, 'VirtualEnv Install', 0)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
|
|
|
|
####
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = "virtualenv --system-site-packages /usr/local/CyberCP"
|
|
|
|
|
Upgrade.executioner(command, 'Setting up VirtualEnv [One]', 1)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
##
|
|
|
|
|
|
|
|
|
|
env_path = '/usr/local/CyberCP'
|
|
|
|
|
subprocess.call(['virtualenv', env_path])
|
|
|
|
|
activate_this = os.path.join(env_path, 'bin', 'activate_this.py')
|
|
|
|
|
execfile(activate_this, dict(__file__=activate_this))
|
|
|
|
|
|
|
|
|
|
##
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = "pip install --ignore-installed -r /usr/local/CyberCP/requirments.txt"
|
|
|
|
|
Upgrade.executioner(command, 'CyberPanel requirements', 1)
|
2018-08-21 13:10:40 +05:00
|
|
|
|
2018-11-14 13:36:34 +05:00
|
|
|
command = "systemctl stop gunicorn.socket"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, '', 0)
|
2018-11-14 13:36:34 +05:00
|
|
|
|
|
|
|
|
command = "virtualenv --system-site-packages /usr/local/CyberCP"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Setting up VirtualEnv [Two]', 1)
|
2018-08-21 13:10:40 +05:00
|
|
|
|
|
|
|
|
Upgrade.stdOut('Virtual enviroment for CyberPanel successfully installed.')
|
2018-07-19 22:38:37 +05:00
|
|
|
except OSError, msg:
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.stdOut(str(msg) + " [setupVirtualEnv]", 0)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def updateGunicornConf():
|
|
|
|
|
try:
|
|
|
|
|
path = '/etc/systemd/system/gunicorn.service'
|
|
|
|
|
|
|
|
|
|
cont = """[Unit]
|
|
|
|
|
Description=gunicorn daemon
|
|
|
|
|
Requires=gunicorn.socket
|
|
|
|
|
After=network.target
|
|
|
|
|
|
|
|
|
|
[Service]
|
|
|
|
|
PIDFile=/run/gunicorn/pid
|
|
|
|
|
User=cyberpanel
|
|
|
|
|
Group=cyberpanel
|
|
|
|
|
RuntimeDirectory=gunicorn
|
|
|
|
|
WorkingDirectory=/usr/local/CyberCP
|
|
|
|
|
ExecStart=/usr/local/CyberCP/bin/gunicorn --pid /run/gunicorn/gucpid \
|
|
|
|
|
--bind 127.0.0.1:5003 CyberCP.wsgi
|
|
|
|
|
ExecReload=/bin/kill -s HUP $MAINPID
|
|
|
|
|
ExecStop=/bin/kill -s TERM $MAINPID
|
|
|
|
|
PrivateTmp=true
|
|
|
|
|
|
|
|
|
|
[Install]
|
|
|
|
|
WantedBy=multi-user.target"""
|
|
|
|
|
|
|
|
|
|
writeToFile = open(path, 'w')
|
|
|
|
|
writeToFile.write(cont)
|
|
|
|
|
writeToFile.close()
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
##
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = 'systemctl daemon-reload'
|
|
|
|
|
Upgrade.executioner(command, 'daemon-reload', 0)
|
|
|
|
|
|
|
|
|
|
##
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = 'systemctl restart gunicorn.socket'
|
|
|
|
|
Upgrade.executioner(command, 'restart gunicorn.socket', 0)
|
2018-07-19 22:38:37 +05:00
|
|
|
except BaseException, msg:
|
|
|
|
|
Upgrade.stdOut(str(msg) + " [updateGunicornConf]")
|
|
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def fileManager():
|
|
|
|
|
## Copy File manager files
|
|
|
|
|
|
2018-11-14 13:36:34 +05:00
|
|
|
command = "rm -rf /usr/local/lsws/Example/html/FileManager"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Remove old Filemanager', 0)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-11-14 13:36:34 +05:00
|
|
|
if os.path.exists('/usr/local/lsws/bin/openlitespeed'):
|
2018-12-14 05:01:10 +05:00
|
|
|
command = "mv /usr/local/CyberCP/install/FileManager /usr/local/lsws/Example/html"
|
|
|
|
|
Upgrade.executioner(command, 'Setup new Filemanager', 0)
|
2018-11-14 13:36:34 +05:00
|
|
|
else:
|
2018-12-14 05:01:10 +05:00
|
|
|
command = "mv /usr/local/CyberCP/install/FileManager /usr/local/lsws"
|
|
|
|
|
Upgrade.executioner(command, 'Setup new Filemanager', 0)
|
2018-11-14 13:36:34 +05:00
|
|
|
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
##
|
|
|
|
|
|
|
|
|
|
command = "chmod -R 777 /usr/local/lsws/Example/html/FileManager"
|
|
|
|
|
Upgrade.executioner(command, 'Filemanager permissions change', 0)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-07-23 02:09:33 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def setupCLI():
|
|
|
|
|
try:
|
2018-08-28 01:19:34 +05:00
|
|
|
|
2018-11-14 13:36:34 +05:00
|
|
|
command = "ln -s /usr/local/CyberCP/cli/cyberPanel.py /usr/bin/cyberpanel"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'CLI Symlink', 0)
|
2018-11-14 13:36:34 +05:00
|
|
|
|
|
|
|
|
command = "chmod +x /usr/local/CyberCP/cli/cyberPanel.py"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'CLI Permissions', 0)
|
2018-08-28 01:19:34 +05:00
|
|
|
|
2018-11-14 13:36:34 +05:00
|
|
|
except OSError, msg:
|
2018-07-23 02:09:33 +05:00
|
|
|
Upgrade.stdOut(str(msg) + " [setupCLI]")
|
|
|
|
|
return 0
|
|
|
|
|
|
2018-07-19 22:38:37 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def staticContent():
|
2018-12-14 05:01:10 +05:00
|
|
|
|
|
|
|
|
command = "rm -rf /usr/local/lscp/cyberpanel/static"
|
|
|
|
|
Upgrade.executioner(command, 'Remove old static content', 0)
|
|
|
|
|
|
|
|
|
|
##
|
|
|
|
|
|
|
|
|
|
command = "mv /usr/local/CyberCP/static /usr/local/lscp/cyberpanel"
|
|
|
|
|
Upgrade.executioner(command, 'Update new static content', 0)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def upgradeVersion():
|
2018-12-14 05:01:10 +05:00
|
|
|
try:
|
|
|
|
|
vers = version.objects.get(pk=1)
|
|
|
|
|
getVersion = requests.get('https://cyberpanel.net/version.txt')
|
|
|
|
|
latest = getVersion.json()
|
|
|
|
|
vers.currentVersion = latest['version']
|
|
|
|
|
vers.build = latest['build']
|
|
|
|
|
vers.save()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def setupConnection(db = None):
|
|
|
|
|
try:
|
|
|
|
|
passFile = "/etc/cyberpanel/mysqlPassword"
|
|
|
|
|
|
|
|
|
|
f = open(passFile)
|
|
|
|
|
data = f.read()
|
|
|
|
|
password = data.split('\n', 1)[0]
|
|
|
|
|
|
|
|
|
|
if db == None:
|
|
|
|
|
conn = mysql.connect(user='root', passwd=password)
|
|
|
|
|
else:
|
2018-12-17 18:46:34 +05:00
|
|
|
try:
|
|
|
|
|
conn = mysql.connect(db=db, user='root', passwd=password)
|
|
|
|
|
except:
|
2018-12-20 16:18:16 +05:00
|
|
|
try:
|
|
|
|
|
conn = mysql.connect(host = '127.0.0.1', port = 3307 , db=db, user='root', passwd=password)
|
|
|
|
|
except:
|
|
|
|
|
dbUser = settings.DATABASES['default']['USER']
|
|
|
|
|
password = settings.DATABASES['default']['PASSWORD']
|
|
|
|
|
host = settings.DATABASES['default']['HOST']
|
|
|
|
|
port = settings.DATABASES['default']['PORT']
|
|
|
|
|
|
|
|
|
|
conn = mysql.connect(host=host, port=port, db=db, user=dbUser, passwd=password)
|
2018-12-14 05:01:10 +05:00
|
|
|
|
|
|
|
|
cursor = conn.cursor()
|
|
|
|
|
return conn, cursor
|
|
|
|
|
|
|
|
|
|
except BaseException, msg:
|
|
|
|
|
Upgrade.stdOut(str(msg))
|
|
|
|
|
return 0, 0
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-19 00:28:31 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def applyLoginSystemMigrations():
|
|
|
|
|
try:
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
connection, cursor = Upgrade.setupConnection('cyberpanel')
|
2018-08-19 00:28:31 +05:00
|
|
|
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute('CREATE TABLE `loginSystem_acl` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `name` varchar(50) NOT NULL UNIQUE, `adminStatus` integer NOT NULL DEFAULT 0, `versionManagement` integer NOT NULL DEFAULT 0, `createNewUser` integer NOT NULL DEFAULT 0, `deleteUser` integer NOT NULL DEFAULT 0, `resellerCenter` integer NOT NULL DEFAULT 0, `changeUserACL` integer NOT NULL DEFAULT 0, `createWebsite` integer NOT NULL DEFAULT 0, `modifyWebsite` integer NOT NULL DEFAULT 0, `suspendWebsite` integer NOT NULL DEFAULT 0, `deleteWebsite` integer NOT NULL DEFAULT 0, `createPackage` integer NOT NULL DEFAULT 0, `deletePackage` integer NOT NULL DEFAULT 0, `modifyPackage` integer NOT NULL DEFAULT 0, `createDatabase` integer NOT NULL DEFAULT 0, `deleteDatabase` integer NOT NULL DEFAULT 0, `listDatabases` integer NOT NULL DEFAULT 0, `createNameServer` integer NOT NULL DEFAULT 0, `createDNSZone` integer NOT NULL DEFAULT 0, `deleteZone` integer NOT NULL DEFAULT 0, `addDeleteRecords` integer NOT NULL DEFAULT 0, `createEmail` integer NOT NULL DEFAULT 0, `deleteEmail` integer NOT NULL DEFAULT 0, `emailForwarding` integer NOT NULL DEFAULT 0, `changeEmailPassword` integer NOT NULL DEFAULT 0, `dkimManager` integer NOT NULL DEFAULT 0, `createFTPAccount` integer NOT NULL DEFAULT 0, `deleteFTPAccount` integer NOT NULL DEFAULT 0, `listFTPAccounts` integer NOT NULL DEFAULT 0, `createBackup` integer NOT NULL DEFAULT 0, `restoreBackup` integer NOT NULL DEFAULT 0, `addDeleteDestinations` integer NOT NULL DEFAULT 0, `scheDuleBackups` integer NOT NULL DEFAULT 0, `remoteBackups` integer NOT NULL DEFAULT 0, `manageSSL` integer NOT NULL DEFAULT 0, `hostnameSSL` integer NOT NULL DEFAULT 0, `mailServerSSL` integer NOT NULL DEFAULT 0)')
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2018-11-26 02:32:30 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute('ALTER TABLE loginSystem_administrator ADD token varchar(500)')
|
2018-11-26 02:32:30 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute('ALTER TABLE loginSystem_administrator ADD acl_id integer')
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute('ALTER TABLE loginSystem_administrator ADD FOREIGN KEY (acl_id) REFERENCES loginSystem_acl(id)')
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute("insert into loginSystem_acl (id, name, adminStatus) values (1,'admin',1)")
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute("insert into loginSystem_acl (id, name, adminStatus, createNewUser, deleteUser, createWebsite, resellerCenter, modifyWebsite, suspendWebsite, deleteWebsite, createPackage, deletePackage, modifyPackage, createNameServer, restoreBackup) values (2,'reseller',0,1,1,1,1,1,1,1,1,1,1,1,1)")
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute("insert into loginSystem_acl (id, name, createDatabase, deleteDatabase, listDatabases, createDNSZone, deleteZone, addDeleteRecords, createEmail, deleteEmail, emailForwarding, changeEmailPassword, dkimManager, createFTPAccount, deleteFTPAccount, listFTPAccounts, createBackup, manageSSL) values (3,'user', 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1)")
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute("UPDATE loginSystem_administrator SET acl_id = 3")
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute("UPDATE loginSystem_administrator SET acl_id = 1 where userName = 'admin'")
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute("alter table loginSystem_administrator drop initUserAccountsLimit")
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute("CREATE TABLE `websiteFunctions_aliasdomains` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `aliasDomain` varchar(75) NOT NULL)")
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute("ALTER TABLE `websiteFunctions_aliasdomains` ADD COLUMN `master_id` integer NOT NULL")
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2018-12-14 05:01:10 +05:00
|
|
|
try:
|
|
|
|
|
cursor.execute("ALTER TABLE `websiteFunctions_aliasdomains` ADD CONSTRAINT `websiteFunctions_ali_master_id_726c433d_fk_websiteFu` FOREIGN KEY (`master_id`) REFERENCES `websiteFunctions_websites` (`id`)")
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
2018-12-20 16:18:16 +05:00
|
|
|
try:
|
|
|
|
|
connection.close()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
2018-12-14 05:01:10 +05:00
|
|
|
|
|
|
|
|
except OSError, msg:
|
|
|
|
|
Upgrade.stdOut(str(msg) + " [applyLoginSystemMigrations]")
|
|
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def s3BackupMigrations():
|
|
|
|
|
try:
|
|
|
|
|
|
|
|
|
|
connection, cursor = Upgrade.setupConnection('cyberpanel')
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `s3Backups_backupplan` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`name` varchar(50) NOT NULL,
|
|
|
|
|
`bucket` varchar(50) NOT NULL,
|
|
|
|
|
`freq` varchar(50) NOT NULL,
|
|
|
|
|
`retention` int(11) NOT NULL,
|
|
|
|
|
`type` varchar(5) NOT NULL,
|
|
|
|
|
`lastRun` varchar(50) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
UNIQUE KEY `name` (`name`),
|
|
|
|
|
KEY `s3Backups_backupplan_owner_id_7d058ced_fk_loginSyst` (`owner_id`),
|
|
|
|
|
CONSTRAINT `s3Backups_backupplan_owner_id_7d058ced_fk_loginSyst` FOREIGN KEY (`owner_id`) REFERENCES `loginSystem_administrator` (`id`)
|
|
|
|
|
)"""
|
2018-08-28 01:19:34 +05:00
|
|
|
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute(query)
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
query = """CREATE TABLE `s3Backups_websitesinplan` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`domain` varchar(100) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `s3Backups_websitesin_owner_id_0e9a4fe3_fk_s3Backups` (`owner_id`),
|
|
|
|
|
CONSTRAINT `s3Backups_websitesin_owner_id_0e9a4fe3_fk_s3Backups` FOREIGN KEY (`owner_id`) REFERENCES `s3Backups_backupplan` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute(query)
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
query = """CREATE TABLE `s3Backups_backuplogs` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`timeStamp` varchar(200) NOT NULL,
|
|
|
|
|
`level` varchar(5) NOT NULL,
|
|
|
|
|
`msg` varchar(500) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `s3Backups_backuplogs_owner_id_7b4653af_fk_s3Backups` (`owner_id`),
|
|
|
|
|
CONSTRAINT `s3Backups_backuplogs_owner_id_7b4653af_fk_s3Backups` FOREIGN KEY (`owner_id`) REFERENCES `s3Backups_backupplan` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
|
2018-12-31 22:55:17 +05:00
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `s3Backups_backupplando` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`name` varchar(50) NOT NULL,
|
|
|
|
|
`bucket` varchar(50) NOT NULL,
|
|
|
|
|
`freq` varchar(50) NOT NULL,
|
|
|
|
|
`retention` int(11) NOT NULL,
|
|
|
|
|
`type` varchar(5) NOT NULL,
|
|
|
|
|
`region` varchar(5) NOT NULL,
|
|
|
|
|
`lastRun` varchar(50) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
UNIQUE KEY `name` (`name`),
|
|
|
|
|
KEY `s3Backups_backupplan_owner_id_1a3ec86d_fk_loginSyst` (`owner_id`),
|
|
|
|
|
CONSTRAINT `s3Backups_backupplan_owner_id_1a3ec86d_fk_loginSyst` FOREIGN KEY (`owner_id`) REFERENCES `loginSystem_administrator` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `s3Backups_websitesinplando` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`domain` varchar(100) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `s3Backups_websitesin_owner_id_cef3ea04_fk_s3Backups` (`owner_id`),
|
|
|
|
|
CONSTRAINT `s3Backups_websitesin_owner_id_cef3ea04_fk_s3Backups` FOREIGN KEY (`owner_id`) REFERENCES `s3Backups_backupplando` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `s3Backups_backuplogsdo` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`timeStamp` varchar(200) NOT NULL,
|
|
|
|
|
`level` varchar(5) NOT NULL,
|
|
|
|
|
`msg` varchar(500) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `s3Backups_backuplogs_owner_id_c7cb5872_fk_s3Backups` (`owner_id`),
|
|
|
|
|
CONSTRAINT `s3Backups_backuplogs_owner_id_c7cb5872_fk_s3Backups` FOREIGN KEY (`owner_id`) REFERENCES `s3Backups_backupplando` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute(query)
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2018-08-26 04:55:51 +05:00
|
|
|
|
2018-12-20 16:18:16 +05:00
|
|
|
try:
|
|
|
|
|
connection.close()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
2018-08-19 00:28:31 +05:00
|
|
|
|
|
|
|
|
except OSError, msg:
|
|
|
|
|
Upgrade.stdOut(str(msg) + " [applyLoginSystemMigrations]")
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-04-23 19:23:03 +05:00
|
|
|
@staticmethod
|
2018-08-21 13:10:40 +05:00
|
|
|
def mailServerMigrations():
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
connection, cursor = Upgrade.setupConnection('cyberpanel')
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute('ALTER TABLE e_forwardings DROP PRIMARY KEY;ALTER TABLE e_forwardings ADD id INT AUTO_INCREMENT PRIMARY KEY')
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailPremium_domainlimits` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`limitStatus` int(11) NOT NULL,
|
|
|
|
|
`monthlyLimit` int(11) NOT NULL,
|
|
|
|
|
`monthlyUsed` int(11) NOT NULL,
|
|
|
|
|
`domain_id` varchar(50) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `emailPremium_domainlimits_domain_id_303ab297_fk_e_domains_domain` (`domain_id`),
|
|
|
|
|
CONSTRAINT `emailPremium_domainlimits_domain_id_303ab297_fk_e_domains_domain` FOREIGN KEY (`domain_id`) REFERENCES `e_domains` (`domain`)
|
|
|
|
|
)"""
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute(query)
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2018-12-14 05:01:10 +05:00
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailPremium_emaillimits` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`limitStatus` int(11) NOT NULL,
|
|
|
|
|
`monthlyLimits` int(11) NOT NULL,
|
|
|
|
|
`monthlyUsed` int(11) NOT NULL,
|
|
|
|
|
`hourlyLimit` int(11) NOT NULL,
|
|
|
|
|
`hourlyUsed` int(11) NOT NULL,
|
|
|
|
|
`emailLogs` int(11) NOT NULL,
|
|
|
|
|
`email_id` varchar(80) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `emailPremium_emaillimits_email_id_1c111df5_fk_e_users_email` (`email_id`),
|
|
|
|
|
CONSTRAINT `emailPremium_emaillimits_email_id_1c111df5_fk_e_users_email` FOREIGN KEY (`email_id`) REFERENCES `e_users` (`email`)
|
|
|
|
|
)"""
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute(query)
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2018-12-14 05:01:10 +05:00
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailPremium_emaillogs` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`destination` varchar(200) NOT NULL,
|
|
|
|
|
`timeStamp` varchar(200) NOT NULL,
|
|
|
|
|
`email_id` varchar(80) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `emailPremium_emaillogs_email_id_9ef49552_fk_e_users_email` (`email_id`),
|
|
|
|
|
CONSTRAINT `emailPremium_emaillogs_email_id_9ef49552_fk_e_users_email` FOREIGN KEY (`email_id`) REFERENCES `e_users` (`email`)
|
|
|
|
|
)"""
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
cursor.execute(query)
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2018-12-14 05:01:10 +05:00
|
|
|
|
2018-12-20 16:18:16 +05:00
|
|
|
try:
|
|
|
|
|
connection.close()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
2018-08-21 13:10:40 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2018-07-26 04:11:10 +05:00
|
|
|
|
2018-10-22 10:55:52 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def emailMarketingMigrationsa():
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
connection, cursor = Upgrade.setupConnection('cyberpanel')
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailMarketing_emailmarketing` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`userName` varchar(50) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
UNIQUE KEY `userName` (`userName`)
|
|
|
|
|
)"""
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailMarketing_emaillists` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`listName` varchar(50) NOT NULL,
|
|
|
|
|
`dateCreated` varchar(200) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
UNIQUE KEY `listName` (`listName`),
|
|
|
|
|
KEY `emailMarketing_email_owner_id_bf1b4530_fk_websiteFu` (`owner_id`),
|
|
|
|
|
CONSTRAINT `emailMarketing_email_owner_id_bf1b4530_fk_websiteFu` FOREIGN KEY (`owner_id`) REFERENCES `websiteFunctions_websites` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailMarketing_emailsinlist` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`email` varchar(50) NOT NULL,
|
|
|
|
|
`firstName` varchar(20) NOT NULL,
|
|
|
|
|
`lastName` varchar(20) NOT NULL,
|
|
|
|
|
`verificationStatus` varchar(100) NOT NULL,
|
|
|
|
|
`dateCreated` varchar(200) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `emailMarketing_email_owner_id_c5c27005_fk_emailMark` (`owner_id`),
|
|
|
|
|
CONSTRAINT `emailMarketing_email_owner_id_c5c27005_fk_emailMark` FOREIGN KEY (`owner_id`) REFERENCES `emailMarketing_emaillists` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailMarketing_smtphosts` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`host` varchar(150) NOT NULL,
|
|
|
|
|
`port` varchar(10) NOT NULL,
|
|
|
|
|
`userName` varchar(50) NOT NULL,
|
|
|
|
|
`password` varchar(50) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
UNIQUE KEY `host` (`host`),
|
|
|
|
|
KEY `emailMarketing_smtph_owner_id_8b2d4ac7_fk_loginSyst` (`owner_id`),
|
|
|
|
|
CONSTRAINT `emailMarketing_smtph_owner_id_8b2d4ac7_fk_loginSyst` FOREIGN KEY (`owner_id`) REFERENCES `loginSystem_administrator` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailMarketing_emailtemplate` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`name` varchar(100) NOT NULL,
|
|
|
|
|
`subject` varchar(1000) NOT NULL,
|
|
|
|
|
`fromName` varchar(100) NOT NULL,
|
|
|
|
|
`fromEmail` varchar(150) NOT NULL,
|
|
|
|
|
`replyTo` varchar(150) NOT NULL,
|
|
|
|
|
`emailMessage` varchar(30000) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
UNIQUE KEY `name` (`name`),
|
|
|
|
|
KEY `emailMarketing_email_owner_id_d27e1d00_fk_loginSyst` (`owner_id`),
|
|
|
|
|
CONSTRAINT `emailMarketing_email_owner_id_d27e1d00_fk_loginSyst` FOREIGN KEY (`owner_id`) REFERENCES `loginSystem_administrator` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `emailMarketing_emailjobs` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`date` varchar(200) NOT NULL,
|
|
|
|
|
`host` varchar(1000) NOT NULL,
|
|
|
|
|
`totalEmails` int(11) NOT NULL,
|
|
|
|
|
`sent` int(11) NOT NULL,
|
|
|
|
|
`failed` int(11) NOT NULL,
|
|
|
|
|
`owner_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
KEY `emailMarketing_email_owner_id_73ee4827_fk_emailMark` (`owner_id`),
|
|
|
|
|
CONSTRAINT `emailMarketing_email_owner_id_73ee4827_fk_emailMark` FOREIGN KEY (`owner_id`) REFERENCES `emailMarketing_emailtemplate` (`id`)
|
|
|
|
|
)"""
|
2018-11-14 13:36:34 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
2018-11-14 13:36:34 +05:00
|
|
|
|
2018-12-20 16:18:16 +05:00
|
|
|
try:
|
|
|
|
|
connection.close()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
2018-10-22 10:55:52 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
2019-01-09 14:55:10 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def dockerMigrations():
|
|
|
|
|
try:
|
|
|
|
|
connection, cursor = Upgrade.setupConnection('cyberpanel')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
query = """CREATE TABLE `dockerManager_containers` (
|
|
|
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
|
|
|
`name` varchar(50) NOT NULL,
|
|
|
|
|
`cid` varchar(64) NOT NULL,
|
|
|
|
|
`image` varchar(50) NOT NULL,
|
|
|
|
|
`tag` varchar(50) NOT NULL,
|
|
|
|
|
`memory` int(11) NOT NULL,
|
|
|
|
|
`ports` longtext NOT NULL,
|
|
|
|
|
`env` longtext NOT NULL,
|
|
|
|
|
`startOnReboot` int(11) NOT NULL,
|
|
|
|
|
`admin_id` int(11) NOT NULL,
|
|
|
|
|
PRIMARY KEY (`id`),
|
|
|
|
|
UNIQUE KEY `name` (`name`),
|
|
|
|
|
KEY `dockerManager_contai_admin_id_58fb62b7_fk_loginSyst` (`admin_id`),
|
|
|
|
|
CONSTRAINT `dockerManager_contai_admin_id_58fb62b7_fk_loginSyst` FOREIGN KEY (`admin_id`) REFERENCES `loginSystem_administrator` (`id`)
|
|
|
|
|
)"""
|
|
|
|
|
try:
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
connection.close()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def enableServices():
|
|
|
|
|
try:
|
|
|
|
|
servicePath = '/home/cyberpanel/powerdns'
|
|
|
|
|
writeToFile = open(servicePath, 'w+')
|
|
|
|
|
writeToFile.close()
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
servicePath = '/home/cyberpanel/postfix'
|
|
|
|
|
writeToFile = open(servicePath, 'w+')
|
|
|
|
|
writeToFile.close()
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
servicePath = '/home/cyberpanel/pureftpd'
|
|
|
|
|
writeToFile = open(servicePath, 'w+')
|
|
|
|
|
writeToFile.close()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
2018-07-26 04:11:10 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
@staticmethod
|
2018-12-14 05:01:10 +05:00
|
|
|
def downloadAndUpgrade(versionNumbring):
|
2018-08-21 13:10:40 +05:00
|
|
|
try:
|
|
|
|
|
## Download latest version.
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = "wget https://cyberpanel.net/CyberPanel." + versionNumbring
|
|
|
|
|
# command = "wget https://cyberpanel.net/CyberPanel.1.7.4.tar.gz"
|
|
|
|
|
Upgrade.executioner(command, 'Download latest version', 1)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
## Backup settings file.
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
Upgrade.stdOut("Backing up settings file.")
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
shutil.copy("/usr/local/CyberCP/CyberCP/settings.py", "/usr/local/settings.py")
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
Upgrade.stdOut("Settings file backed up.")
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-10-12 18:18:10 +05:00
|
|
|
if os.path.exists('/usr/local/CyberCP/bin'):
|
|
|
|
|
shutil.rmtree('/usr/local/CyberCP/bin')
|
|
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
## Extract Latest files
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
# command = "tar zxf CyberPanel.1.7.4.tar.gz"
|
|
|
|
|
command = "tar zxf CyberPanel." + versionNumbring
|
|
|
|
|
Upgrade.executioner(command, 'Extract latest version', 1)
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
## Copy settings file
|
2018-11-14 13:36:34 +05:00
|
|
|
|
2018-10-12 18:18:10 +05:00
|
|
|
data = open("/usr/local/settings.py", 'r').readlines()
|
|
|
|
|
|
|
|
|
|
pluginCheck = 1
|
|
|
|
|
for items in data:
|
|
|
|
|
if items.find('pluginHolder') > -1:
|
|
|
|
|
pluginCheck = 0
|
|
|
|
|
|
2018-10-22 10:55:52 +05:00
|
|
|
emailMarketing = 1
|
|
|
|
|
for items in data:
|
|
|
|
|
if items.find('emailMarketing') > -1:
|
|
|
|
|
emailMarketing = 0
|
|
|
|
|
|
2018-11-14 13:36:34 +05:00
|
|
|
emailPremium = 1
|
|
|
|
|
for items in data:
|
|
|
|
|
if items.find('emailPremium') > -1:
|
|
|
|
|
emailPremium = 0
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
s3Backups = 1
|
|
|
|
|
for items in data:
|
|
|
|
|
if items.find('s3Backups') > -1:
|
|
|
|
|
s3Backups = 0
|
|
|
|
|
|
2019-01-13 23:58:09 +05:00
|
|
|
dockerManager = 1
|
|
|
|
|
for items in data:
|
|
|
|
|
if items.find('dockerManager') > -1:
|
|
|
|
|
dockerManager = 0
|
|
|
|
|
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
Upgrade.stdOut('Restoring settings file!')
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-10-12 18:18:10 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
writeToFile = open("/usr/local/CyberCP/CyberCP/settings.py", 'w')
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
for items in data:
|
|
|
|
|
if items.find("'filemanager',") > -1:
|
|
|
|
|
writeToFile.writelines(items)
|
2018-10-12 18:18:10 +05:00
|
|
|
if pluginCheck == 1:
|
|
|
|
|
writeToFile.writelines(" 'pluginHolder',\n")
|
2018-10-22 10:55:52 +05:00
|
|
|
if emailMarketing == 1:
|
|
|
|
|
writeToFile.writelines(" 'emailMarketing',\n")
|
2018-11-14 13:36:34 +05:00
|
|
|
if emailPremium == 1:
|
2018-09-03 16:46:51 +05:00
|
|
|
writeToFile.writelines(" 'emailPremium',\n")
|
2018-12-14 05:01:10 +05:00
|
|
|
if s3Backups == 1:
|
|
|
|
|
writeToFile.writelines(" 's3Backups',\n")
|
2019-01-13 23:58:09 +05:00
|
|
|
if dockerManager == 1:
|
|
|
|
|
writeToFile.writelines(" 'dockerManager',\n")
|
2018-08-21 13:10:40 +05:00
|
|
|
else:
|
|
|
|
|
writeToFile.writelines(items)
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
writeToFile.close()
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
Upgrade.stdOut('Settings file restored!')
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
## Move static files
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
Upgrade.staticContent()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-10-22 10:55:52 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def installPYDNS():
|
|
|
|
|
try:
|
|
|
|
|
command = "pip install pydns"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Install PyDNS', 1)
|
2018-10-22 10:55:52 +05:00
|
|
|
except OSError, msg:
|
|
|
|
|
Upgrade.stdOut(str(msg) + " [installPYDNS]")
|
|
|
|
|
return 0
|
|
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def installTLDExtract():
|
|
|
|
|
try:
|
2018-12-14 05:01:10 +05:00
|
|
|
command = "pip install tldextract"
|
|
|
|
|
Upgrade.executioner(command, 'Install tldextract', 1)
|
2018-08-21 13:10:40 +05:00
|
|
|
except OSError, msg:
|
|
|
|
|
Upgrade.stdOut(str(msg) + " [installTLDExtract]")
|
|
|
|
|
return 0
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-10-12 18:18:10 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def installLSCPD():
|
|
|
|
|
try:
|
|
|
|
|
|
|
|
|
|
Upgrade.stdOut("Starting LSCPD installation..")
|
|
|
|
|
|
2018-12-17 18:46:34 +05:00
|
|
|
cwd = os.getcwd()
|
|
|
|
|
|
|
|
|
|
os.chdir('/usr/local')
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = 'yum -y install gcc gcc-c++ make autoconf glibc rcs'
|
|
|
|
|
Upgrade.executioner(command, 'LSCPD Pre-reqs [one]', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
##
|
2018-10-12 18:18:10 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = 'yum -y install pcre-devel openssl-devel expat-devel geoip-devel zlib-devel udns-devel which curl'
|
|
|
|
|
Upgrade.executioner(command, 'LSCPD Pre-reqs [two]', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
2018-12-24 20:21:14 +05:00
|
|
|
##
|
2018-10-12 18:18:10 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
if os.path.exists('/usr/local/lscp.tar.gz'):
|
|
|
|
|
os.remove('/usr/local/lscp.tar.gz')
|
2018-10-12 18:18:10 +05:00
|
|
|
|
2018-12-24 20:21:14 +05:00
|
|
|
command = 'wget https://cyberpanel.net/lscp.tar.gz'
|
|
|
|
|
Upgrade.executioner(command, 'Download LSCPD [two]', 0)
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
##
|
2018-10-12 18:18:10 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
command = 'tar zxf lscp.tar.gz -C /usr/local/'
|
|
|
|
|
Upgrade.executioner(command, 'Extract LSCPD [two]', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
os.remove("/usr/local/lscp/fcgi-bin/lsphp")
|
|
|
|
|
shutil.copy("/usr/local/lsws/lsphp70/bin/lsphp","/usr/local/lscp/fcgi-bin/lsphp")
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
command = 'adduser lscpd -M -d /usr/local/lscp'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Add user LSCPD', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
|
|
|
|
command = 'groupadd lscpd'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Add group LSCPD', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
|
|
|
|
command = 'usermod -a -G lscpd lscpd'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Add group LSCPD', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
|
|
|
|
command = 'usermod -a -G lsadm lscpd'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Add group LSCPD', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
|
|
|
|
command = 'chown -R lscpd:lscpd /usr/local/lscp/cyberpanel'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'chown cyberpanel', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
|
|
|
|
command = 'systemctl daemon-reload'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'daemon-reload LSCPD', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
|
|
|
|
command = 'systemctl restart lscpd'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Restart LSCPD', 0)
|
2018-10-12 18:18:10 +05:00
|
|
|
|
2018-12-17 18:46:34 +05:00
|
|
|
os.chdir(cwd)
|
|
|
|
|
|
2018-10-12 18:18:10 +05:00
|
|
|
Upgrade.stdOut("LSCPD successfully installed!")
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
except BaseException, msg:
|
2018-10-12 18:18:10 +05:00
|
|
|
Upgrade.stdOut(str(msg) + " [installLSCPD]")
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-11-26 02:32:30 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def fixPermissions():
|
|
|
|
|
try:
|
|
|
|
|
|
|
|
|
|
Upgrade.stdOut("Fixing permissions..")
|
|
|
|
|
|
|
|
|
|
command = 'chown -R cyberpanel:cyberpanel /usr/local/CyberCP'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'chown core code', 0)
|
2018-11-26 02:32:30 +05:00
|
|
|
|
|
|
|
|
command = 'chown -R cyberpanel:cyberpanel /usr/local/lscp'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'chown lscp', 0)
|
2018-11-26 02:32:30 +05:00
|
|
|
|
|
|
|
|
command = 'chown -R lscpd:lscpd /usr/local/lscp/cyberpanel'
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'chown static content', 0)
|
2018-11-26 02:32:30 +05:00
|
|
|
|
|
|
|
|
Upgrade.stdOut("Permissions updated.")
|
|
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
except BaseException, msg:
|
|
|
|
|
Upgrade.stdOut(str(msg) + " [installLSCPD]")
|
2018-11-26 02:32:30 +05:00
|
|
|
|
2018-12-20 16:18:16 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def installPHP73():
|
|
|
|
|
try:
|
|
|
|
|
command = 'yum install -y lsphp73 lsphp73-json lsphp73-xmlrpc lsphp73-xml lsphp73-tidy lsphp73-soap lsphp73-snmp ' \
|
|
|
|
|
'lsphp73-recode lsphp73-pspell lsphp73-process lsphp73-pgsql lsphp73-pear lsphp73-pdo lsphp73-opcache ' \
|
|
|
|
|
'lsphp73-odbc lsphp73-mysqlnd lsphp73-mcrypt lsphp73-mbstring lsphp73-ldap lsphp73-intl lsphp73-imap ' \
|
|
|
|
|
'lsphp73-gmp lsphp73-gd lsphp73-enchant lsphp73-dba lsphp73-common lsphp73-bcmath'
|
|
|
|
|
Upgrade.executioner(command, 'Install PHP 73, 0')
|
|
|
|
|
except:
|
|
|
|
|
command = 'DEBIAN_FRONTEND=noninteractive apt-get -y install ' \
|
|
|
|
|
'lsphp7? lsphp7?-common lsphp7?-curl lsphp7?-dev lsphp7?-imap lsphp7?-intl lsphp7?-json ' \
|
|
|
|
|
'lsphp7?-ldap lsphp7?-mysql lsphp7?-opcache lsphp7?-pspell lsphp7?-recode ' \
|
|
|
|
|
'lsphp7?-sqlite3 lsphp7?-tidy'
|
|
|
|
|
Upgrade.executioner(command, 'Install PHP 73, 0')
|
|
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def upgrade():
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
os.chdir("/usr/local")
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
## Current Version
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
Version = version.objects.get(pk=1)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-11-14 13:36:34 +05:00
|
|
|
command = "systemctl stop gunicorn.socket"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'stop gunicorn', 0)
|
2018-11-14 13:36:34 +05:00
|
|
|
|
|
|
|
|
command = "systemctl stop lscpd"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'stop lscpd', 0)
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
##
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
versionNumbring = Upgrade.downloadLink()
|
2018-05-06 14:18:41 +05:00
|
|
|
|
|
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
if os.path.exists('/usr/local/CyberPanel.' + versionNumbring):
|
|
|
|
|
os.remove('/usr/local/CyberPanel.' + versionNumbring)
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
if float(Version.currentVersion) < 1.6:
|
|
|
|
|
Upgrade.stdOut('Upgrades works for version 1.6 onwards.')
|
|
|
|
|
os._exit(0)
|
2018-06-25 03:37:23 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
##
|
2018-12-14 05:01:10 +05:00
|
|
|
|
2018-10-22 10:55:52 +05:00
|
|
|
Upgrade.installPYDNS()
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.downloadAndUpgrade(versionNumbring)
|
|
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
##
|
2018-12-14 05:01:10 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
Upgrade.installTLDExtract()
|
2018-12-14 05:01:10 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
##
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
Upgrade.mailServerMigrations()
|
2018-10-22 10:55:52 +05:00
|
|
|
Upgrade.emailMarketingMigrationsa()
|
2019-01-09 14:55:10 +05:00
|
|
|
Upgrade.dockerMigrations()
|
2018-07-19 22:38:37 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
##
|
2018-07-19 22:38:37 +05:00
|
|
|
|
|
|
|
|
Upgrade.setupVirtualEnv()
|
2018-08-21 13:10:40 +05:00
|
|
|
Upgrade.updateGunicornConf()
|
2018-06-25 03:37:23 +05:00
|
|
|
|
2018-08-21 13:10:40 +05:00
|
|
|
##
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-28 01:19:34 +05:00
|
|
|
Upgrade.applyLoginSystemMigrations()
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.s3BackupMigrations()
|
2018-08-28 01:19:34 +05:00
|
|
|
Upgrade.enableServices()
|
2018-08-19 00:28:31 +05:00
|
|
|
|
2018-12-20 16:18:16 +05:00
|
|
|
Upgrade.installPHP73()
|
2018-07-23 02:09:33 +05:00
|
|
|
Upgrade.setupCLI()
|
2018-10-12 18:18:10 +05:00
|
|
|
Upgrade.installLSCPD()
|
2018-11-26 02:32:30 +05:00
|
|
|
Upgrade.fixPermissions()
|
2018-05-14 22:26:25 +05:00
|
|
|
time.sleep(3)
|
|
|
|
|
|
2018-04-23 19:23:03 +05:00
|
|
|
## Upgrade version
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-07-19 22:38:37 +05:00
|
|
|
Upgrade.upgradeVersion()
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-08-28 01:19:34 +05:00
|
|
|
try:
|
|
|
|
|
command = "systemctl start lscpd"
|
2018-12-14 05:01:10 +05:00
|
|
|
Upgrade.executioner(command, 'Start LSCPD', 0)
|
2018-08-28 01:19:34 +05:00
|
|
|
except:
|
|
|
|
|
pass
|
2017-10-30 14:34:07 +05:00
|
|
|
|
2018-07-19 22:38:37 +05:00
|
|
|
Upgrade.stdOut("Upgrade Completed.")
|
2017-10-24 19:16:36 +05:00
|
|
|
|
2018-12-14 05:01:10 +05:00
|
|
|
def main():
|
|
|
|
|
Upgrade.upgrade()
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
|
main()
|