mirror of
				https://github.com/usmannasir/cyberpanel.git
				synced 2025-10-26 07:46:35 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			1217 lines
		
	
	
		
			41 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			1217 lines
		
	
	
		
			41 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/local/CyberCP/bin/python
 | |
| try:
 | |
|     import os
 | |
|     import os.path
 | |
|     from django.shortcuts import HttpResponse
 | |
|     from plogical.CyberCPLogFileWriter import CyberCPLogFileWriter as logging
 | |
|     from plogical.httpProc import httpProc
 | |
|     from plogical.acl import ACLManager
 | |
|     import threading as multi
 | |
|     from plogical.mailUtilities import mailUtilities
 | |
|     import boto3
 | |
|     from boto3.s3.transfer import TransferConfig
 | |
|     import json
 | |
|     from .models import *
 | |
|     from math import ceil
 | |
|     import requests
 | |
|     import time
 | |
|     from random import randint
 | |
|     import subprocess, shlex
 | |
|     from plogical.processUtilities import ProcessUtilities
 | |
|     from websiteFunctions.models import Websites, Backups
 | |
|     from plogical.virtualHostUtilities import virtualHostUtilities
 | |
|     from multiprocessing import Process
 | |
|     import plogical.backupUtilities as backupUtil
 | |
| except:
 | |
|     import threading as multi
 | |
|     from random import randint
 | |
|     import json
 | |
|     import requests
 | |
|     import subprocess, shlex
 | |
|     from multiprocessing import Process
 | |
| 
 | |
| 
 | |
| class S3Backups(multi.Thread):
 | |
|     def __init__(self, request=None, data=None, function=None):
 | |
|         multi.Thread.__init__(self)
 | |
|         self.request = request
 | |
|         self.data = data
 | |
|         self.function = function
 | |
| 
 | |
|     def run(self):
 | |
|         try:
 | |
|             if self.function == 'connectAccount':
 | |
|                 self.connectAccount()
 | |
|             elif self.function == 'forceRunAWSBackupDO':
 | |
|                 self.forceRunAWSBackupDO()
 | |
|             elif self.function == 'forceRunAWSBackupMINIO':
 | |
|                 self.forceRunAWSBackupMINIO()
 | |
|         except BaseException as msg:
 | |
|             logging.writeToFile(str(msg) + ' [S3Backups.run]')
 | |
| 
 | |
|     @staticmethod
 | |
|     def getPagination(records, toShow):
 | |
|         pages = float(records) / float(toShow)
 | |
| 
 | |
|         pagination = []
 | |
|         counter = 1
 | |
| 
 | |
|         if pages <= 1.0:
 | |
|             pages = 1
 | |
|             pagination.append(counter)
 | |
|         else:
 | |
|             pages = ceil(pages)
 | |
|             finalPages = int(pages) + 1
 | |
| 
 | |
|             for i in range(1, finalPages):
 | |
|                 pagination.append(counter)
 | |
|                 counter = counter + 1
 | |
| 
 | |
|         return pagination
 | |
| 
 | |
|     @staticmethod
 | |
|     def recordsPointer(page, toShow):
 | |
|         finalPageNumber = ((page * toShow)) - toShow
 | |
|         endPageNumber = finalPageNumber + toShow
 | |
|         return endPageNumber, finalPageNumber
 | |
| 
 | |
|     @staticmethod
 | |
|     def getLogsInJson(logs):
 | |
|         json_data = "["
 | |
|         checker = 0
 | |
|         counter = 1
 | |
| 
 | |
|         for items in logs:
 | |
|             dic = {'id': items.id, 'timeStamp': items.timeStamp, 'level': items.level, 'mesg': items.msg}
 | |
|             if checker == 0:
 | |
|                 json_data = json_data + json.dumps(dic)
 | |
|                 checker = 1
 | |
|             else:
 | |
|                 json_data = json_data + ',' + json.dumps(dic)
 | |
|             counter = counter + 1
 | |
