Linux ip-172-26-2-223 5.4.0-1018-aws #18-Ubuntu SMP Wed Jun 24 01:15:00 UTC 2020 x86_64
Apache
: 172.26.2.223 | : 18.188.181.58
Cant Read [ /etc/named.conf ]
8.1.13
www
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
BLACK DEFEND!
README
+ Create Folder
+ Create File
/
www /
server /
panel /
mod /
base /
push_mod /
[ HOME SHELL ]
Name
Size
Permission
Action
__pycache__
[ DIR ]
drwxr-xr-x
__init__.py
17.01
KB
-rw-r--r--
base_task.py
9.72
KB
-rw-r--r--
compatible.py
787
B
-rw-r--r--
database_push.py
9.24
KB
-rw-r--r--
database_push_template.json
1.55
KB
-rw-r--r--
domain_blcheck_push.py
5.62
KB
-rw-r--r--
domain_blcheck_push_template.j...
1.82
KB
-rw-r--r--
load_push.py
10.69
KB
-rw-r--r--
manager.py
17.54
KB
-rw-r--r--
mods.py
12.87
KB
-rw-r--r--
rsync_push.py
10.03
KB
-rw-r--r--
send_tool.py
3.29
KB
-rw-r--r--
site_push.py
55.03
KB
-rw-r--r--
site_push_template.json
7.78
KB
-rw-r--r--
ssl_push.py
13.28
KB
-rw-r--r--
ssl_push_template.json
2.27
KB
-rw-r--r--
system.py
17.35
KB
-rw-r--r--
system_push.py
15.3
KB
-rw-r--r--
system_push_template.json
5.5
KB
-rw-r--r--
task_manager_push.py
17.17
KB
-rw-r--r--
tool.py
2.24
KB
-rw-r--r--
util.py
3.31
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : manager.py
import json import os import time from typing import Union, Optional from .mods import TaskTemplateConfig, TaskConfig, SenderConfig, TaskRecordConfig from .system import PushSystem from mod.base import json_response import sys sys.path.insert(0, "/www/server/panel/class/") import public class PushManager: def __init__(self): self.template_conf = TaskTemplateConfig() self.task_conf = TaskConfig() self.send_config = SenderConfig() self._send_conf_cache = {} def _get_sender_conf(self, sender_id): if sender_id in self._send_conf_cache: return self._send_conf_cache[sender_id] tmp = self.send_config.get_by_id(sender_id) self._send_conf_cache[sender_id] = tmp return tmp def normalize_task_config(self, task, template) -> Union[dict, str]: result = {} sender = task.get("sender", None) if sender is None: return "No alarm channel is configured" if not isinstance(sender, list): return "The alarm channel is incorrect" new_sender = [] for i in sender: sender_conf = self._get_sender_conf(i) if not sender_conf: continue else: new_sender.append(i) if sender_conf["sender_type"] not in template["send_type_list"]: if sender_conf["sender_type"] == "sms": return "SMS alerts are not supported" return "Unsupported alerting methods:{}".format(sender_conf['data']["title"]) if not sender_conf["used"]: if sender_conf["sender_type"] == "sms": return "The SMS alert channel has been closed" return "Closed alert mode:{}".format(sender_conf['data']["title"]) result["sender"] = new_sender if "default" in template and template["default"]: task_data = task.get("task_data", {}) for k, v in template["default"].items(): if k not in task_data: task_data[k] = v result["task_data"] = task_data if "task_data" not in result: result["task_data"] = {} time_rule = task.get("time_rule", {}) if "send_interval" in time_rule: if not isinstance(time_rule["send_interval"], int): return "The minimum interval is set incorrectly" if time_rule["send_interval"] < 0: return "The minimum interval is set incorrectly" if "time_range" in time_rule: if not isinstance(time_rule["time_range"], list): return "The time range is set incorrectly" if not len(time_rule["time_range"]) == 2: del time_rule["time_range"] else: time_range = time_rule["time_range"] if not (isinstance(time_range[0], int) and isinstance(time_range[1], int) and 0 <= time_range[0] < time_range[1] <= 60 * 60 * 24): return "The time range is set incorrectly" result["time_rule"] = time_rule number_rule = task.get("number_rule", {}) if "day_num" in number_rule: if not (isinstance(number_rule["day_num"], int) and number_rule["day_num"] >= 0): return "The minimum number of times per day is set incorrectly" if "total" in number_rule: if not (isinstance(number_rule["total"], int) and number_rule["total"] >= 0): return "The maximum number of alarms is set incorrectly" result["number_rule"] = number_rule if "status" not in task: result["status"] = True if "status" in task: if isinstance(task["status"], bool): result["status"] = task["status"] return result def set_task_conf_data(self, push_data: dict) -> Optional[str]: task_id = push_data.get("task_id", None) template_id = push_data.get("template_id") task = push_data.get("task_data") target_task_conf = None if task_id is not None: tmp = self.task_conf.get_by_id(task_id) if tmp is None: target_task_conf = tmp template = self.template_conf.get_by_id(template_id) if not template: return "No alarm template was found" if template["unique"] and not target_task_conf: for i in self.task_conf.config: if i["template_id"] == template["id"]: target_task_conf = i break task_obj = PushSystem().get_task_object(template_id, template["load_cls"]) if not task_obj: return "Loading task type error, you can try to fix the panel" # {'id': '4', 'ver': '1', 'used': True, 'source': 'ssh_login_error', 'title': 'SSH login failure alarm', # 'load_cls': {'load_type': 'path', 'cls_path': 'mod.base.push_mod.site_push', 'name': 'SSHLoginErrorTask'}, # 'template': {'field': [{'attr': 'cycle', 'name': 'Trigger conditions', 'type': 'number', 'unit': 'minute(s)', # 'suffix': 'less than ', 'default': 30}, # {'attr': 'count', 'name': 'Login failed', 'type': 'number', 'unit': 'time(s)', # 'suffix': '', 'default': 3}, # {'attr': 'interval', 'name': 'Interval', 'type': 'number', 'unit': 'second(s)', # 'suffix': 'more than ', 'default': 600}], # 'sorted': [['cycle', 'count'], ['interval']]}, # 'default': {'cycle': 30, 'count': 3, 'interval': 600}, # 'advanced_default': {'number_rule': {'day_num': 3}, 'time_rule': {'send_interval': 600}}, # 'send_type_list': ['wx_account', 'dingding', 'feishu', 'mail', 'weixin', 'webhook'], 'unique': True} res = self.normalize_task_config(task, template) if isinstance(res, str): return res task_data = task_obj.check_task_data(res["task_data"]) if isinstance(task_data, str): return task_data number_rule = task_obj.check_num_rule(res["number_rule"]) if isinstance(number_rule, str): return number_rule time_rule = task_obj.check_time_rule(res["time_rule"]) if isinstance(time_rule, str): return time_rule res["task_data"] = task_data res["number_rule"] = number_rule res["time_rule"] = time_rule res["keyword"] = task_obj.get_keyword(task_data) res["source"] = task_obj.source_name res["title"] = task_obj.get_title(task_data) if not target_task_conf: tmp = self.task_conf.get_by_keyword(res["source"], res["keyword"]) if tmp: target_task_conf = tmp if not target_task_conf: res["id"] = self.task_conf.nwe_id() res["template_id"] = template_id res["status"] = True res["pre_hook"] = {} res["after_hook"] = {} res["last_check"] = 0 res["last_send"] = 0 res["number_data"] = {} res["create_time"] = time.time() res["record_time"] = 0 self.task_conf.config.append(res) task_obj.task_config_create_hook(res) else: target_task_conf.update(res) target_task_conf["last_check"] = 0 target_task_conf["number_data"] = {} # 次数控制数据置空 task_obj.task_config_update_hook(target_task_conf) self.task_conf.save_config() return None def update_task_status(self, get): # 先调用 set_task_conf 修改任务配置 set_conf_response = self.set_task_conf(get) if set_conf_response['status'] != 0: return set_conf_response # 返回错误信息 # 读取任务数据 file_path = '{}/data/mod_push_data/task.json'.format(public.get_panel_path()) try: with open(file_path, 'r') as file: tasks = json.load(file) except (IOError, json.JSONDecodeError): return json_response(status=False, msg=public.lang("Unable to read task data.")) # 查找对应的 task_id task_title = get.title.strip() # 假设 get 中有 title 参数 task_id = None for task in tasks: if task.get('title') == task_title: task_id = task.get('id') break if not task_id: return json_response(status=False, msg=public.lang("The task has not been found.")) # 调用 change_task_conf 修改任务状态 get.task_id = task_id return self.change_task_conf(get) def set_task_conf(self, get): task_id = None try: if hasattr(get, "task_id"): task_id = get.task_id.strip() if not task_id: task_id = None else: self.remove_task_conf(get) template_id = get.template_id.strip() task = json.loads(get.task_data.strip()) except (AttributeError, json.JSONDecodeError, TypeError, ValueError): return json_response(status=False, msg="The parameter is incorrect") push_data = { "task_id": task_id, "template_id": template_id, "task_data": task, } res = self.set_task_conf_data(push_data) if res: return json_response(status=False, msg=res) # target_task_conf = None # if task_id is not None: # tmp = self.task_conf.get_by_id(task_id) # if tmp is None: # target_task_conf = tmp # # template = self.template_conf.get_by_id(template_id) # if not template: # return json_response(status=False, msg="为查询到告警模板") # # if template["unique"] and not target_task_conf: # for i in self.task_conf.config: # if i["template_id"] == template["id"]: # target_task_conf = i # break # # task_obj = PushSystem().get_task_object(template_id, template["load_cls"]) # if not task_obj: # return json_response(status=False, msg="加载任务类型错误,您可以尝试修复面板") # # res = self.normalize_task_config(task, template) # if isinstance(res, str): # return json_response(status=True, msg=res) # # task_data = task_obj.check_task_data(res["task_data"]) # if isinstance(task_data, str): # return json_response(status=True, msg=task_data) # # number_rule = task_obj.check_num_rule(res["number_rule"]) # if isinstance(number_rule, str): # return json_response(status=True, msg=number_rule) # # time_rule = task_obj.check_time_rule(res["time_rule"]) # if isinstance(time_rule, str): # return json_response(status=True, msg=time_rule) # # res["task_data"] = task_data # res["number_rule"] = number_rule # res["time_rule"] = time_rule # # res["keyword"] = task_obj.get_keyword(task_data) # res["source"] = task_obj.source_name # res["title"] = task_obj.get_title(task_data) # # if not target_task_conf: # tmp = self.task_conf.get_by_keyword(res["source"], res["keyword"]) # if tmp: # target_task_conf = tmp # # if not target_task_conf: # res["id"] = self.task_conf.nwe_id() # res["template_id"] = template_id # res["status"] = True # res["pre_hook"] = {} # res["after_hook"] = {} # res["last_check"] = 0 # res["last_send"] = 0 # res["number_data"] = {} # res["create_time"] = time.time() # res["record_time"] = 0 # self.task_conf.config.append(res) # task_obj.task_config_create_hook(res) # else: # target_task_conf.update(res) # target_task_conf["last_check"] = 0 # target_task_conf["number_data"] = {} # 次数控制数据置空 # task_obj.task_config_update_hook(target_task_conf) # # self.task_conf.save_config() return json_response(status=True, msg="The alarm task is saved successfully") def change_task_conf(self, get): try: task_id = get.task_id.strip() status = int(get.status) # 获取status字段并转换为整数 except (AttributeError, ValueError): return json_response(status=False, msg="Parameter error") if status not in [0, 1]: return json_response(status=False, msg="Invalid status value") tmp = self.task_conf.get_by_id(task_id) if tmp is None: return json_response(status=True, msg="No alarm task was queried") tmp["status"] = bool(status) # 将status转换为布尔值并设置 self.task_conf.save_config() return json_response(status=True, msg="operate successfully") def update_ssl_task(self, get): import sys sys.path.insert(0, "/www/server/panel/class/") import public """ 根据前端发送的参数,修改对应任务的配置 :param file_path: JSON文件的路径 :param task_id: 需要修改的任务ID :param update_data: 前端发送的更新数据 :return: 修改结果 """ def load_task_data(): try: file_path = f'{public.get_panel_path()}/data/mod_push_data/task.json' return json.loads(public.readFile(file_path)) except: return [] def save_task_data(data): file_path = f'{public.get_panel_path()}/data/mod_push_data/task.json' with open(file_path, 'w') as file: json.dump(data, file, indent=4) def find_task(data, project): for task in data: if task.get('source') == 'site_ssl' and task.get('task_data', {}).get('project') == project: return task return None try: task_id = get.task_id update_data = json.loads(get.task_data) if not update_data.get('sender'): return {'status': False, 'msg': 'Set the alert notification method!'} status = int(get.status) project = update_data['task_data']['project'] data = load_task_data() if not task_id: return self.set_task_conf(get) task = find_task(data, project) if task: get.task_id = task['id'] else: get.task_id = "" self.set_task_conf(get) if status == 0: task_found = False for task in data: if task.get('source') == 'site_ssl' and task.get('task_data', {}).get('project') == project: task['status'] = False task_found = True if not task_found: get.task_id = "" self.set_task_conf(get) data = load_task_data() for task in data: if task.get('source') == 'site_ssl' and task.get('keyword') == project: task['status'] = False break save_task_data(data) return {'status': True, 'msg': 'operate successfully'} except Exception as e: return {'status': False, 'msg': str(e)} def change_task(self,task_id,status): tmp = self.task_conf.get_by_id(task_id) tmp["status"] = bool(status) # 将status转换为布尔值并设置 self.task_conf.save_config() def change_ssl_task(self, get): # result = public.M('sites').select() try: task_id = get.task_id.strip() status = int(get.status) # 获取status字段并转换为整数 except (AttributeError, ValueError): return json_response(status=False, msg="Parameter error") if status not in [0, 1]: return json_response(status=False, msg="Invalid status value") project=get.project try: data = json.loads(public.readFile('{}/data/mod_push_data/task.json'.format(public.get_panel_path()))) except: return {'status': False, 'msg': 'file does not exist'} self.process_tasks(data, status, project, task_id, get) return json_response(status=True, msg="operate successfully") def remove_task_conf(self, get): try: task_id = get.task_id.strip() except AttributeError: return json_response(status=False, msg="The parameter is incorrect") tmp = self.task_conf.get_by_id(task_id) if tmp is None: return json_response(status=True, msg="No alarm task was queried") self.task_conf.config.remove(tmp) self.task_conf.save_config() template = self.template_conf.get_by_id(tmp["template_id"]) if template: task_obj = PushSystem().get_task_object(template["id"], template["load_cls"]) if task_obj: task_obj.task_config_remove_hook(tmp) return json_response(status=True, msg="operate successfully") @staticmethod def clear_task_record_by_task_id(task_id): tr_conf = TaskRecordConfig(task_id) if os.path.exists(tr_conf.config_file_path): os.remove(tr_conf.config_file_path)
Close