Files
CyberPanel/tuning/tuning.py

181 lines
7.8 KiB
Python
Raw Normal View History

2019-12-10 23:04:24 +05:00
#!/usr/local/CyberCP/bin/python
2018-11-10 02:37:45 +05:00
import os.path
import sys
import django
2021-03-03 19:29:48 +05:00
from plogical.httpProc import httpProc
2018-11-10 02:37:45 +05:00
sys.path.append('/usr/local/CyberCP')
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "CyberCP.settings")
django.setup()
from django.http import HttpResponse
import json
import plogical.CyberCPLogFileWriter as logging
from plogical.tuning import tuning
from loginSystem.views import loadLoginPage
from plogical.virtualHostUtilities import virtualHostUtilities
from plogical.acl import ACLManager
from plogical.processUtilities import ProcessUtilities
class tuningManager:
def loadTuningHome(self, request, userID):
2021-03-03 19:29:48 +05:00
proc = httpProc(request, 'tuning/index.html',
None, 'admin')
return proc.render()
2018-11-10 02:37:45 +05:00
def liteSpeedTuning(self, request, userID):
2021-03-03 19:29:48 +05:00
proc = httpProc(request, 'tuning/liteSpeedTuning.html',
None, 'admin')
return proc.render()
2018-11-10 02:37:45 +05:00
def phpTuning(self, request, userID):
2021-03-06 11:45:17 +05:00
currentACL = ACLManager.loadedACL(userID)
if ProcessUtilities.decideServer() == ProcessUtilities.OLS:
websitesName = ACLManager.findAllSites(currentACL, userID)
OLS = 1
proc = httpProc(request, 'tuning/phpTuning.html',
{'websiteList': websitesName, 'OLS': OLS}, 'admin')
return proc.render()
else:
OLS = 0
proc = httpProc(request, 'tuning/phpTuning.html',
{'OLS': OLS}, 'admin')
return proc.render()
2018-11-10 02:37:45 +05:00
def tuneLitespeed(self, userID, data):
try:
currentACL = ACLManager.loadedACL(userID)
if currentACL['admin'] == 1:
pass
else:
return ACLManager.loadError()
2018-11-10 02:37:45 +05:00
status = data['status']
if status == "fetch":
json_data = json.dumps(tuning.fetchTuningDetails())
data_ret = {'fetch_status': 1, 'error_message': "None", "tuning_data": json_data,
'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
else:
2025-06-15 01:10:08 +05:00
if data.get('maxConn') is None:
2018-11-10 02:37:45 +05:00
data_ret = {'fetch_status': 1, 'error_message': "Provide Max Connections", 'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
2025-06-15 01:10:08 +05:00
if data.get('maxSSLConn') is None:
2018-11-10 02:37:45 +05:00
data_ret = {'fetch_status': 1, 'error_message': "Provide Max SSL Connections",
'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
2025-06-15 01:10:08 +05:00
if data.get('keepAlive') is None:
2018-11-10 02:37:45 +05:00
data_ret = {'fetch_status': 1, 'error_message': "Provide Keep Alive", 'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
2025-06-15 01:10:08 +05:00
if data.get('inMemCache') is None:
2018-11-10 02:37:45 +05:00
data_ret = {'fetch_status': 1, 'error_message': "Provide Cache Size in memory",
'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
2025-06-15 01:10:08 +05:00
if not data.get('gzipCompression'):
2018-11-10 02:37:45 +05:00
data_ret = {'fetch_status': 1, 'error_message': "Provide Enable GZIP Compression",
'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
2025-06-15 01:10:08 +05:00
maxConn = str(data['maxConn'])
maxSSLConn = str(data['maxSSLConn'])
connTime = str(data['connTime'])
keepAlive = str(data['keepAlive'])
inMemCache = str(data['inMemCache'])
2018-11-10 02:37:45 +05:00
gzipCompression = data['gzipCompression']
2019-12-10 23:04:24 +05:00
execPath = "/usr/local/CyberCP/bin/python " + virtualHostUtilities.cyberPanel + "/plogical/tuning.py"
2018-11-10 02:37:45 +05:00
execPath = execPath + " saveTuningDetails --maxConn " + maxConn + " --maxSSLConn " + maxSSLConn + " --connTime " + connTime + " --keepAlive " + keepAlive + " --inMemCache '" + inMemCache + "' --gzipCompression " + gzipCompression
2019-03-26 16:19:03 +05:00
output = ProcessUtilities.outputExecutioner(execPath)
2018-11-10 02:37:45 +05:00
if output.find("1,None") > -1:
data_ret = {'fetch_status': 1, 'error_message': "None", 'tuneStatus': 1}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
else:
data_ret = {'fetch_status': 1, 'error_message': "None", 'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
2019-12-10 15:09:10 +05:00
except BaseException as msg:
2018-11-10 02:37:45 +05:00
data_ret = {'fetch_status': 0, 'error_message': str(msg), 'tuneStatus': 0}
json_data = json.dumps(data_ret)
return HttpResponse(json_data)
def tunePHP(self, userID, data):
try:
currentACL = ACLManager.loadedACL(userID)
if currentACL['admin'] == 1:
pass
else:
return ACLManager.loadError()
2018-11-10 02:37:45 +05:00
status = data['status']
2025-06-15 01:10:08 +05:00
domainSelection = data.get('domainSelection')
# Check if domainSelection is None or 'null' string
if domainSelection is None or domainSelection == 'null' or domainSelection == '':
data_ret = {'fetch_status': 0, 'error_message': "Please select a domain/PHP version first", 'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
domainSelection = str(domainSelection)
2018-11-10 02:37:45 +05:00
if status == "fetch":
json_data = json.dumps(tuning.fetchPHPDetails(domainSelection))
data_ret = {'fetch_status': 1, 'error_message': "None", "tuning_data": json_data,
'tuneStatus': 0}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
else:
initTimeout = str(data['initTimeout'])
maxConns = str(data['maxConns'])
memSoftLimit = data['memSoftLimit']
memHardLimit = data['memHardLimit']
procSoftLimit = str(data['procSoftLimit'])
procHardLimit = str(data['procHardLimit'])
persistConn = data['persistConn']
2019-12-10 23:04:24 +05:00
execPath = "/usr/local/CyberCP/bin/python " + virtualHostUtilities.cyberPanel + "/plogical/tuning.py"
2018-11-10 02:37:45 +05:00
execPath = execPath + " tunePHP --virtualHost " + domainSelection + " --initTimeout " + initTimeout + " --maxConns " + maxConns + " --memSoftLimit " + memSoftLimit + " --memHardLimit '" + memHardLimit + "' --procSoftLimit " + procSoftLimit + " --procHardLimit " + procHardLimit + " --persistConn " + persistConn
2019-03-26 16:19:03 +05:00
output = ProcessUtilities.outputExecutioner(execPath)
2018-11-10 02:37:45 +05:00
if output.find("1,None") > -1:
data_ret = {'tuneStatus': 1, 'fetch_status': 0, 'error_message': "None"}
final_json = json.dumps(data_ret)
return HttpResponse(final_json)
else:
data_ret = {'fetch_status': 0, 'error_message': output, 'tuneStatus': 0}
logging.CyberCPLogFileWriter.writeToFile(output + " [tunePHP]]")
json_data = json.dumps(data_ret)
return HttpResponse(json_data)
2019-12-10 15:09:10 +05:00
except BaseException as msg:
2018-11-10 02:37:45 +05:00
data_ret = {'fetch_status': 0, 'error_message': str(msg), 'tuneStatus': 0}
logging.CyberCPLogFileWriter.writeToFile(str(msg) + " [tunePHP]]")
json_data = json.dumps(data_ret)
return HttpResponse(json_data)