Files
CyberPanel/plogical/cPanelImporter.py

913 lines
36 KiB
Python
Raw Normal View History

2019-07-03 13:15:26 +05:00
#!/usr/local/CyberCP/bin/python2
import os.path
import sys
import django
sys.path.append('/usr/local/CyberCP')
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "CyberCP.settings")
django.setup()
import argparse
from plogical.processUtilities import ProcessUtilities
from random import randint
from plogical.CyberCPLogFileWriter import CyberCPLogFileWriter as logging
import re
import shutil
from dns.models import Domains, Records
from manageServices.models import PDNSStatus
from loginSystem.models import Administrator
from plogical.dnsUtilities import DNS
import MySQLdb as mysql
import MySQLdb.cursors as cursors
import shlex
import subprocess
from databases.models import Databases
from websiteFunctions.models import Websites, ChildDomains as CDomains
2019-07-03 13:15:26 +05:00
from plogical.vhost import vhost
from plogical.virtualHostUtilities import virtualHostUtilities
from plogical.mailUtilities import mailUtilities
from mailServer.models import EUsers
class ChildDomains:
def __init__(self, domain, addon):
self.domain = domain
self.addon = addon
class cPanelImporter:
MailDir = 1
MdBox = 0
mainBackupPath = '/home/backup/'
def __init__(self, backupFile, logFile):
self.backupFile = backupFile
self.fileName = backupFile.split('/')[-1].replace('.tar.gz', '')
2019-07-03 13:15:26 +05:00
self.logFile = logFile
self.PHPVersion = ''
self.email = ''
self.mainDomain = ''
self.homeDir = ''
self.documentRoot = ''
self.mailFormat = 1
def PHPDecider(self):
2019-08-03 14:53:31 +05:00
if self.PHPVersion == 'inherit':
self.PHPVersion = 'PHP 7.2'
2019-07-03 13:15:26 +05:00
if self.PHPVersion.find('53') > -1:
self.PHPVersion = 'PHP 5.3'
elif self.PHPVersion.find('54') > -1:
self.PHPVersion = 'PHP 5.4'
elif self.PHPVersion.find('55') > -1:
self.PHPVersion = 'PHP 5.5'
elif self.PHPVersion.find('56') > -1:
self.PHPVersion = 'PHP 5.6'
elif self.PHPVersion.find('70') > -1:
self.PHPVersion = 'PHP 7.0'
elif self.PHPVersion.find('71') > -1:
self.PHPVersion = 'PHP 7.1'
elif self.PHPVersion.find('72') > -1:
self.PHPVersion = 'PHP 7.2'
elif self.PHPVersion.find('73') > -1:
self.PHPVersion = 'PHP 7.3'
if self.PHPVersion == '':
self.PHPVersion = 'PHP 7.1'
2019-07-03 13:15:26 +05:00
def SetupSSL(self, path, domain):
data = open(path, 'r').readlines()
Key = []
Cert = []
KeyCheck = 1
CertCheck = 0
for items in data:
if KeyCheck == 1 and items.find('-----END RSA PRIVATE KEY-----') > -1:
KeyCheck = 0
CertCheck = 1
Key.append(items)
continue
else:
Key.append(items)
if CertCheck == 1:
Cert.append(items)
KeyPath = '/home/cyberpanel/%s' % (str(randint(1000, 9999)))
writeToFile = open(KeyPath, 'w')
for items in Key:
writeToFile.writelines(items)
writeToFile.close()
##
CertPath = '/home/cyberpanel/%s' % (str(randint(1000, 9999)))
writeToFile = open(CertPath, 'w')
for items in Cert:
writeToFile.writelines(items)
writeToFile.close()
virtualHostUtilities.saveSSL(domain, KeyPath, CertPath)
def ExtractBackup(self):
try:
message = 'Extracting main cPanel archive file: %s' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
if not os.path.exists(cPanelImporter.mainBackupPath):
os.mkdir(cPanelImporter.mainBackupPath)
os.chdir(cPanelImporter.mainBackupPath)
command = 'tar -xf %s --directory %s' % (self.backupFile, cPanelImporter.mainBackupPath)
ProcessUtilities.normalExecutioner(command)
message = '%s successfully extracted.' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
return 1
except BaseException, msg:
message = 'Failed to extract backup for file %s, error message: %s. [ExtractBackup]' % (
self.backupFile, str(msg))
logging.statusWriter(self.logFile, message, 1)
return 0
def CreateMainWebsite(self):
try:
message = 'Creating main account from archive file: %s' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
CompletPathToExtractedArchive = cPanelImporter.mainBackupPath + self.fileName
### Find Domain Name
UserData = '%s/userdata/main' % (CompletPathToExtractedArchive)
data = open(UserData, 'r').readlines()
DomainName = ''
for items in data:
if items.find('main_domain') > -1:
DomainName = items.split(' ')[-1].replace('\n', '')
2019-07-03 13:15:26 +05:00
self.mainDomain = DomainName
break
message = 'Detected main domain for this file is: %s.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
## Find PHP Version
message = 'Finding PHP version for %s.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
DomainMeta = '%s/userdata/%s' % (CompletPathToExtractedArchive, DomainName)
data = open(DomainMeta, 'r').readlines()
phpChecker = 1
2019-07-03 13:15:26 +05:00
for items in data:
if items.find('phpversion') > -1:
self.PHPVersion = items.split(' ')[-1].replace('\n', '')
2019-07-03 13:15:26 +05:00
self.PHPDecider()
phpChecker = 0
2019-07-03 13:15:26 +05:00
break
if phpChecker:
self.PHPDecider()
2019-07-03 13:15:26 +05:00
message = 'PHP version of %s is %s.' % (DomainName, self.PHPVersion)
logging.statusWriter(self.logFile, message, 1)
## Find Email
message = 'Finding Server Admin email for %s.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
data = open(DomainMeta, 'r').readlines()
for items in data:
if items.find('serveradmin') > -1:
self.email = items.split(' ')[-1].replace('\n', '')
2019-07-03 13:15:26 +05:00
break
message = 'Server Admin email for %s is %s.' % (DomainName, self.email)
logging.statusWriter(self.logFile, message, 1)
## Create Site
message = 'Calling core to create %s.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
externalApp = "".join(re.findall("[a-zA-Z]+", DomainName))[:7]
try:
counter = 0
while 1:
tWeb = Websites.objects.get(externalApp=externalApp)
externalApp = '%s%s' % (tWeb.externalApp, str(counter))
counter = counter + 1
except:
pass
2019-07-03 13:15:26 +05:00
result = virtualHostUtilities.createVirtualHost(DomainName, self.email, self.PHPVersion, externalApp, 0, 0,
0, 'admin', 'Default', 0)
if result[0] == 1:
pass
else:
message = 'Failed to create main site %s from archive file: %s' % (DomainName, self.backupFile)
logging.statusWriter(self.logFile, message, 1)
return 0
message = 'Successfully created %s from core.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
### Let see if there is SSL
message = 'Detecting SSL for %s.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
SSLPath = '%s/apache_tls/%s' % (CompletPathToExtractedArchive, DomainName)
if os.path.exists(SSLPath):
message = 'SSL found for %s, setting up.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
self.SetupSSL(SSLPath, DomainName)
message = 'SSL set up OK for %s.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
else:
message = 'SSL not detected for %s, you can later issue SSL from Manage SSL in CyberPanel.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
## Document root
message = 'Restoring document root files for %s.' % (DomainName)
logging.statusWriter(self.logFile, message, 1)
data = open(DomainMeta, 'r').readlines()
for items in data:
if items.find('homedir') > -1:
self.homeDir = items.split(' ')[-1].replace('\n', '')
2019-07-03 13:15:26 +05:00
break
data = open(DomainMeta, 'r').readlines()
for items in data:
if items.find('documentroot') > -1:
self.documentRoot = items.split(' ')[-1].replace('\n', '')
2019-07-03 13:15:26 +05:00
break
nowPath = '/home/%s/public_html' % (DomainName)
if os.path.exists(nowPath):
shutil.rmtree(nowPath)
movePath = '%s/homedir/%s' % (
CompletPathToExtractedArchive, self.documentRoot.replace(self.homeDir, '', 1).replace('/', ''))
2019-08-20 02:50:35 +05:00
shutil.copytree(movePath, nowPath, symlinks=True)
2019-07-03 13:15:26 +05:00
command = 'chown -R %s:%s %s' % (externalApp, externalApp, nowPath)
ProcessUtilities.normalExecutioner(command)
message = 'Main site %s created from archive file: %s' % (DomainName, self.backupFile)
logging.statusWriter(self.logFile, message, 1)
return 1
except BaseException, msg:
message = 'Failed to create main website from backup file %s, error message: %s.' % (
self.backupFile, str(msg))
logging.statusWriter(self.logFile, message, 1)
return 0
def CreateChildDomains(self):
try:
message = 'Creating child domains from archive file: %s' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
CompletPathToExtractedArchive = cPanelImporter.mainBackupPath + self.fileName
### Find Possible Child Domains
message = 'Finding Addon/Subdomains from backup file %s. Account main domain was %s.' % (self.backupFile, self.mainDomain)
logging.statusWriter(self.logFile, message, 1)
UserData = '%s/userdata/main' % (CompletPathToExtractedArchive)
data = open(UserData, 'r').readlines()
Domains = []
addonStatus = 0
subDomainsStatus = 0
for items in data:
if items.find('addon_domains') > -1:
addonStatus = 1
continue
if addonStatus == 1:
if items.find('main_domain') > -1:
addonStatus = 0
continue
else:
cDomain = items.split(':')[0].replace(' ', '')
2019-07-03 13:15:26 +05:00
if len(cDomain) < 2:
continue
Domains.append(ChildDomains(cDomain, 1))
continue
##
if items.find('sub_domains') > -1:
subDomainsStatus = 1
continue
existCheck = 0
if subDomainsStatus == 1:
cDomain = items.split(' ')[-1].replace('\n', '')
2019-07-03 13:15:26 +05:00
for items in Domains:
if cDomain.find(items.domain) > -1:
existCheck = 1
if existCheck == 0:
if len(cDomain) > 2:
Domains.append(ChildDomains(cDomain, 0))
message = 'Following Addon/Subdomains found for backup file %s. Account main domain was %s.' % (
self.backupFile, self.mainDomain)
logging.statusWriter(self.logFile, message, 1)
for items in Domains:
print items.domain
## Starting Child-domains creation
message = 'Starting Addon/Subdomains creation from backup file %s. Account main domain was %s.' % (
self.backupFile, self.mainDomain)
logging.statusWriter(self.logFile, message, 1)
for items in Domains:
try:
2019-07-03 13:15:26 +05:00
message = 'Creating %s.' % (items.domain)
logging.statusWriter(self.logFile, message, 1)
2019-07-03 13:15:26 +05:00
path = '/home/' + self.mainDomain + '/public_html/' + items.domain
2019-07-03 13:15:26 +05:00
## Find PHP Version
2019-07-03 13:15:26 +05:00
if items.addon == 1:
DomainMeta = '%s/userdata/%s.%s' % (CompletPathToExtractedArchive, items.domain, self.mainDomain)
else:
DomainMeta = '%s/userdata/%s' % (CompletPathToExtractedArchive, items.domain)
data = open(DomainMeta, 'r').readlines()
phpChecker = 1
for it in data:
if it.find('phpversion') > -1:
self.PHPVersion = it.split(' ')[-1].replace('\n', '')
self.PHPDecider()
phpChecker = 0
break
if phpChecker:
2019-07-03 13:15:26 +05:00
self.PHPDecider()
message = 'Calling core to create %s.' % (items.domain)
2019-07-03 13:15:26 +05:00
logging.statusWriter(self.logFile, message, 1)
result = virtualHostUtilities.createDomain(self.mainDomain, items.domain, self.PHPVersion, path, 0, 0,
0, 'admin', 0)
2019-07-03 13:15:26 +05:00
if result[0] == 1:
message = 'Child domain %s created from archive file: %s' % (items.domain, self.backupFile)
logging.statusWriter(self.logFile, message, 1)
else:
message = 'Failed to create Child domain %s from archive file: %s' % (items.domain, self.backupFile)
logging.statusWriter(self.logFile, message, 1)
2019-07-03 13:15:26 +05:00
## Setup SSL
2019-07-03 13:15:26 +05:00
message = 'Detecting SSL for %s.' % (items.domain)
2019-07-03 13:15:26 +05:00
logging.statusWriter(self.logFile, message, 1)
SSLPath = '%s/apache_tls/%s' % (CompletPathToExtractedArchive, items.domain)
2019-07-03 13:15:26 +05:00
if os.path.exists(SSLPath):
message = 'SSL found for %s, setting up.' % (items.domain)
logging.statusWriter(self.logFile, message, 1)
self.SetupSSL(SSLPath, items.domain)
message = 'SSL set up OK for %s.' % (items.domain)
logging.statusWriter(self.logFile, message, 1)
else:
SSLPath = '%s/apache_tls/%s.%s' % (CompletPathToExtractedArchive, items.domain, self.mainDomain)
if os.path.exists(SSLPath):
message = 'SSL found for %s, setting up.' % (items.domain)
logging.statusWriter(self.logFile, message, 1)
self.SetupSSL(SSLPath, items.domain)
message = 'SSL set up OK for %s.' % (items.domain)
logging.statusWriter(self.logFile, message, 1)
else:
message = 'SSL not detected for %s, you can later issue SSL from Manage SSL in CyberPanel.' % (
items.domain)
logging.statusWriter(self.logFile, message, 1)
2019-07-03 13:15:26 +05:00
## Creating Document root for childs
2019-07-03 13:15:26 +05:00
message = 'Restoring document root files for %s.' % (items.domain)
logging.statusWriter(self.logFile, message, 1)
2019-07-03 13:15:26 +05:00
externalApp = "".join(re.findall("[a-zA-Z]+", self.mainDomain))[:7]
2019-07-03 13:15:26 +05:00
data = open(DomainMeta, 'r').readlines()
2019-07-03 13:15:26 +05:00
for items in data:
if items.find('documentroot') > -1:
ChildDocRoot = items.split(' ')[-1].replace('\n', '')
break
2019-07-03 13:15:26 +05:00
if os.path.exists(path):
shutil.rmtree(path)
2019-07-03 13:15:26 +05:00
movePath = '%s/homedir/public_html/%s' % (
CompletPathToExtractedArchive, ChildDocRoot.replace(self.documentRoot, '', 1).replace('/', ''))
2019-07-03 13:15:26 +05:00
if os.path.exists(movePath):
shutil.move(movePath, path)
else:
movePath = '%s/homedir/%s' % (
CompletPathToExtractedArchive, ChildDocRoot.split('/')[-1].replace(self.documentRoot, '', 1).replace('/', ''))
if os.path.exists(movePath):
shutil.move(movePath, path)
else:
movePath = '%s/homedir/%s' % (
CompletPathToExtractedArchive, items.domain)
shutil.move(movePath, path)
2019-07-03 13:15:26 +05:00
command = 'chown -R %s:%s %s' % (externalApp, externalApp, path)
ProcessUtilities.normalExecutioner(command)
2019-07-03 13:15:26 +05:00
message = 'Successfully created child domain.'
logging.statusWriter(self.logFile, message, 1)
except BaseException, msg:
message = 'Failed to create child domain from backup file %s, error message: %s. Moving on..' % (
self.backupFile, str(msg))
2019-07-03 13:15:26 +05:00
return 1
except BaseException, msg:
message = 'Failed to create child domain from backup file %s, error message: %s.' % (
self.backupFile, str(msg))
logging.statusWriter(self.logFile, message, 1)
return 0
def createDummyChild(self, childDomain):
path = '/home/%s/public_html/%s' % (self.mainDomain, childDomain)
virtualHostUtilities.createDomain(self.mainDomain, childDomain, self.PHPVersion, path, 0, 0,
0, 'admin', 0)
2019-07-03 13:15:26 +05:00
def CreateDNSRecords(self):
try:
message = 'We are going to create DNS records now, please note we will not create DKIM records. Make sure to create them from CyberPanel interface using our DKIM manager.'
logging.statusWriter(self.logFile, message, 1)
ipFile = "/etc/cyberpanel/machineIP"
f = open(ipFile)
ipData = f.read()
ipAddress = ipData.split('\n', 1)[0]
admin = Administrator.objects.get(pk=1)
CompletPathToExtractedArchive = cPanelImporter.mainBackupPath + self.fileName
DNSZonesPath = '%s/dnszones' % (CompletPathToExtractedArchive)
for items in os.listdir(DNSZonesPath):
topLevelDomain = items.replace('.db', '', 1)
message = 'Creating DNS records for %s' % (topLevelDomain)
logging.statusWriter(self.logFile, message, 1)
try:
Domains.objects.get(name=topLevelDomain).delete()
except:
pass
try:
pdns = PDNSStatus.objects.get(pk=1)
if pdns.type == 'MASTER':
zone = Domains(admin=admin, name=topLevelDomain, type="MASTER")
zone.save()
else:
zone = Domains(admin=admin, name=topLevelDomain, type="NATIVE")
zone.save()
except:
pass
content = "ns1." + topLevelDomain + " hostmaster." + topLevelDomain + " 1 10800 3600 604800 3600"
soaRecord = Records(domainOwner=zone,
domain_id=zone.id,
name=topLevelDomain,
type="SOA",
content=content,
ttl=3600,
prio=0,
disabled=0,
auth=1)
soaRecord.save()
CurrentZonePath = '%s/%s' % (DNSZonesPath, items)
data = open(CurrentZonePath, 'r').readlines()
SOACheck = 0
start = 0
for items in data:
2019-07-24 22:37:37 +05:00
try:
if items.find('SOA') > -1:
SOACheck = 1
continue
2019-07-03 13:15:26 +05:00
2019-07-24 22:37:37 +05:00
if SOACheck == 1 and items.find(')') > -1:
SOACheck = 0
start = 1
continue
else:
pass
if start == 1:
if len(items) > 3:
if items.find("DKIM1") > -1:
continue
RecordsData = items.split('\t')
if RecordsData[3] == 'A':
RecordsData[4] = ipAddress
if RecordsData[0].find(topLevelDomain) > -1:
2019-08-17 21:14:37 +05:00
if RecordsData[3] == 'MX':
DNS.createDNSRecord(zone, RecordsData[0].rstrip('.'), RecordsData[3],RecordsData[5].rstrip('.').rstrip('.\n'), int(RecordsData[4]), RecordsData[1])
else:
DNS.createDNSRecord(zone, RecordsData[0].rstrip('.'), RecordsData[3], RecordsData[4].rstrip('.').rstrip('.\n'), 0, RecordsData[1])
2019-07-24 22:37:37 +05:00
else:
2019-08-17 21:14:37 +05:00
if RecordsData[3] == 'MX':
DNS.createDNSRecord(zone, RecordsData[0] + '.' + topLevelDomain, RecordsData[3],
RecordsData[5].rstrip('.').rstrip('.\n'), RecordsData[4],
RecordsData[1])
else:
DNS.createDNSRecord(zone, RecordsData[0] + '.' + topLevelDomain , RecordsData[3], RecordsData[4].rstrip('.').rstrip('.\n'), 0,
RecordsData[1])
2019-07-24 22:37:37 +05:00
except BaseException, msg:
message = 'Failed while creating DNS entry for %s, error message: %s.' % (topLevelDomain, str(msg))
logging.statusWriter(self.logFile, message, 1)
2019-07-03 13:15:26 +05:00
message = 'DNS records successfully created for %s.' % (topLevelDomain)
logging.statusWriter(self.logFile, message, 1)
return 1
except BaseException, msg:
message = 'Failed to create DNS records from file %s, error message: %s.' % (
self.backupFile, str(msg))
logging.statusWriter(self.logFile, message, 1)
return 0
def setupConnection(self, db=None):
try:
passFile = "/etc/cyberpanel/mysqlPassword"
f = open(passFile)
data = f.read()
password = data.split('\n', 1)[0]
password = password.replace('\n', '').replace('\r', '')
2019-07-03 13:15:26 +05:00
conn = mysql.connect(user='root', passwd=password, cursorclass=cursors.SSCursor)
cursor = conn.cursor()
return conn, cursor
except BaseException, msg:
message = 'Failed to connect to database, error message: %s. [ExtractBackup]' % (str(msg))
logging.statusWriter(self.logFile, message, 1)
return 0, 0
def RestoreDatabases(self):
try:
message = 'Restoring databases from %s.' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
##
passFile = "/etc/cyberpanel/mysqlPassword"
f = open(passFile)
data = f.read()
password = data.split('\n', 1)[0]
##
connection, cursor = self.setupConnection()
CompletPathToExtractedArchive = cPanelImporter.mainBackupPath + self.fileName
DatabasesPath = '%s/mysql' % (CompletPathToExtractedArchive)
for items in os.listdir(DatabasesPath):
if items.find('roundcube') > -1:
continue
2019-07-03 13:15:26 +05:00
if items.endswith('.sql'):
message = 'Restoring MySQL dump for %s.' % (items.replace('.sql', ''))
2019-07-03 13:15:26 +05:00
logging.statusWriter(self.logFile, message, 1)
try:
cursor.execute("CREATE DATABASE `%s`" % (items.replace('.sql', '')))
2019-07-03 13:15:26 +05:00
except BaseException, msg:
2019-07-24 22:37:37 +05:00
message = 'Failed while restoring database %s from backup file %s, error message: %s' % (items.replace('.sql', ''), self.backupFile, str(msg))
2019-07-03 13:15:26 +05:00
logging.statusWriter(self.logFile, message, 1)
command = 'sudo mysql -u root -p' + password + ' ' + items.replace('.sql', '')
2019-07-03 13:15:26 +05:00
cmd = shlex.split(command)
DBPath = "%s/%s" % (DatabasesPath, items)
with open(DBPath, 'r') as f:
res = subprocess.call(cmd, stdin=f)
website = Websites.objects.get(domain=self.mainDomain)
## Trying to figure out dbname
CommandsPath = '%s/mysql.sql' % (CompletPathToExtractedArchive)
data = open(CommandsPath, 'r').readlines()
for inItems in data:
if inItems.find('GRANT ALL PRIVILEGES') > -1 and inItems.find('localhost') > -1 and inItems.find('_test') == -1:
cDBName = inItems.split('`')[1].replace('\\', '')
logging.statusWriter(self.logFile, inItems, 1)
if cDBName == items.replace('.sql', ''):
cDBUser = inItems.split("'")[1]
message = 'Database user for %s is %s.' % (cDBName, cDBUser)
logging.statusWriter(self.logFile, message, 1)
if Databases.objects.filter(dbUser=cDBUser).count() > 0:
continue
break
db = Databases(website=website, dbName=items.replace('.sql', ''), dbUser=cDBUser)
2019-07-03 13:15:26 +05:00
db.save()
message = 'MySQL dump successfully restored for %s.' % (items.replace('.sql', ''))
2019-07-03 13:15:26 +05:00
logging.statusWriter(self.logFile, message, 1)
message = 'Creating Database users from backup file %s.' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
CommandsPath = '%s/mysql.sql' % (CompletPathToExtractedArchive)
data = open(CommandsPath, 'r').readlines()
for items in data:
if items.find("--") > -1 or items.find("'cyberpanel'@") > -1:
continue
try:
cursor.execute(items)
except BaseException, msg:
2019-07-24 22:37:37 +05:00
message = 'Failed while restoring database %s from backup file %s, error message: %s' % (
items.replace('.sql', ''), self.backupFile, str(msg))
2019-07-03 13:15:26 +05:00
logging.statusWriter(self.logFile, message, 1)
connection.close()
message = 'Databases successfully restored.'
logging.statusWriter(self.logFile, message, 1)
return 1
except BaseException, msg:
message = 'Failed to retore databases from file %s, error message: %s.' % (
self.backupFile, str(msg))
logging.statusWriter(self.logFile, message, 1)
return 0
def FixPermissions(self):
externalApp = "".join(re.findall("[a-zA-Z]+", self.mainDomain))[:7]
command = "sudo chown -R " + externalApp + ":" + externalApp + " /home/" + self.mainDomain
ProcessUtilities.normalExecutioner(command)
command = "sudo chown -R lscpd:lscpd /home/" + self.mainDomain + "/logs"
ProcessUtilities.normalExecutioner(command)
command = "sudo find %s -type d -exec chmod 0755 {} \;" % ("/home/" + self.mainDomain + "/public_html")
ProcessUtilities.normalExecutioner(command)
command = "sudo find %s -type f -exec chmod 0644 {} \;" % ("/home/" + self.mainDomain + "/public_html")
ProcessUtilities.normalExecutioner(command)
def MainController(self):
if self.ExtractBackup():
pass
else:
return 0
if self.CreateMainWebsite():
pass
else:
return 0
if self.CreateChildDomains():
pass
else:
return 0
if self.CreateDNSRecords():
pass
else:
return 0
2019-07-24 22:37:37 +05:00
2019-07-03 13:15:26 +05:00
if self.RestoreDatabases():
pass
else:
return 0
self.RestoreEmails()
self.FixPermissions()
message = 'Backup file %s successfully restored.' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
return 1
def DeleteSite(self):
vhost.deleteVirtualHostConfigurations(self.mainDomain)
def checkIfExists(self, virtualHostName):
if Websites.objects.filter(domain=virtualHostName).count() > 0:
return 1
if CDomains.objects.filter(domain=virtualHostName).count() > 0:
return 1
return 0
2019-07-03 13:15:26 +05:00
def RestoreEmails(self):
try:
message = 'Restoring emails from archive file: %s' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
CompletPathToExtractedArchive = cPanelImporter.mainBackupPath + self.fileName
### Find Mail Format
UserData = '%s/homedir/mail' % (CompletPathToExtractedArchive)
FormatPath = '%s/mailbox_format.cpanel' % (UserData)
message = 'Detecting email format from %s.' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
2019-08-13 16:27:56 +05:00
try:
2019-07-03 13:15:26 +05:00
2019-08-13 16:27:56 +05:00
Format = open(FormatPath, 'r').read()
if Format.find('mdbox') > -1:
self.mailFormat = cPanelImporter.MdBox
message = 'Mdbox format detected from %s.' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
else:
self.mailFormat = cPanelImporter.MailDir
message = 'Maildir format detected from %s.' % (self.backupFile)
logging.statusWriter(self.logFile, message, 1)
except:
2019-07-03 13:15:26 +05:00
self.mailFormat = cPanelImporter.MailDir
####
for items in os.listdir(UserData):
FinalMailDomainPath = '%s/%s' % (UserData, items)
if os.path.isdir(FinalMailDomainPath):
if items[0] == '.':
continue
if items.find('.') > -1:
for it in os.listdir(FinalMailDomainPath):
try:
if self.checkIfExists(items) == 0:
self.createDummyChild(items)
2019-07-03 13:15:26 +05:00
mailUtilities.createEmailAccount(items, it, 'cyberpanel')
finalEmailUsername = it + "@" + items
message = 'Starting restore for %s.' % (finalEmailUsername)
logging.statusWriter(self.logFile, message, 1)
eUser = EUsers.objects.get(email=finalEmailUsername)
2019-07-03 13:15:26 +05:00
if self.mailFormat == cPanelImporter.MailDir:
eUser.mail = 'maildir:/home/vmail/%s/%s/Maildir' % (items, it)
MailPath = '/home/vmail/%s/%s' % (items, it)
2019-07-03 13:15:26 +05:00
command = 'mkdir -p %s' % (MailPath)
ProcessUtilities.normalExecutioner(command)
2019-07-03 13:15:26 +05:00
command = 'rm -rf %s/Maildir' % (MailPath)
ProcessUtilities.normalExecutioner(command)
MailPathInBackup = '%s/%s' % (FinalMailDomainPath, it)
2019-07-03 13:15:26 +05:00
command = 'mv %s %s/Maildir' % (MailPathInBackup, MailPath)
subprocess.call(command, shell=True)
2019-07-03 13:15:26 +05:00
else:
eUser.mail = 'mdbox:/home/vmail/%s/%s/Mdbox' % (items, it)
MailPath = '/home/vmail/%s/%s' % (items, it)
2019-07-03 13:15:26 +05:00
command = 'mkdir -p %s' % (MailPath)
ProcessUtilities.normalExecutioner(command)
2019-07-03 13:15:26 +05:00
command = 'rm -rf %s/Mdbox' % (MailPath)
ProcessUtilities.normalExecutioner(command)
MailPathInBackup = '%s/%s' % (FinalMailDomainPath, it)
2019-07-03 13:15:26 +05:00
command = 'mv %s %s/Mdbox' % (MailPathInBackup, MailPath)
subprocess.call(command, shell=True)
2019-07-03 13:15:26 +05:00
## Also update password
2019-07-03 13:15:26 +05:00
PasswordPath = '%s/homedir/etc/%s/shadow' % (CompletPathToExtractedArchive, items)
PasswordData = open(PasswordPath, 'r').readlines()
2019-07-03 13:15:26 +05:00
for i in PasswordData:
if i.find(it) > -1:
finalPassword = '%s%s' % ('{CRYPT}', i.split(':')[1])
eUser.password = finalPassword
2019-07-03 13:15:26 +05:00
eUser.save()
message = 'Restore completed for %s.' % (finalEmailUsername)
logging.statusWriter(self.logFile, message, 1)
except BaseException, msg:
message = 'Failed to restore emails from archive file %s, For domain: %s. error message: %s. [ExtractBackup]' % (
self.backupFile, items, str(msg))
logging.statusWriter(self.logFile, message, 1)
2019-07-03 13:15:26 +05:00
command = 'chown -R vmail:vmail /home/vmail'
ProcessUtilities.normalExecutioner(command)
message = 'Emails successfully restored'
logging.statusWriter(self.logFile, message, 1)
return 1
except BaseException, msg:
message = 'Failed to restore emails from archive file %s, error message: %s. [ExtractBackup]' % (
self.backupFile, str(msg))
logging.statusWriter(self.logFile, message, 1)
return 0
def main():
LogFile = '/home/cyberpanel/%s' % (str(randint(1000, 9999)))
message = 'Backup logs to be generated in %s' % (LogFile)
print(message)
parser = argparse.ArgumentParser(description='CyberPanel cPanel Importer')
parser.add_argument('--path', help='Path where cPanel .tar.gz files are stored.')
args = parser.parse_args()
for items in os.listdir(args.path):
if items.endswith('.tar.gz'):
finalPath = '%s/%s' % (args.path.rstrip('/'), items)
2019-07-24 22:37:37 +05:00
try:
cI = cPanelImporter(finalPath, LogFile)
if cI.MainController():
pass
else:
pass
except:
pass
2019-07-03 13:15:26 +05:00
if __name__ == "__main__":
main()