| 
 | |
|         json_data = json_data + ']'
 | |
|         return json_data
 | |
| 
 | |
|     def connectAccount(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             mailUtilities.checkHome()
 | |
| 
 | |
|             path = '/home/cyberpanel/.aws'
 | |
| 
 | |
|             if not os.path.exists(path):
 | |
|                 os.mkdir(path)
 | |
| 
 | |
|             credentials = path + '/credentials'
 | |
| 
 | |
|             credFile = open(credentials, 'w')
 | |
|             credFile.write(self.data['credData'])
 | |
|             credFile.close()
 | |
| 
 | |
|             ##
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchAWSKeys(self):
 | |
|         path = '/home/cyberpanel/.aws'
 | |
|         credentials = path + '/credentials'
 | |
| 
 | |
|         data = open(credentials, 'r').readlines()
 | |
| 
 | |
|         aws_access_key_id = data[1].split(' ')[2].strip(' ').strip('\n')
 | |
|         aws_secret_access_key = data[2].split(' ')[2].strip(' ').strip('\n')
 | |
|         region = data[3].split(' ')[2].strip(' ').strip('\n')
 | |
| 
 | |
|         return aws_access_key_id, aws_secret_access_key, region
 | |
| 
 | |
|     def fetchBuckets(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             aws_access_key_id, aws_secret_access_key, region = self.fetchAWSKeys()
 | |
| 
 | |
|             if region.find('http') > -1:
 | |
|                 s3 = boto3.resource(
 | |
|                     's3',
 | |
|                     aws_access_key_id=aws_access_key_id,
 | |
|                     aws_secret_access_key=aws_secret_access_key,
 | |
|                     endpoint_url=region,
 | |
|                 )
 | |
|             else:
 | |
|                 s3 = boto3.resource(
 | |
|                     's3',
 | |
|                     aws_access_key_id=aws_access_key_id,
 | |
|                     aws_secret_access_key=aws_secret_access_key,
 | |
|                 )
 | |
| 
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for bucket in s3.buckets.all():
 | |
|                 dic = {'name': bucket.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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def createPlan(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             admin = Administrator.objects.get(pk=userID)
 | |
| 
 | |
|             ## What to backup
 | |
| 
 | |
|             WTB = {}
 | |
|             try:
 | |
|                 WTB['data'] = int(self.data['data'])
 | |
|             except:
 | |
|                 WTB['data'] = 0
 | |
| 
 | |
|             try:
 | |
|                 WTB['databases'] = int(self.data['databases'])
 | |
|             except:
 | |
|                 WTB['databases'] = 0
 | |
| 
 | |
|             try:
 | |
|                 WTB['emails'] = int(self.data['emails'])
 | |
|             except:
 | |
|                 WTB['emails'] = 0
 | |
| 
 | |
|             ###
 | |
| 
 | |
|             newPlan = BackupPlan(owner=admin, name=self.data['planName'].replace(' ', ''), freq=self.data['frequency'],
 | |
|                                  retention=self.data['retenion'], bucket=self.data['bucketName'], config=json.dumps(WTB))
 | |
|             newPlan.save()
 | |
| 
 | |
|             for items in self.data['websitesInPlan']:
 | |
|                 wp = WebsitesInPlan(owner=newPlan, domain=items)
 | |
|                 wp.save()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             logging.writeToFile(str(msg) + ' [createPlan]')
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchBackupPlans(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             admin = Administrator.objects.get(pk=userID)
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for plan in admin.backupplan_set.all():
 | |
|                 config = json.loads(plan.config)
 | |
|                 dic = {
 | |
|                     'name': plan.name,
 | |
|                     'bucket': plan.bucket,
 | |
|                     'freq': plan.freq,
 | |
|                     'retention': plan.retention,
 | |
|                     'lastRun': plan.lastRun,
 | |
|                     'data': config['data'],
 | |
|                     'databases': config['databases'],
 | |
|                     'emails': config['emails'],
 | |
|                 }
 | |
| 
 | |
|                 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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def deletePlan(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             delPlan = BackupPlan.objects.get(name=self.data['planName'])
 | |
|             delPlan.delete()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchWebsitesInPlan(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             plan = BackupPlan.objects.get(name=self.data['planName'])
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for website in plan.websitesinplan_set.all():
 | |
|                 dic = {
 | |
|                     'id': website.id,
 | |
|                     'domain': website.domain,
 | |
|                 }
 | |
| 
 | |
|                 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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def deleteDomainFromPlan(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             plan = BackupPlan.objects.get(name=self.data['planName'])
 | |
|             web = WebsitesInPlan.objects.get(owner=plan, domain=self.data['domainName'])
 | |
|             web.delete()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def savePlanChanges(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             changePlan = BackupPlan.objects.get(name=self.data['planName'])
 | |
| 
 | |
|             ## What to backup
 | |
| 
 | |
|             WTB = {}
 | |
|             try:
 | |
|                 WTB['data'] = int(self.data['data'])
 | |
|             except:
 | |
|                 WTB['data'] = 0
 | |
| 
 | |
|             try:
 | |
|                 WTB['databases'] = int(self.data['databases'])
 | |
|             except:
 | |
|                 WTB['databases'] = 0
 | |
| 
 | |
|             try:
 | |
|                 WTB['emails'] = int(self.data['emails'])
 | |
|             except:
 | |
|                 WTB['emails'] = 0
 | |
| 
 | |
|             changePlan.bucket = self.data['bucketName']
 | |
|             changePlan.freq = self.data['frequency']
 | |
|             changePlan.retention = self.data['retention']
 | |
|             changePlan.config = json.dumps(WTB)
 | |
| 
 | |
|             changePlan.save()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchBackupLogs(self):
 | |
|         try:
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             recordsToShow = int(self.data['recordsToShow'])
 | |
|             page = int(self.data['page'])
 | |
| 
 | |
|             backupPlan = BackupPlan.objects.get(name=self.data['planName'])
 | |
|             logs = backupPlan.backuplogs_set.all().order_by('-id')
 | |
| 
 | |
|             pagination = S3Backups.getPagination(len(logs), recordsToShow)
 | |
|             endPageNumber, finalPageNumber = S3Backups.recordsPointer(page, recordsToShow)
 | |
|             jsonData = S3Backups.getLogsInJson(logs[finalPageNumber:endPageNumber])
 | |
| 
 | |
|             data = {}
 | |
|             data['data'] = jsonData
 | |
|             data['pagination'] = pagination
 | |
| 
 | |
|             return proc.ajax(1, None, data)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajaxPre(0, str(msg))
 | |
| 
 | |
|     def createBackup(self, virtualHost):
 | |
| 
 | |
|         website = Websites.objects.get(domain=virtualHost)
 | |
|         # defining paths
 | |
| 
 | |
|         ## /home/example.com/backup
 | |
|         backupPath = os.path.join("/home", virtualHost, "backup/")
 | |
|         domainUser = website.externalApp
 | |
|         backupName = 'backup-' + domainUser + "-" + time.strftime("%m.%d.%Y_%H-%M-%S")
 | |
| 
 | |
|         ## /home/example.com/backup/backup-example.com-02.13.2018_10-24-52
 | |
|         tempStoragePath = os.path.join(backupPath, backupName)
 | |
| 
 | |
|         p = Process(target=backupUtil.submitBackupCreation,
 | |
|                     args=(tempStoragePath, backupName, backupPath, virtualHost))
 | |
|         p.start()
 | |
| 
 | |
|         time.sleep(2)
 | |
| 
 | |
|         while (1):
 | |
| 
 | |
|             backupDomain = virtualHost
 | |
|             status = os.path.join("/home", backupDomain, "backup/status")
 | |
|             backupFileNamePath = os.path.join("/home", backupDomain, "backup/backupFileName")
 | |
|             pid = os.path.join("/home", backupDomain, "backup/pid")
 | |
|             ## read file name
 | |
| 
 | |
|             try:
 | |
|                 fileName = open(backupFileNamePath, 'r').read()
 | |
|             except:
 | |
|                 fileName = "Fetching.."
 | |
| 
 | |
|             ## file name read ends
 | |
| 
 | |
|             if os.path.exists(status):
 | |
|                 status = open(status, 'r').read()
 | |
| 
 | |
|                 if status.find("Completed") > -1:
 | |
| 
 | |
|                     ### Removing Files
 | |
| 
 | |
|                     command = 'sudo rm -f ' + status
 | |
|                     ProcessUtilities.normalExecutioner(command)
 | |
| 
 | |
|                     command = 'sudo rm -f ' + backupFileNamePath
 | |
|                     ProcessUtilities.normalExecutioner(command)
 | |
| 
 | |
|                     command = 'sudo rm -f ' + pid
 | |
|                     ProcessUtilities.normalExecutioner(command)
 | |
| 
 | |
|                     return 1, tempStoragePath
 | |
| 
 | |
|                 elif status.find("[5009]") > -1:
 | |
|                     backupObs = Backups.objects.filter(fileName=fileName)
 | |
|                     for items in backupObs:
 | |
|                         items.delete()
 | |
|                     return 0, status
 | |
| 
 | |
| 
 | |
|     def connectAccountDO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             mailUtilities.checkHome()
 | |
| 
 | |
|             path = '/home/cyberpanel/.do'
 | |
| 
 | |
|             if not os.path.exists(path):
 | |
|                 os.mkdir(path)
 | |
| 
 | |
|             credentials = path + '/credentials'
 | |
| 
 | |
|             credFile = open(credentials, 'w')
 | |
|             credFile.write(self.data['credData'])
 | |
|             credFile.close()
 | |
| 
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchBucketsDO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             filePath = '/home/cyberpanel/.do/credentials'
 | |
| 
 | |
|             data = open(filePath, 'r').readlines()
 | |
| 
 | |
|             accessID = data[1].split('=')[1].strip(' ').strip('\n')
 | |
|             secret = data[2].split('=')[1].strip(' ').strip('\n')
 | |
| 
 | |
|             session = boto3.session.Session()
 | |
|             client = session.client(
 | |
|                 's3',
 | |
|                 region_name=self.data['doRegion'],
 | |
|                 endpoint_url='https://' + self.data['doRegion'] + '.digitaloceanspaces.com',
 | |
|                 aws_access_key_id=accessID,
 | |
|                 aws_secret_access_key=secret
 | |
|             )
 | |
|             response = client.list_buckets()
 | |
|             spaces = [space['Name'] for space in response['Buckets']]
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for space in spaces:
 | |
|                 dic = {'name': space}
 | |
| 
 | |
|                 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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             logging.writeToFile(str(msg))
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def createPlanDO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             admin = Administrator.objects.get(pk=userID)
 | |
| 
 | |
|             newPlan = BackupPlanDO(owner=admin, name=self.data['planName'].replace(' ', ''),
 | |
|                                    freq=self.data['frequency'],
 | |
|                                    retention=self.data['retenion'], bucket=self.data['bucketName'],
 | |
|                                    type=self.data['type'],
 | |
|                                    region=self.data['region'])
 | |
|             newPlan.save()
 | |
| 
 | |
|             for items in self.data['websitesInPlan']:
 | |
|                 wp = WebsitesInPlanDO(owner=newPlan, domain=items)
 | |
|                 wp.save()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             logging.writeToFile(str(msg) + ' [createPlanDO]')
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchBackupPlansDO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             admin = Administrator.objects.get(pk=userID)
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for plan in admin.backupplando_set.filter(type=self.data['type']):
 | |
|                 dic = {
 | |
|                     'name': plan.name,
 | |
|                     'bucket': plan.bucket,
 | |
|                     'freq': plan.freq,
 | |
|                     'retention': plan.retention,
 | |
|                     'lastRun': plan.lastRun,
 | |
|                 }
 | |
| 
 | |
|                 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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def deletePlanDO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             delPlan = BackupPlanDO.objects.get(name=self.data['planName'])
 | |
|             delPlan.delete()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchWebsitesInPlanDO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             plan = BackupPlanDO.objects.get(name=self.data['planName'])
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for website in plan.websitesinplando_set.all():
 | |
|                 dic = {
 | |
|                     'id': website.id,
 | |
|                     'domain': website.domain,
 | |
|                 }
 | |
| 
 | |
|                 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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchBackupLogsDO(self):
 | |
|         try:
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             recordsToShow = int(self.data['recordsToShow'])
 | |
|             page = int(self.data['page'])
 | |
| 
 | |
|             backupPlan = BackupPlanDO.objects.get(name=self.data['planName'])
 | |
|             logs = backupPlan.backuplogsdo_set.all().order_by('-id')
 | |
| 
 | |
|             pagination = S3Backups.getPagination(len(logs), recordsToShow)
 | |
|             endPageNumber, finalPageNumber = S3Backups.recordsPointer(page, recordsToShow)
 | |
|             jsonData = S3Backups.getLogsInJson(logs[finalPageNumber:endPageNumber])
 | |
| 
 | |
|             data = {}
 | |
|             data['data'] = jsonData
 | |
|             data['pagination'] = pagination
 | |
| 
 | |
|             return proc.ajax(1, None, data)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajaxPre(0, str(msg))
 | |
| 
 | |
|     def deleteDomainFromPlanDO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             plan = BackupPlanDO.objects.get(name=self.data['planName'])
 | |
|             web = WebsitesInPlanDO.objects.get(owner=plan, domain=self.data['domainName'])
 | |
|             web.delete()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def savePlanChangesDO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             changePlan = BackupPlanDO.objects.get(name=self.data['planName'])
 | |
| 
 | |
|             changePlan.bucket = self.data['bucketName']
 | |
|             changePlan.freq = self.data['frequency']
 | |
|             changePlan.retention = self.data['retention']
 | |
|             changePlan.region = self.data['region']
 | |
| 
 | |
|             changePlan.save()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def forceRunAWSBackupDO(self):
 | |
|         try:
 | |
| 
 | |
|             plan = BackupPlanDO.objects.get(name=self.data['planName'])
 | |
|             bucketName = plan.bucket.strip('\n').strip(' ')
 | |
|             runTime = time.strftime("%d:%m:%Y")
 | |
| 
 | |
|             ## Setup DO Client
 | |
| 
 | |
|             filePath = '/home/cyberpanel/.do/credentials'
 | |
| 
 | |
|             data = open(filePath, 'r').readlines()
 | |
| 
 | |
|             accessID = data[1].split('=')[1].strip(' ').strip('\n')
 | |
|             secret = data[2].split('=')[1].strip(' ').strip('\n')
 | |
| 
 | |
|             session = boto3.session.Session()
 | |
|             client = session.client(
 | |
|                 's3',
 | |
|                 region_name=plan.region,
 | |
|                 endpoint_url='https://' + plan.region + '.digitaloceanspaces.com',
 | |
|                 aws_access_key_id=accessID,
 | |
|                 aws_secret_access_key=secret
 | |
|             )
 | |
| 
 | |
|             config = TransferConfig(multipart_threshold=1024 * 25, max_concurrency=10,
 | |
|                                     multipart_chunksize=1024 * 25, use_threads=True)
 | |
| 
 | |
|             ## Set Expiration for objects
 | |
|             try:
 | |
| 
 | |
|                 client.put_bucket_lifecycle_configuration(
 | |
|                     Bucket='string',
 | |
|                     LifecycleConfiguration={
 | |
|                         'Rules': [
 | |
|                             {
 | |
|                                 'Expiration': {
 | |
|                                     'Days': plan.retention,
 | |
|                                     'ExpiredObjectDeleteMarker': True
 | |
|                                 },
 | |
|                                 'ID': plan.name,
 | |
|                                 'Prefix': '',
 | |
|                                 'Filter': {
 | |
|                                     'Prefix': plan.name + '/',
 | |
|                                 },
 | |
|                                 'Status': 'Enabled',
 | |
| 
 | |
|                             },
 | |
|                         ]
 | |
|                     }
 | |
|                 )
 | |
|             except BaseException as msg:
 | |
|                 BackupLogsDO(owner=plan, timeStamp=time.strftime("%b %d %Y, %H:%M:%S"), level='ERROR',
 | |
|                              msg=str(msg)).save()
 | |
| 
 | |
|             ##
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 BackupLogsDO(owner=plan, timeStamp=time.strftime("%b %d %Y, %H:%M:%S"), level='INFO',
 | |
|                              msg='Unauthorised user tried to run AWS Backups.').save()
 | |
|                 return 0
 | |
| 
 | |
|             BackupLogsDO(owner=plan, level='INFO', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                          msg='Starting backup process..').save()
 | |
| 
 | |
|             for items in plan.websitesinplando_set.all():
 | |
|                 result = self.createBackup(items.domain)
 | |
|                 if result[0]:
 | |
|                     key = plan.name + '/' + runTime + '/' + result[1].split('/')[-1] + ".tar.gz"
 | |
|                     client.upload_file(
 | |
|                         result[1] + ".tar.gz",
 | |
|                         bucketName,
 | |
|                         key,
 | |
|                         Config=config,
 | |
|                     )
 | |
|                     command = 'rm -f ' + result[1] + ".tar.gz"
 | |
|                     ProcessUtilities.executioner(command)
 | |
|                     BackupLogsDO(owner=plan, level='INFO', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                                  msg='Backup successful for ' + items.domain + '.').save()
 | |
| 
 | |
|                 else:
 | |
|                     BackupLogsDO(owner=plan, level='ERROR', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                                  msg='Backup failed for ' + items.domain + '. Error: ' + result[1]).save()
 | |
| 
 | |
|             plan.lastRun = runTime
 | |
|             plan.save()
 | |
| 
 | |
|             BackupLogsDO(owner=plan, level='INFO', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                          msg='Backup Process Finished.').save()
 | |
|         except BaseException as msg:
 | |
|             logging.writeToFile(str(msg) + ' [S3Backups.forceRunAWSBackupDO]')
 | |
|             plan = BackupPlanDO.objects.get(name=self.data['planName'])
 | |
|             BackupLogsDO(owner=plan, timeStamp=time.strftime("%b %d %Y, %H:%M:%S"), level='ERROR', msg=str(msg)).save()
 | |
| 
 | |
|     def addMINIONode(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use MINIO Backups.')
 | |
| 
 | |
|             admin = Administrator.objects.get(pk=userID)
 | |
| 
 | |
|             newNode = MINIONodes(owner=admin, endPointURL=self.data['endPoint'], accessKey=self.data['accessKey'],
 | |
|                                  secretKey=self.data['secretKey'])
 | |
|             newNode.save()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             logging.writeToFile(str(msg) + ' [addMINIONode]')
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchMINIONodes(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use MINIO Backups.')
 | |
| 
 | |
|             admin = Administrator.objects.get(pk=userID)
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for node in admin.minionodes_set.all():
 | |
|                 dic = {
 | |
|                     'accessKey': node.accessKey,
 | |
|                     'endPoint': node.endPointURL.lstrip('https://').lstrip('http://')
 | |
|                 }
 | |
| 
 | |
|                 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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def deleteMINIONode(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             delNode = MINIONodes.objects.get(accessKey=self.data['accessKey'])
 | |
|             delNode.delete()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def createPlanMINIO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             admin = Administrator.objects.get(pk=userID)
 | |
| 
 | |
|             minioNode = MINIONodes.objects.get(accessKey=self.data['minioNode'])
 | |
| 
 | |
|             newPlan = BackupPlanMINIO(owner=admin, name=self.data['planName'].replace(' ', ''),
 | |
|                                       freq=self.data['frequency'],
 | |
|                                       retention=self.data['retenion'], minioNode=minioNode)
 | |
|             newPlan.save()
 | |
| 
 | |
|             for items in self.data['websitesInPlan']:
 | |
|                 wp = WebsitesInPlanMINIO(owner=newPlan, domain=items)
 | |
|                 wp.save()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             logging.writeToFile(str(msg) + ' [createPlanDO]')
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchBackupPlansMINIO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             admin = Administrator.objects.get(pk=userID)
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for plan in admin.backupplanminio_set.all():
 | |
|                 dic = {
 | |
|                     'name': plan.name,
 | |
|                     'minioNode': plan.minioNode.accessKey,
 | |
|                     'freq': plan.freq,
 | |
|                     'retention': plan.retention,
 | |
|                     'lastRun': plan.lastRun,
 | |
|                 }
 | |
| 
 | |
|                 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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def deletePlanMINIO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             delPlan = BackupPlanMINIO.objects.get(name=self.data['planName'])
 | |
|             delPlan.delete()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def savePlanChangesMINIO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             changePlan = BackupPlanMINIO.objects.get(name=self.data['planName'])
 | |
|             minioNode = MINIONodes.objects.get(accessKey=self.data['minioNode'].strip(' ').strip('\n'))
 | |
| 
 | |
|             changePlan.minioNode = minioNode
 | |
|             changePlan.freq = self.data['frequency']
 | |
|             changePlan.retention = self.data['retention']
 | |
| 
 | |
|             changePlan.save()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def forceRunAWSBackupMINIO(self):
 | |
|         try:
 | |
| 
 | |
|             plan = BackupPlanMINIO.objects.get(name=self.data['planName'])
 | |
|             runTime = time.strftime("%d:%m:%Y")
 | |
| 
 | |
|             ## Setup MINIO Client
 | |
| 
 | |
|             endPoint = plan.minioNode.endPointURL
 | |
|             accessID = plan.minioNode.accessKey
 | |
|             secret = plan.minioNode.secretKey
 | |
| 
 | |
|             session = boto3.session.Session()
 | |
|             client = session.client(
 | |
|                 's3',
 | |
|                 endpoint_url= endPoint,
 | |
|                 aws_access_key_id=accessID,
 | |
|                 aws_secret_access_key=secret,
 | |
|                 verify= False
 | |
|             )
 | |
| 
 | |
|             config = TransferConfig(multipart_threshold=1024 * 25, max_concurrency=10,
 | |
|                                     multipart_chunksize=1024 * 25, use_threads=True)
 | |
| 
 | |
|             try:
 | |
|                 client.create_bucket(Bucket=plan.name.lower())
 | |
|             except BaseException as msg:
 | |
|                 BackupLogsMINIO(owner=plan, level='INFO', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                                 msg=str(msg)).save()
 | |
|                 return 0
 | |
| 
 | |
|             ##
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 BackupLogsMINIO(owner=plan, timeStamp=time.strftime("%b %d %Y, %H:%M:%S"), level='INFO',
 | |
|                                 msg='Unauthorised user tried to run AWS Backups.').save()
 | |
|                 return 0
 | |
| 
 | |
|             BackupLogsMINIO(owner=plan, level='INFO', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                             msg='Starting backup process..').save()
 | |
| 
 | |
|             for items in plan.websitesinplanminio_set.all():
 | |
|                 result = self.createBackup(items.domain)
 | |
|                 if result[0]:
 | |
|                     key = runTime + '/' + result[1].split('/')[-1] + ".tar.gz"
 | |
| 
 | |
|                     client.upload_file(
 | |
|                         result[1] + ".tar.gz",
 | |
|                         plan.name.lower(),
 | |
|                         key,
 | |
|                         Config=config,
 | |
|                     )
 | |
|                     command = 'rm -f ' + result[1] + ".tar.gz"
 | |
|                     ProcessUtilities.executioner(command)
 | |
|                     BackupLogsMINIO(owner=plan, level='INFO', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                                     msg='Backup successful for ' + items.domain + '.').save()
 | |
|                 else:
 | |
|                     BackupLogsMINIO(owner=plan, level='ERROR', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                                     msg='Backup failed for ' + items.domain + '. Error: ' + result[1]).save()
 | |
| 
 | |
|             plan.lastRun = runTime
 | |
|             plan.save()
 | |
| 
 | |
|             BackupLogsMINIO(owner=plan, level='INFO', timeStamp=time.strftime("%b %d %Y, %H:%M:%S"),
 | |
|                             msg='Backup Process Finished.').save()
 | |
|         except BaseException as msg:
 | |
|             logging.writeToFile(str(msg) + ' [S3Backups.forceRunAWSBackupMINIO]')
 | |
|             plan = BackupPlanMINIO.objects.get(name=self.data['planName'])
 | |
|             BackupLogsMINIO(owner=plan, timeStamp=time.strftime("%b %d %Y, %H:%M:%S"), level='ERROR',
 | |
|                             msg=str(msg)).save()
 | |
| 
 | |
|     def fetchWebsitesInPlanMINIO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             plan = BackupPlanMINIO.objects.get(name=self.data['planName'])
 | |
|             json_data = "["
 | |
|             checker = 0
 | |
| 
 | |
|             for website in plan.websitesinplanminio_set.all():
 | |
|                 dic = {
 | |
|                     'id': website.id,
 | |
|                     'domain': website.domain,
 | |
|                 }
 | |
| 
 | |
|                 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({'status': 1, 'error_message': "None", "data": json_data})
 | |
|             return HttpResponse(final_json)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 | |
| 
 | |
|     def fetchBackupLogsMINIO(self):
 | |
|         try:
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             recordsToShow = int(self.data['recordsToShow'])
 | |
|             page = int(self.data['page'])
 | |
| 
 | |
|             backupPlan = BackupPlanMINIO.objects.get(name=self.data['planName'])
 | |
|             logs = backupPlan.backuplogsminio_set.all().order_by('-id')
 | |
| 
 | |
|             pagination = S3Backups.getPagination(len(logs), recordsToShow)
 | |
|             endPageNumber, finalPageNumber = S3Backups.recordsPointer(page, recordsToShow)
 | |
|             jsonData = S3Backups.getLogsInJson(logs[finalPageNumber:endPageNumber])
 | |
| 
 | |
|             data = {}
 | |
|             data['data'] = jsonData
 | |
|             data['pagination'] = pagination
 | |
| 
 | |
|             return proc.ajax(1, None, data)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajaxPre(0, str(msg))
 | |
| 
 | |
|     def deleteDomainFromPlanMINIO(self):
 | |
|         try:
 | |
| 
 | |
|             proc = httpProc(self.request, None, None)
 | |
| 
 | |
|             userID = self.request.session['userID']
 | |
|             currentACL = ACLManager.loadedACL(userID)
 | |
| 
 | |
|             if currentACL['admin'] == 0:
 | |
|                 return proc.ajax(0, 'Only administrators can use AWS S3 Backups.')
 | |
| 
 | |
|             plan = BackupPlanMINIO.objects.get(name=self.data['planName'])
 | |
|             web = WebsitesInPlanMINIO.objects.get(owner=plan, domain=self.data['domainName'])
 | |
|             web.delete()
 | |
| 
 | |
|             return proc.ajax(1, None)
 | |
| 
 | |
|         except BaseException as msg:
 | |
|             proc = httpProc(self.request, None, None)
 | |
|             return proc.ajax(0, str(msg))
 |