2023-02-12 22:31:41 +05:00
|
|
|
import argparse
|
2023-02-11 21:27:06 +05:00
|
|
|
import json
|
2023-02-11 11:27:09 +05:00
|
|
|
import os
|
|
|
|
|
import sys
|
2023-02-12 13:15:41 +05:00
|
|
|
import time
|
2023-02-11 11:27:09 +05:00
|
|
|
|
|
|
|
|
sys.path.append('/usr/local/CyberCP')
|
|
|
|
|
import django
|
|
|
|
|
|
|
|
|
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "CyberCP.settings")
|
|
|
|
|
try:
|
|
|
|
|
django.setup()
|
|
|
|
|
except:
|
|
|
|
|
pass
|
|
|
|
|
|
2023-02-12 22:31:41 +05:00
|
|
|
from plogical.processUtilities import ProcessUtilities
|
|
|
|
|
|
2023-02-11 11:27:09 +05:00
|
|
|
|
|
|
|
|
class CPBackupsV2:
|
2023-02-12 13:15:41 +05:00
|
|
|
PENDING_START = 0
|
|
|
|
|
RUNNING = 1
|
|
|
|
|
COMPLETED = 2
|
|
|
|
|
FAILED = 3
|
|
|
|
|
|
2023-02-11 11:27:09 +05:00
|
|
|
def __init__(self, data):
|
|
|
|
|
self.data = data
|
|
|
|
|
pass
|
|
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
@staticmethod
|
|
|
|
|
def FetchCurrentTimeStamp():
|
|
|
|
|
import time
|
|
|
|
|
return str(time.time())
|
|
|
|
|
|
|
|
|
|
def UpdateStatus(self, message, status):
|
2023-02-12 22:31:41 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
from websiteFunctions.models import Backupsv2, BackupsLogsv2
|
|
|
|
|
self.buv2 = Backupsv2.objects.get(fileName=self.buv2.fileName)
|
|
|
|
|
self.buv2.status = status
|
|
|
|
|
self.buv2.save()
|
|
|
|
|
|
2023-02-12 22:31:41 +05:00
|
|
|
BackupsLogsv2(message=message, owner=self.buv2).save()
|
2023-02-12 13:15:41 +05:00
|
|
|
|
|
|
|
|
if status == CPBackupsV2.FAILED:
|
|
|
|
|
self.buv2.website.BackupLock = 0
|
|
|
|
|
self.buv2.website.save()
|
|
|
|
|
elif status == CPBackupsV2.COMPLETED:
|
|
|
|
|
self.buv2.website.BackupLock = 0
|
|
|
|
|
self.buv2.website.save()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-02-11 11:27:09 +05:00
|
|
|
def InitiateBackup(self):
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
from websiteFunctions.models import Websites, Backupsv2
|
2023-02-11 11:27:09 +05:00
|
|
|
from django.forms.models import model_to_dict
|
|
|
|
|
from plogical.mysqlUtilities import mysqlUtilities
|
|
|
|
|
website = Websites.objects.get(domain=self.data['domain'])
|
|
|
|
|
|
2023-02-12 22:31:41 +05:00
|
|
|
if not os.path.exists(self.data['BasePath']):
|
|
|
|
|
command = f"mkdir -p {self.data['BasePath']}"
|
|
|
|
|
ProcessUtilities.executioner(command)
|
|
|
|
|
|
|
|
|
|
command = f"chmod 711 {self.data['BasePath']}"
|
|
|
|
|
ProcessUtilities.executioner(command)
|
|
|
|
|
|
|
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
while(1):
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
if website.BackupLock == 0:
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
website.BackupLock = 1
|
|
|
|
|
website.save()
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
self.buv2 = Backupsv2(website=website, fileName='backup-' + self.data['domain'] + "-" + time.strftime("%m.%d.%Y_%H-%M-%S"), status=CPBackupsV2.RUNNING, BasePath=self.data['BasePath'])
|
|
|
|
|
self.buv2.save()
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 22:31:41 +05:00
|
|
|
FinalPath = f"{self.data['BasePath']}/{self.buv2.fileName}"
|
|
|
|
|
|
|
|
|
|
command = f"mkdir -p {FinalPath}"
|
|
|
|
|
ProcessUtilities.executioner(command)
|
|
|
|
|
|
|
|
|
|
command = f"chown {website.externalApp}:{website.externalApp} {FinalPath}"
|
|
|
|
|
ProcessUtilities.executioner(command)
|
|
|
|
|
|
|
|
|
|
command = f"chmod 711 {FinalPath}"
|
|
|
|
|
ProcessUtilities.executioner(command, website.externalApp)
|
|
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
try:
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 22:31:41 +05:00
|
|
|
self.UpdateStatus('Creating backup config,0', CPBackupsV2.RUNNING)
|
|
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
Config = {'MainWebsite': model_to_dict(website, fields=['domain', 'adminEmail', 'phpSelection', 'state', 'config'])}
|
|
|
|
|
Config['admin'] = model_to_dict(website.admin, fields=['userName', 'password', 'firstName', 'lastName',
|
|
|
|
|
'email', 'type', 'owner', 'token', 'api', 'securityLevel',
|
|
|
|
|
'state', 'initWebsitesLimit', 'twoFA', 'secretKey', 'config'])
|
|
|
|
|
Config['acl'] = model_to_dict(website.admin.acl)
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
### Child domains to config
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
ChildsList = []
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
for childDomains in website.childdomains_set.all():
|
|
|
|
|
print(childDomains.domain)
|
|
|
|
|
ChildsList.append(model_to_dict(childDomains))
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
Config['ChildDomains'] = ChildsList
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
#print(str(Config))
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
### Databases
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
connection, cursor = mysqlUtilities.setupConnection()
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
if connection == 0:
|
|
|
|
|
return 0
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
dataBases = website.databases_set.all()
|
|
|
|
|
DBSList = []
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
for db in dataBases:
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
query = f"SELECT host,user FROM mysql.db WHERE db='{db.dbName}';"
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
DBUsers = cursor.fetchall()
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
UserList = []
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
for databaseUser in DBUsers:
|
|
|
|
|
query = f"SELECT password FROM `mysql`.`user` WHERE `Host`='{databaseUser[0]}' AND `User`='{databaseUser[1]}';"
|
|
|
|
|
cursor.execute(query)
|
|
|
|
|
resp = cursor.fetchall()
|
|
|
|
|
print(resp)
|
|
|
|
|
UserList.append({'user': databaseUser[1], 'host': databaseUser[0], 'password': resp[0][0]})
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
DBSList.append({db.dbName: UserList})
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
Config['databases'] = DBSList
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-12 13:15:41 +05:00
|
|
|
WPSitesList = []
|
|
|
|
|
|
|
|
|
|
for wpsite in website.wpsites_set.all():
|
|
|
|
|
WPSitesList.append(model_to_dict(wpsite,fields=['title', 'path', 'FinalURL', 'AutoUpdates', 'PluginUpdates', 'ThemeUpdates', 'WPLockState']))
|
|
|
|
|
|
|
|
|
|
Config['WPSites'] = WPSitesList
|
2023-02-12 22:31:41 +05:00
|
|
|
|
|
|
|
|
command = f"echo '{json.dumps(Config)}' > {FinalPath}/config.json"
|
|
|
|
|
ProcessUtilities.executioner(command, website.externalApp, True)
|
|
|
|
|
|
|
|
|
|
self.UpdateStatus('Backup config created,5', CPBackupsV2.RUNNING)
|
2023-02-12 13:15:41 +05:00
|
|
|
except BaseException as msg:
|
|
|
|
|
self.UpdateStatus(str(msg), CPBackupsV2.FAILED)
|
|
|
|
|
return 0
|
|
|
|
|
|
2023-02-12 22:31:41 +05:00
|
|
|
if self.data['BackupDatabase']:
|
|
|
|
|
command = f'/usr/local/CyberCP/bin/python /usr/local/CyberCP/plogical/Backupsv2.py BackupDataBases --path {FinalPath}'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
self.UpdateStatus('Completed', CPBackupsV2.COMPLETED)
|
|
|
|
|
|
|
|
|
|
print(FinalPath)
|
2023-02-12 13:15:41 +05:00
|
|
|
|
|
|
|
|
break
|
|
|
|
|
else:
|
|
|
|
|
time.sleep(5)
|
2023-02-11 21:27:06 +05:00
|
|
|
|
2023-02-11 22:52:38 +05:00
|
|
|
def BackupDataBases(self):
|
2023-02-11 21:27:06 +05:00
|
|
|
|
|
|
|
|
### This function will backup databases of the website, also need to take care of database that we need to exclude
|
|
|
|
|
### excluded databases are in a list self.data['ExcludedDatabases'] only backup databases if backupdatabase check is on
|
|
|
|
|
## For example if self.data['BackupDatabase'] is one then only run this function otherwise not
|
|
|
|
|
|
|
|
|
|
pass
|
2023-02-11 11:27:09 +05:00
|
|
|
|
2023-02-11 22:52:38 +05:00
|
|
|
def BackupData(self):
|
2023-02-12 10:04:58 +05:00
|
|
|
|
2023-02-11 21:27:06 +05:00
|
|
|
### This function will backup data of the website, also need to take care of directories that we need to exclude
|
|
|
|
|
### excluded directories are in a list self.data['ExcludedDirectories'] only backup data if backupdata check is on
|
|
|
|
|
## For example if self.data['BackupData'] is one then only run this function otherwise not
|
2023-02-11 11:27:09 +05:00
|
|
|
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2023-02-12 22:31:41 +05:00
|
|
|
try:
|
|
|
|
|
parser = argparse.ArgumentParser(description='CyberPanel Backup Generator')
|
|
|
|
|
parser.add_argument('function', help='Specify a function to call!')
|
|
|
|
|
parser.add_argument('--path', help='')
|
|
|
|
|
|
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
|
|
if args.function == "BackupDataBases":
|
|
|
|
|
cpbuv2 = CPBackupsV2({'finalPath': args.path})
|
|
|
|
|
cpbuv2.BackupDataBases()
|
|
|
|
|
|
|
|
|
|
except:
|
|
|
|
|
cpbuv2 = CPBackupsV2({'domain': 'cyberpanel.net', 'BasePath': '/home/backup', 'BackupDatabase': 1, 'BackupData': 1} )
|
|
|
|
|
cpbuv2.InitiateBackup()
|