diff --git a/Image/1.png b/Image/1.png
index ed06c91..a276525 100644
Binary files a/Image/1.png and b/Image/1.png differ
diff --git a/README.md b/README.md
deleted file mode 100644
index 4979e77..0000000
--- a/README.md
+++ /dev/null
@@ -1,179 +0,0 @@
-
-
-# RmEye
-RmEye是一个window上的基于att&ck现代EDR设计思想的威胁响应工具.
-不同于EDR,它轻量、高效.自身定位是轻量级威胁检出工具.
-而不是繁重的、需要付费的、效果不明的所谓的EDR
-RmEye基于att&ck模型,如果您对att&ck模型不熟悉,请先阅读相关文章后再使用:
-https://key08.com/index.php/2022/08/09/1505.html
-
-### 功能特点
-1. 基于att&ck设计.所有设计只是为了符合att&ck的攻击路径、攻击链(虽然规则里面没有标注T因为懒惰)
-2. 轻量、高效.为了不适用繁重超占内存的ELK设计思路,而且要保证检出的同时保证不会太重,agent端使用了大量规则过滤,这样才使得后端使用sqlite作为数据库成为可能.单机日志平均一天4M.此外轻量级别的客户端一天只占40-400KB的内存.
-3. 行为检出,让免杀成为过去式.基于att&ck设计,只看行为不看文件.文件类免杀已经成为过去式.
-4. 高扩展性.可随需求定制功能
-
-### RmEye 之所以不是 Edr/Xdr/Mdr/Ndr/XXXXXdr
-1. RmEye没有流量监控
-2. RmEye仅覆盖20%左右的datasource
-3. RmEye没有联动WAF、IPS/IDS
-4. RmEye没有实时拦截功能
-5. 对RPC、COM、ALPC基本无能为力
-6. 不支持更高级的扩展检测,如检测脚本、下发规则,主机链
-7. 受限于Sysmon,很多att&ck的T没有覆盖,也无法覆盖.
-8. 没有响应能力,只能被动记录.
-请牢记,RmEye自身定位是轻量级威胁检出工具
-
-### 最新新闻
-2022/9/8:
-增加服务端规则指南: \
-[doc_server_rule_manual.md](./doc_server_rule_manual.md)
-
-2022/9/5:
-增加规则编写教程:
-https://github.com/RoomaSec/RmEye/blob/main/doc_day0_rule.md
-增加`mimikatz`检测
-
-2022/8/31:
-增加进程白名单系统,现在能给进程加白名单了.在打开进程链后,点击某个进程加入白名单即可
-
-2022/8/29:
-增加uac提权检测插件`uac_bypass_detect`,但是受限于sysmon,没有办法获取RPC信息,因此只能检测一部分的UAC提权行为.并且有误报,请酌情考虑
-
-### 检出截图
-威胁列表:
-
-进程链行为回溯
-
-powershell恶意执行:
-
-apt样本:
-
-勒索软件:
-
-网站入侵提权到执行cobalt strike:
-
-offic宏钓鱼:
-
-uac提权检测:
-
-mimikatz检测:
-
-
-### 待做列表
-1. 更好的前端(目前是VUE-CDN模式,不太好,想换成VUE-CLI) 已经完成
-2. 日志回放【目前重点】
-3. 威胁狩猎【目前重点】
-4. att&ck热力图
-5. 在线规则编辑器
-6. 内网横向检测
-7. iis、apache、nginx日志搜集分析(aka: XDR的实现)
-8. 集成反病毒引擎
-9. 完善目前的插件系统【目前重点】
-10. 云日志检测能力【目前重点】
-### 安装
-下载release( https://github.com/RoomaSec/RmEye/releases ),里面有客户端,服务端自行clone本项目
-服务端是python3编写,安装完依赖库后输入
-```
-python webserver.py
-```
-即可部署
-服务端部署后,修改config.py里面的
-```
-# 检出阈值,越高越难检出但是也会越准确
-MAX_THREAT_SCORE = 170
-
-# 授权访问主站的IP列表.如果不在后台里面则不能访问后台
-ALLOW_ACCESS_IP = ['127.0.0.1']
-```
-MAX_THREAT_SCORE代表报警分数,意思为进程链总分超过此分数则报警,越高越准但是也会漏报
-ALLOW_ACCESS_IP代表允许的IP,只有在此名单里面的IP才能访问后台.请增加自己的IP地址
-
-客户端则编辑config.ini
-```
-[communication]
-server = http://192.168.111.189:5000
-```
-其中server改成你的服务端的地址
-然后分发三个文件给客户端并且放在同一目录:
-config.ini、install.cmd、RmEye.exe、sysmon.xml、Sysmon64.exe
-之后管理员身份运行install.cmd安装sysmon与RmEye
-访问 http://服务器ip:5000(flask默认端口) 查看后台
-当然一开始啥数据也没有,为了确认是否安装成功可以将webserver.py中的
-```
- flask_log = logging.getLogger('werkzeug')
- flask_log.setLevel(logging.ERROR)
-```
-注释掉,检查有没有客户端的请求即可
-手动安装(cmd脚本其实执行了这些命令):
-```
-//安装sysmon:
-sysmon -i
-//sysmon加载配置项
-sysmon -c sysmon.xml
-//安装RmEye
-RmEye /install
-```
-
-### 卸载
-卸载RmEye:
-在RmEye目录下执行
-```
-SysEye /uninstall
-```
-如果您需要卸载sysmon
-执行
-```
-sysmon /uninstall
-```
-即可干净卫生的卸载掉RmEye
-
-### 规则相关的问题
-1. 规则目前仅120条,很多攻击面没有覆盖,其他规则请访问《社区》
-2. 规则目前只支持rule_engine与yara的规则,其中yara的规则支持是以插件的形式支持
-3. 目前的规则字段完全依赖sysmon的字段,sysmon的字段请检查根目录下的provider.json(但是请记住纯小写,自行做大小写转换)
-
-规则目前在`Server/rules`目录规则目前有两种规则:
-rule_engine:
-如检测由CMD启动的ipconfig:
-```
-{
- 'rules': [
- 'originalfilename =~ ".*cmd.exe" and commandline =~ ".*ipconfig.*"',
- ],
- 'score': 80,
- 'name': 'cmd启动ipconfig'
-},
-```
-分数代表的是本次规则给进程链所增加的分数,报警是根据前面的MAX_THREAT_SCORE设置的
-
-规则编写教程请移步:
-https://github.com/RoomaSec/RmEye/blob/main/doc_day0_rule.md
-
-规则引擎的语法请移步:
-https://github.com/zeroSteiner/rule-engine
-
-yara,需要安装插件,具体请看交流部分
-
-### 第三方引用库
-1. sysmon
-https://docs.microsoft.com/zh-cn/sysinternals/downloads/sysmon
-2. rule_engine
-https://github.com/zeroSteiner/rule-engine
-3. yara
-https://github.com/VirusTotal/yara
-4. sysmon-config(客户端使用的默认的规则,但是我做了一些修改)
-https://github.com/SwiftOnSecurity/sysmon-config
-请遵守相关库的开源协议.相关法律风险本项目不负任何责任
-
-### 交流
-开源的目的不是为了免费填鸭式教学,或者被免费拿去发公众号引流、去拿去集成产品方案去赚钱,而是要一起完善这个工具,从而实现共赢.
-扫一扫加入这个工具的交流群,这样就能获取实时动态.参与开发、参与交流规则编写等等.欢迎加入
-最近进群的人有点多,所以不活跃的哥们暂时清理掉,但是微信太不好使了.要是t错了或者还想在群待着不发言的重新加群吧
-
-
-### 特别感谢
-@Pwn0x01 yara插件
-@zeroSteiner 规则引擎插件
-@SwiftOnSecurity 客户端规则
-@Fplyth0ner-Combie 规则相关文档
diff --git a/Server/config.py b/Server/config.py
index 5efcb30..c5bde2b 100644
--- a/Server/config.py
+++ b/Server/config.py
@@ -1,4 +1,4 @@
# 检出阈值,越高越难检出但是也会越准确
-MAX_THREAT_SCORE = 170
+MAX_THREAT_SCORE = 45
# 授权访问主站的IP列表.如果不在后台里面则不能访问后台
ALLOW_ACCESS_IP = ['127.0.0.1', '192.168.111.189', '192.168.111.187']
diff --git a/Server/log.py b/Server/log.py
index 19138a5..8bb4e33 100644
--- a/Server/log.py
+++ b/Server/log.py
@@ -1,6 +1,5 @@
import json
import time
-import operator
import process
import rule
@@ -10,6 +9,66 @@ import config
import plugin
import hash_white_list
+LOG_TYPE_PROCESS_CREATE = 1
+LOG_TYPE_PROCESS_ACTION = 2
+
+
+def update_att_ck(process: process.Process, score, hit_name, attck_t_list):
+ if process.is_white or process.chain.root_process.is_white or process.parent_process.is_white:
+ score = 0
+ for t in attck_t_list:
+ process.set_attck(score, t, hit_name)
+ # 更新命中的规则
+ return global_vars.THREAT_TYPE_PROCESS
+
+
+def update_threat(process: process.Process, score, rule_hit_name):
+ had_threat = global_vars.THREAT_TYPE_NONE
+ if process.is_white or process.chain.root_process.is_white or process.parent_process.is_white:
+ return had_threat
+ if score > 0:
+ # 更新命中的规则
+ process.set_score(score, rule_hit_name)
+ had_threat = global_vars.THREAT_TYPE_PROCESS
+ return had_threat
+
+
+def match_threat(process: process.Process, log, log_type):
+ had_threat = global_vars.THREAT_TYPE_NONE
+ success_match = False
+ hit_name = ''
+ hit_score = 0
+ is_ioa = False
+ if log_type == LOG_TYPE_PROCESS_CREATE:
+ success_match, is_ioa, attck_t_list, hit_score, rule_hit_name = rule.calc_score_in_create_process(
+ log)
+ elif log_type == LOG_TYPE_PROCESS_ACTION:
+ success_match, is_ioa, attck_t_list, hit_score, rule_hit_name = rule.calc_score_in_action(
+ log)
+ if success_match == False:
+ return had_threat, is_ioa, hit_name, hit_score
+ # 匹配到了首先更新att&ck的t
+ had_threat = update_att_ck(
+ process, hit_score, rule_hit_name, attck_t_list)
+ hit_name = rule_hit_name
+ if is_ioa:
+ had_threat = update_threat(
+ process, hit_score, rule_hit_name)
+ else:
+ is_match_software, software_name, software_score = rule.match_att_ck_software(
+ process.chain.attck_hit_list)
+ if is_match_software:
+ # 匹配到software了,设置为ioa
+ had_threat = update_threat(
+ process, software_score, software_name)
+ hit_name = software_name
+ hit_score = software_score
+ #print('match_threat', had_threat, is_ioa, hit_name, hit_score)
+ # if had_threat != global_vars.THREAT_TYPE_NONE:
+ # print('path: {} hit_name: {} socre: {}'.format(
+ # process.path, hit_name, hit_score))
+ return had_threat, is_ioa, hit_name, hit_score
+
def process_log(host, json_log, raw_log):
log = json_log["data"]
@@ -20,6 +79,7 @@ def process_log(host, json_log, raw_log):
chain_hash = ""
params = ""
user = ""
+ is_ioa = False
if json_log["action"] == "processcreate":
pid = log["processid"]
@@ -39,7 +99,7 @@ def process_log(host, json_log, raw_log):
if path in process.skip_process_path or path in process.skip_process_path:
return
parent_process: process.Process = process.get_process_by_pid(ppid)
- score, rule_hit_name = rule.calc_score_in_create_process(log)
+
if hash in process.skip_md5:
return
if parent_process is None or parent_path in process.root_process_path:
@@ -63,9 +123,9 @@ def process_log(host, json_log, raw_log):
chain = process.create_chain(parent_process)
chain.add_process(child, parent_pid)
current_process = child
- if score > 0:
- child.set_score(score, rule_hit_name)
- had_threat = global_vars.THREAT_TYPE_PROCESS
+
+ had_threat, is_ioa, rule_hit_name, score = match_threat(
+ current_process, log, LOG_TYPE_PROCESS_CREATE)
else:
is_white_list = hash in hash_white_list.g_white_list
child = process.Process(
@@ -74,9 +134,9 @@ def process_log(host, json_log, raw_log):
child.parent_process = parent_process
parent_process.chain.add_process(child, ppid)
current_process = child
- if score > 0:
- child.set_score(score, rule_hit_name)
- had_threat = global_vars.THREAT_TYPE_PROCESS
+
+ had_threat, is_ioa, rule_hit_name, score = match_threat(
+ current_process, log, LOG_TYPE_PROCESS_CREATE)
had_threat_plugin = plugin.dispath_rule_new_process_create(
host, current_process, raw_log, json_log
@@ -100,6 +160,7 @@ def process_log(host, json_log, raw_log):
host,
current_process.chain.risk_score,
json.dumps(current_process.chain.operationlist),
+ json.dumps(current_process.chain.attck_hit_list),
current_process.chain.hash,
current_process.chain.get_json(),
global_vars.THREAT_TYPE_PROCESS,
@@ -110,10 +171,8 @@ def process_log(host, json_log, raw_log):
current_process = process.get_process_by_pid(log["processid"])
if current_process is not None:
log["action"] = json_log["action"]
- score, rule_hit_name = rule.calc_score_in_action(log)
- if score > 0:
- current_process.set_score(score, rule_hit_name)
- had_threat = global_vars.THREAT_TYPE_PROCESS
+ had_threat, is_ioa, rule_hit_name, score = match_threat(
+ current_process, log, LOG_TYPE_PROCESS_ACTION)
had_threat_plugin = plugin.dispath_rule_new_process_action(
host, current_process, raw_log, json_log
)
@@ -145,6 +204,7 @@ def process_log(host, json_log, raw_log):
host,
current_process.chain.risk_score,
json.dumps(current_process.chain.operationlist),
+ json.dumps(current_process.chain.attck_hit_list),
current_process.chain.hash,
current_process.chain.get_json(),
global_vars.THREAT_TYPE_PROCESS,
@@ -155,6 +215,7 @@ def process_log(host, json_log, raw_log):
host,
current_process.chain.risk_score,
json.dumps(current_process.chain.operationlist),
+ json.dumps(current_process.chain.attck_hit_list),
current_process.chain.hash,
current_process.chain.get_json(),
global_vars.THREAT_TYPE_PROCESS,
@@ -179,29 +240,34 @@ def process_log(host, json_log, raw_log):
target_hash = target_process.md5
self_hash = current_process.md5
# 以后有其他排除需求再优化
- if json_log['action'] == 'imageload' and json_log['data']['imageloaded'] not in hash_white_list.g_white_dll_load_list:
- sql.push_process_raw(
- host,
- raw_json_log,
- rule_hit_name,
- score,
- chain_hash,
- had_threat,
- parent_pid,
- target_pid,
- self_hash,
- target_image_path,
- target_hash,
- params,
- user,
- )
+ if json_log['action'] == 'imageload' and (json_log['data']['imageloaded'][len(json_log['data']['imageloaded']) - 4:] == '.exe' or json_log['data']['imageloaded'] in hash_white_list.g_white_dll_load_list):
+ return
- """
+ if json_log['action'] == 'imageload':
+ print(json_log['data']['imageloaded'])
+ return
+
+ sql.push_process_raw(
+ host,
+ raw_json_log,
+ rule_hit_name,
+ score,
+ chain_hash,
+ had_threat,
+ parent_pid,
+ target_pid,
+ self_hash,
+ target_image_path,
+ target_hash,
+ params,
+ user,
+ )
+ '''
for iter in process.g_ProcessChainList:
item: process.Process = iter
if item.risk_score >= config.MAX_THREAT_SCORE:
item.print_process()
- """
+ '''
def process_raw_log(raw_logs: list) -> list:
diff --git a/Server/plugins/mimikazt_detect/mimikatz_detect.py b/Server/plugins/mimikazt_detect/mimikatz_detect.py
index 9dde0ad..077f7b7 100644
--- a/Server/plugins/mimikazt_detect/mimikatz_detect.py
+++ b/Server/plugins/mimikazt_detect/mimikatz_detect.py
@@ -34,7 +34,7 @@ mimikatz_dll_list = [
def rule_new_process_create(current_process: process.Process, host, raw_log_data, json_log_data):
# 服务端提供了一个 plugin_var 变量用于存放当前进程插件的上下文
- if current_process.path != 'c:\\windows\\system32\\wbem\\wmic.exe' and current_process.parent_process.path != 'c:\\windows\\system32\\svchost.exe':
+ if current_process.path != 'c:\\windows\\system32\\wbem\\wmic.exe' and current_process.parent_process.path != 'c:\\windows\\system32\\svchost.exe' and current_process.path != 'c:\\windows\\system32\\svchost.exe':
current_process.plugin_var['mimikatz_matched_num'] = 0
current_process.plugin_var['mimikatz_detected'] = False
return global_vars.THREAT_TYPE_NONE
diff --git a/Server/process.py b/Server/process.py
index 28023b7..0fe81d7 100644
--- a/Server/process.py
+++ b/Server/process.py
@@ -94,6 +94,8 @@ class Process:
self.chain_hash = ''
self.active = True
self.operationlist = {}
+ self.attck_hit_list = {}
+
self.risk_score = 0
self.terminate = False
self.rmpid = tools.get_md5(
@@ -120,9 +122,16 @@ class Process:
def set_rmppid(self, rmppid):
self.rmppid = rmppid
+ def set_attck(self, new_score, t, name):
+ if t not in self.attck_hit_list:
+ self.risk_score += new_score
+ self.attck_hit_list[t] = name
+
+ if t not in self.chain.attck_hit_list:
+ self.chain.risk_score += new_score
+ self.chain.attck_hit_list[t] = name
+
def set_score(self, new_score, opertion):
- if self.is_white or self.chain.root_process.is_white or self.parent_process.is_white:
- return
if opertion not in self.operationlist:
self.risk_score += new_score
self.operationlist[opertion] = 1
@@ -146,6 +155,7 @@ class ProcessChain:
self.terminate_count = 0
self.risk_score = 0
self.operationlist = {}
+ self.attck_hit_list = {}
self.process_list = []
self.json_arrays = []
self.active = True
@@ -234,6 +244,7 @@ class ProcessChain:
"rmppid": proc_info.rmppid,
"params": proc_info.params,
"operationlist": proc_info.operationlist,
+ "attck_hit_list": proc_info.attck_hit_list,
"md5": proc_info.md5,
"active": proc_info.active,
"children": []
diff --git a/Server/rule.py b/Server/rule.py
index 35125e6..3eacace 100644
--- a/Server/rule.py
+++ b/Server/rule.py
@@ -1,82 +1,132 @@
import rule_engine
-import rules.py.process as rule_process
-import rules.py.action as rule_action
+import rules.py.attck.process as attck_process
+import rules.py.attck.attck as attack_software
+import rules.py.attck.action as attack_action
+import rules.py.ioa.action as ioa_action
+import rules.py.ioa.process as ioa_process
+
import plugin
g_sample_rule = {}
-g_sample_rule['process'] = rule_process.rule
-g_sample_rule['action'] = rule_action.rule
+g_sample_rule['attack_process'] = attck_process.rule
+g_sample_rule['attack_action'] = attack_action.rule
+g_sample_rule['attack_software'] = attack_software.rule
+g_sample_rule['ioa_action'] = ioa_action.rule
+g_sample_rule['ioa_process'] = ioa_process.rule
+attck_process_rules = []
+attck_action_rules = []
+ioa_process_rules = []
+ioa_action_rules = []
-base_process_rules = []
-base_action_rules = []
base_host_rules = []
-def calc_score_in_action(log):
- global base_action_rules
- for iter in base_action_rules:
- for rule in iter['rules']:
- # 这是or
- try:
- if rule.matches(log):
- return iter['score'], iter['name']
- except:
- print("error: {} ".format(log))
+def match_att_ck_software(t_list):
+ # 返回是否命中,命中命中,分数
- return 0, ''
+ global g_sample_rule
+ is_match = False
+ match_name = ''
+ match_score = 0
+ for iter in g_sample_rule['attack_software']:
+ rule_list = iter['rules']
+ min_match_num = iter['hit_num']
+
+ match_num = 0
+
+ for t in t_list.keys():
+ if t in rule_list:
+ match_num += 1
+ if match_num >= min_match_num:
+ is_match = True
+ match_name = iter['name']
+ match_score = iter['score']
+ break
+ if is_match:
+ break
+ return is_match, match_name, match_score
+
+
+def calc_score_in_action(log):
+ # 返回 是否匹配到,是否ioa,attck,分数,名字
+
+ global attck_action_rules
+ global ioa_action_rules
+ for iter in ioa_action_rules:
+ for rule in iter['rules']:
+ if rule.matches(log):
+ return True, True, iter['attck_hit'], iter['score'], iter['name']
+ for iter in attck_action_rules:
+ for rule in iter['rules']:
+ if rule.matches(log):
+ return True, False, iter['attck_hit'], iter['score'], iter['name']
+ return False, False, [], 0, ''
def calc_score_in_create_process(log):
- global base_process_rules
- for iter in base_process_rules:
+ # 返回 是否匹配到,是否ioa,attck,分数,名字
+ global ioa_process_rules
+ global attck_process_rules
+ for iter in ioa_process_rules:
for rule in iter['rules']:
- # 这是or
if rule.matches(log):
- return iter['score'], iter['name']
- return 0, ''
-
-
-def calc_score_in_host(log):
- global base_host_rules
- for iter in base_host_rules:
+ return True, True, iter['attck_hit'], iter['score'], iter['name']
+ for iter in attck_process_rules:
for rule in iter['rules']:
- # 这是or
if rule.matches(log):
- return iter['score'], iter['name']
- return 0, ''
+ return True, False, iter['attck_hit'], iter['score'], iter['name']
+ return False, False, [], 0, ''
def init_rule():
- global base_process_rules
- global base_action_rules
- global base_host_rules
- for iter in g_sample_rule['process']:
+ global attck_process_rules
+ global attck_action_rules
+ global ioa_process_rules
+ global ioa_action_rules
+ for iter in g_sample_rule['attack_process']:
temp_process_rules = []
+ score = 0
+ if 'score' not in iter:
+ score = 5
+ else:
+ score = iter['score']
for iter_i in iter['rules']:
- print(iter_i)
+ print('rule: {} score: {}'.format(iter_i, score))
temp_process_rules.append(rule_engine.Rule(
iter_i
))
- base_process_rules.append(
- {'name': iter['name'], 'score': iter['score'], 'rules': temp_process_rules})
- for iter in g_sample_rule['action']:
+ attck_process_rules.append(
+ {'name': iter['name'], 'attck_hit': iter['attck_hit'], 'score': score, 'rules': temp_process_rules})
+ for iter in g_sample_rule['attack_action']:
temp_process_rules = []
+ score = 0
+ if 'score' not in iter:
+ score = 5
+ else:
+ score = iter['score']
for iter_i in iter['rules']:
- print(iter_i)
+ print('rule: {} score: {}'.format(iter_i, score))
temp_process_rules.append(rule_engine.Rule(
iter_i
))
- base_action_rules.append(
- {'name': iter['name'], 'score': iter['score'], 'rules': temp_process_rules})
- '''
- for iter in g_sample_rule['host']:
+ attck_action_rules.append(
+ {'name': iter['name'], 'attck_hit': iter['attck_hit'], 'score': score, 'rules': temp_process_rules})
+ for iter in g_sample_rule['ioa_action']:
temp_process_rules = []
for iter_i in iter['rules']:
- print(iter_i)
+ print('rule: {} score: {}'.format(iter_i, score))
temp_process_rules.append(rule_engine.Rule(
iter_i
))
- base_host_rules.append(
- {'name': iter['name'], 'score': iter['score'], 'rules': temp_process_rules})
- '''
+ ioa_action_rules.append(
+ {'name': iter['name'], 'attck_hit': iter['attck_hit'], 'score': iter['score'], 'rules': temp_process_rules})
+ for iter in g_sample_rule['ioa_process']:
+ temp_process_rules = []
+ for iter_i in iter['rules']:
+ print('rule: {} score: {}'.format(iter_i, score))
+ temp_process_rules.append(rule_engine.Rule(
+ iter_i
+ ))
+ ioa_process_rules.append(
+ {'name': iter['name'], 'attck_hit': iter['attck_hit'], 'score': iter['score'], 'rules': temp_process_rules})
plugin.dispath_rule_init()
print('init rule done')
diff --git a/Server/rules/py/action.py b/Server/rules/py/action.py
deleted file mode 100644
index e534db6..0000000
--- a/Server/rules/py/action.py
+++ /dev/null
@@ -1,172 +0,0 @@
-rule = [
- {
- 'rules': [
- 'action == "processaccess" and targetimage =~ ".*lsass.exe" and grantedaccess & 0x0010 and sourceimage =~ ".*rundll32.exe"',
- ],
- 'score': 300,
- 'name': '已知内存加载mimikazt行为'
- },
- {
- 'rules': [
- 'action == "processaccess" and targetimage =~ ".*lsass.exe"',
- ],
- 'score': 60,
- 'name': 'LSASS高权限访问'
- },
- {
- 'rules': [
- 'action == "processaccess" and calltrace =~ ".*unknown.*" and not calltrace =~ ".*conpty\.node.*" and not calltrace =~ ".*java\.dll.*" and not calltrace =~ ".*appvisvsubsystems64\.dll.*" and not calltrace =~ ".*twinui\.dll.*" and not calltrace =~ ".*nativeimages.*" and not targetimage == "c:\\windows\\system32\\cmd.exe"',
- ],
- 'score': 20,
- 'name': '异常进程访问'
- },
- {
- 'rules': [
- 'action == "processaccess" and sourceimage =~ ".*office16.*" and calltrace =~ ".*kernelbase\.dll.*"',
- ],
- 'score': 100,
- 'name': 'office异常进程内存'
- },
- {
- 'rules': [
- 'action == "processaccess" and calltrace =~ ".*wshom\.ocx.*"',
- 'action == "processaccess" and calltrace =~ ".*shell32\.dll.*"',
- 'action == "processaccess" and calltrace =~ ".*dbgcore\.dll.*"',
- 'action == "processaccess" and calltrace =~ ".*kernelbase\.dll\+de67e.*"',
- 'action == "processaccess" and calltrace =~ ".*framedynos\.dll.*"',
- ],
- 'score': 40,
- 'name': '不正常的进程访问'
- },
- {
- 'rules': [
- 'action == "pipecreate" and pipename =~ ".*msagent.*"',
- 'action == "pipecreate" and pipename =~ ".*msse.*"',
- 'action == "pipecreate" and pipename =~ ".*postex_.*"',
- 'action == "pipecreate" and pipename =~ ".*postex_ssh.*"',
- 'action == "pipecreate" and pipename =~ ".*status_.*"',
- ],
- 'score': 300,
- 'name': '已知CobalStrike'
- },
- {
- 'rules': [
- 'action == "pipecreate" and pipename =~ ".*paexec.*"',
- 'action == "pipecreate" and pipename =~ ".*remcom.*"',
- 'action == "pipecreate" and pipename =~ ".*csexec.*"'
- ],
- 'score': 300,
- 'name': '已知内网横向工具'
- },
- {
- 'rules': [
- 'action == "pipecreate" and pipename =~ ".*lsadump.*"',
- 'action == "pipecreate" and pipename =~ ".*cachedump.*"',
- 'action == "pipecreate" and pipename =~ ".*wceservicepipe.*"'
- ],
- 'score': 300,
- 'name': '已知mimikazt内存dump'
- },
- # todo 懒得做详细的规则了.加油完善规则吧
- {
- 'rules': [
- 'action == "createremotethread"',
- ],
- 'score': 60,
- 'name': '疑似远程线程注入'
- },
- {
- 'rules': [
- 'action == "filecreatestreamhash"',
- ],
- 'score': 100,
- 'name': '文件流创建'
- },
- {
- 'rules': [
- 'action == "registryadd"',
- 'action == "registryvalueSet"',
- 'action == "registryobjectSet"',
- ],
- 'score': 100,
- 'name': '可疑注册表访问'
- },
- {
- 'rules': [
- 'action == "dnsquery"',
- ],
- 'score': 30,
- 'name': 'DNS解析'
- },
- {
- 'rules': [
- 'action == "networkconnect"',
- ],
- 'score': 30,
- 'name': '可疑网络链接'
- },
- {
- 'rules': [
- 'action == "clipboardchange"',
- ],
- 'score': 30,
- 'name': '可疑剪切板访问'
- },
- {
- 'rules': [
- 'action == "processtampering"',
- ],
- 'score': 200,
- 'name': '进程执行流劫持'
- },
- {
- 'rules': [
- 'action == "filedeletedetected"',
- ],
- 'score': 50,
- 'name': '删除可执行文件'
- },
- {
- 'rules': [
- 'action == "filecreate" and targetfilename =~ "c:\\\\\\\\windows\\\\\\\\.*"',
- 'action == "filecreate" and targetfilename =~ ".*\.exe"',
- 'action == "filecreate" and targetfilename =~ ".*\.cmd"',
- 'action == "filecreate" and targetfilename =~ ".*\.bat"',
- 'action == "filecreate" and targetfilename =~ ".*\.dll"',
- ],
- 'score': 80,
- 'name': '在windows目录创建可执行文件'
- },
- {
- 'rules': [
- 'action == "filecreate" and targetfilename =~ "c:\\\\\\\\windows\\\\\\\\.*"',
- ],
- 'score': 50,
- 'name': '在C盘目录创建文件'
- },
- {
- 'rules': [
- 'action == "filecreate" and targetfilename =~ "c:\\\\\\\\users\\\\\\\\.*"',
- 'action == "filecreate" and targetfilename =~ ".*\.exe"',
- 'action == "filecreate" and targetfilename =~ ".*\.cmd"',
- 'action == "filecreate" and targetfilename =~ ".*\.bat"',
- 'action == "filecreate" and targetfilename =~ ".*\.dll"',
- ],
- 'score': 30,
- 'name': '在appdata目录创建可执行文件'
- },
- {
- 'rules': [
- 'action == "filecreate"',
- ],
- 'score': 50,
- 'name': '创建可疑文件'
- },
- {
- 'rules': [
- 'action == "imageload" and imageloaded == "c:\\windows\\system32\\samlib.dll"',
- ],
- 'score': 10,
- 'name': 'samlib的dll被加载'
- }
-]
diff --git a/Server/rules/py/attck/action.py b/Server/rules/py/attck/action.py
new file mode 100644
index 0000000..9745551
--- /dev/null
+++ b/Server/rules/py/attck/action.py
@@ -0,0 +1,106 @@
+rule = [
+ {
+ 'rules': [
+ 'action == "processaccess" and targetimage =~ ".*lsass.exe"',
+ ],
+ 'attck_hit':['T1003'],
+ 'name': 'OS Credential Dumping: LSASS Memory'
+ },
+ {
+ 'rules': [
+ 'action == "processaccess" and calltrace =~ ".*unknown.*" and not calltrace =~ ".*conpty\.node.*" and not calltrace =~ ".*java\.dll.*" and not calltrace =~ ".*appvisvsubsystems64\.dll.*" and not calltrace =~ ".*twinui\.dll.*" and not calltrace =~ ".*nativeimages.*" and not targetimage == "c:\\windows\\system32\\cmd.exe"',
+ ],
+ 'attck_hit':['T1620'],
+ 'name': 'Reflective Code Loading'
+ },
+ {
+ 'rules': [
+ 'action == "processaccess" and calltrace =~ ".*wshom\.ocx.*"',
+ 'action == "processaccess" and calltrace =~ ".*shell32\.dll.*"',
+ 'action == "processaccess" and calltrace =~ ".*dbgcore\.dll.*"',
+ 'action == "processaccess" and calltrace =~ ".*kernelbase\.dll\+de67e.*"',
+ 'action == "processaccess" and calltrace =~ ".*framedynos\.dll.*"',
+ ],
+ 'attck_hit':['T1559.001'],
+ 'name': 'Inter-Process Communication: Component Object Model'
+ },
+ # todo 懒得做详细的规则了.加油完善规则吧
+ {
+ 'rules': [
+ 'action == "createremotethread"',
+ ],
+ 'attck_hit':['T1055'],
+ 'name': 'Process Injection'
+ },
+ {
+ 'rules': [
+ 'action == "filecreatestreamhash"',
+ ],
+ 'attck_hit':['T1564.004'],
+ 'name': 'Hide Artifacts: NTFS File Attributes'
+ },
+ {
+ 'rules': [
+ 'action == "dnsquery"',
+ ],
+ 'attck_hit':['T1071.004'],
+ 'name': 'Application Layer Protocol: DNS'
+ },
+ {
+ 'rules': [
+ 'action == "networkconnect"',
+ ],
+ 'attck_hit':['T1071'],
+ 'name': 'Application Layer Protocol'
+ },
+ {
+ 'rules': [
+ 'action == "clipboardchange"',
+ ],
+ 'attck_hit':['T1115'],
+ 'name': 'Clipboard Data Monitor API'
+ },
+ {
+ 'rules': [
+ 'action == "processtampering"',
+ ],
+ 'attck_hit':['T1574'],
+ 'name': 'Hijack Execution Flow'
+ },
+ {
+ 'rules': [
+ 'action == "filecreate" and targetfilename =~ "c:\\\\\\\\windows\\\\\\\\.*"',
+ 'action == "filecreate" and targetfilename =~ ".*\.exe"',
+ 'action == "filecreate" and targetfilename =~ ".*\.cmd"',
+ 'action == "filecreate" and targetfilename =~ ".*\.bat"',
+ 'action == "filecreate" and targetfilename =~ ".*\.dll"',
+ ],
+ 'attck_hit':['T1036.005'],
+ 'name': 'Masquerading: Match Legitimate Name or Location'
+ },
+ {
+ 'rules': [
+ 'action == "filecreate" and targetfilename =~ "c:\\\\\\\\windows\\\\\\\\.*"',
+ ],
+ 'attck_hit':['T1036.005'],
+ 'name': 'Masquerading: Match Legitimate Name or Location'
+ },
+ {
+ 'rules': [
+ 'action == "filecreate" and targetfilename =~ "c:\\\\\\\\users\\\\\\\\.*"',
+ 'action == "filecreate" and targetfilename =~ ".*\.exe"',
+ 'action == "filecreate" and targetfilename =~ ".*\.cmd"',
+ 'action == "filecreate" and targetfilename =~ ".*\.bat"',
+ 'action == "filecreate" and targetfilename =~ ".*\.dll"',
+ ],
+ 'attck_hit':['T1036.005'],
+ 'name': 'Masquerading: Match Legitimate Name or Location'
+ },
+ {
+ 'rules': [
+ 'action == "imageload" and imageloaded == "c:\\windows\\system32\\samlib.dll"',
+ ],
+ 'attck_hit':['T1003.002'],
+ 'name': 'OS Credential Dumping: Security Account Manager'
+ }
+]
diff --git a/Server/rules/py/attck/attck.py b/Server/rules/py/attck/attck.py
new file mode 100644
index 0000000..7e047b3
--- /dev/null
+++ b/Server/rules/py/attck/attck.py
@@ -0,0 +1,8 @@
+rule = [
+ {'name': "Ransomware", 'rules': ['T1071',
+ 'T1036.005', 'T1620', 'T1564.001', 'T1222.001', 'T1059.005', 'T1543.003', 'T1490'], 'hit_num': 7, 'score':100},
+ {'name': "APT-System discovery", 'rules': ['T1018',
+ 'T1087.001', 'T1087.001', 'T1082', 'T1016'], 'hit_num': 3, 'score':65},
+ {'name': "APT-Hydra", 'rules': ['T1027.004',
+ 'T1018', 'T1559.001', 'T1218.011', 'T1059.001', 'T1059.005', 'T1570', 'T1087.002', 'T1564', 'T1106', 'T1082', 'T1087.001', 'T1003', 'T1071'], 'hit_num': 10, 'score':100}
+]
diff --git a/Server/rules/py/attck/process.py b/Server/rules/py/attck/process.py
new file mode 100644
index 0000000..b2d733a
--- /dev/null
+++ b/Server/rules/py/attck/process.py
@@ -0,0 +1,314 @@
+rule = [
+ {
+ 'rules': [
+ 'originalfilename =~ ".*taskill.exe.*"',
+ 'originalfilename =~ ".*net.exe.*" and commandline =~ ".*stop.*"',
+ 'originalfilename =~ ".*sc.exe.*" and commandline =~ ".*config.*" and commandline =~ ".*disabled.*"',
+ ],
+ 'attck_hit':['T1489'],
+ 'score': 30,
+ 'name': 'Service Stop'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*curl.exe" or originalfilename =~ ".*wget.exe" or originalfilename =~ ".*dget.exe"',
+ 'originalfilename =~ ".*certutil.exe"',
+ 'originalfilename =~ ".*powershell.exe" and commandline =~ ".*invoke-webrequest.*"'
+ ],
+ 'attck_hit':['T1105'],
+ 'score': 30,
+ 'name':'Ingress Tool Transfer'
+ },
+ {
+ 'rules': [
+ 'image =~ ".*\.doc\.exe"',
+ 'image =~ ".*\.docx\.exe"',
+ 'image =~ ".*\.ppt\.exe"',
+ 'image =~ ".*\.pdf\.exe"',
+ 'image =~ ".*\.html\.exe"',
+ 'image =~ ".*\.htm\.exe"',
+ 'image =~ ".*\.zip\.exe"',
+ 'image =~ ".*\.rar\.exe"'
+ ],
+ 'attck_hit':['T1036.007'],
+ 'score': 60,
+ 'name':'Masquerading: Double File Extension'
+ },
+ {
+ 'rules': [
+ 'commandline =~ ".*-k dcomlaunch.*"'
+ ],
+ 'attck_hit':['T1559.001'],
+ 'score': 30,
+ 'name':'Inter-Process Communication: Component Object Model'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*vssadmin.exe.*" and commandline =~ ".*create.*"',
+ ],
+ 'attck_hit':['T1003.003'],
+ 'score': 30,
+ 'name':'OS Credential Dumping: NTDS'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*wbadmin.exe.*" and commandline =~ ".*delete.*"',
+ 'originalfilename =~ ".*bcdedit.exe" and commandline =~ ".*recoveryenabled.*no.*"',
+ 'originalfilename =~ ".*bcdedit.exe" and commandline =~ ".*bootstatuspolicy.*ignoreallfailures.*"',
+ 'originalfilename =~ ".*wmic.exe" and commandline =~ ".*shadowcopy.*" and commandline =~ ".*delete.*"',
+ 'originalfilename =~ ".*vssadmin.exe" and commandline =~ ".*shadows.*" and commandline =~ ".*delete.*"',
+ ],
+ 'attck_hit':['T1490'],
+ 'score': 30,
+ 'name': 'Inhibit System Recovery'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*net.exe.*" and commandline =~ ".*view.*"',
+ 'originalfilename =~ ".*net.exe.*" and commandline =~ ".*group.*"',
+ 'originalfilename =~ ".*ping.exe"',
+
+ ],
+ 'attck_hit':['T1018'],
+ 'score': 10,
+ 'name': 'Remote System Discovery'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*fsutil.exe.*" and commandline =~ ".*deletejournal.*"',
+ ],
+ 'attck_hit':['T1070.004'],
+ 'score': 10,
+ 'name': 'Indicator Removal on Host'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*net.exe.*" and commandline =~ ".*user.*"',
+ 'originalfilename =~ ".*whoami.*"',
+ 'originalfilename =~ ".*query.exe"',
+ 'originalfilename =~ ".*setspn.exe"',
+ 'originalfilename =~ ".*cmdkey.exe.*"'
+ ],
+ 'attck_hit':['T1087.001'],
+ 'score': 30,
+ 'name': 'Account Discovery: Local Account'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*wmic.exe" and commandline =~ ".*useraccount.*"',
+ ],
+ 'attck_hit':['T1087.001', 'T1047'],
+ 'score': 30,
+ 'name': 'Account Discovery: Local Account by wmic'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*wmic.exe" and commandline =~ ".*startup.*"',
+ 'originalfilename =~ ".*wmic.exe" and commandline =~ ".*share.*"',
+
+ ],
+ 'attck_hit':['T1082', 'T1047'],
+ 'score': 30,
+ 'name': 'System Information Discovery by wmic'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*systeminfo.exe"',
+ 'originalfilename =~ ".*chcp.com"'
+
+ ],
+ 'attck_hit':['T1082'],
+ 'score': 10,
+ 'name': 'System Information Discovery'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*tasklist.exe"',
+ ],
+ 'attck_hit':['T1057'],
+ 'score': 10,
+ 'name': 'Process Discovery'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*at.exe.*"',
+ ],
+ 'attck_hit':['T1053.002'],
+ 'score': 10,
+ 'name': 'Scheduled Task/Job: at'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*schtasks.exe.*"',
+ ],
+ 'attck_hit':['T1053.005'],
+ 'score': 10,
+ 'name': 'Scheduled Task/Job: Scheduled Task'
+ },
+ {
+ 'rules': [
+ 'image =~ ".*\\\\\\\\appdata\\\\\\\\local\\\\\\\\temp\\\\\\\\.*" or image =~ ".*\\\\\\\\windows\\\\\\\\temp\\\\\\\\.*"',
+ ],
+ 'attck_hit':['T1106'],
+ 'score': 10,
+ 'name': 'Execution: Native API'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*rubeus.*" and commandline =~ ".*domain.*"',
+ ],
+ 'attck_hit':['T1558.003'],
+ 'score': 10,
+ 'name': 'Steal or Forge Kerberos Tickets: Kerberoasting'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*\u202e.*"',
+ ],
+ 'attck_hit':['T1564'],
+ 'score': 10,
+ 'name': 'Hide Artifacts'
+ },
+ {
+ 'rules': [
+ 'parentimage =~ ".*mmc.exe" and commandline =~ ".*eventvwr\.msc.*"',
+ ],
+ 'attck_hit':['T1218.014'],
+ 'score': 10,
+ 'name': 'System Binary Proxy Execution: MMC'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*net.exe" and commandline =~ ".*domain.*"',
+ 'originalfilename =~ ".*net.exe" and commandline =~ ".*view.*"',
+ 'originalfilename =~ ".*net.exe" and commandline =~ ".*workstation.*"'
+ ],
+ 'attck_hit':['T1087.002'],
+ 'score': 10,
+ 'name': 'Account Discovery: Domain Account'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*netsh.exe" and commandline =~ ".*firewall.*"',
+ ],
+ 'attck_hit':['T1562.004'],
+ 'score': 10,
+ 'name': 'Impair Defenses: Disable or Modify System Firewall'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*ipconfig.exe"',
+ 'originalfilename =~ ".*netstat.exe"'
+
+ ],
+ 'attck_hit':['T1016'],
+ 'score': 10,
+ 'name': 'System Network Configuration Discovery'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*attrib.exe"',
+ ],
+ 'attck_hit':['T1564.001'],
+ 'score': 10,
+ 'name': 'Hide Artifacts: Hidden Files and Directories'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*psexesvc.exe"',
+ ],
+ 'attck_hit':['T1570'],
+ 'score': 10,
+ 'name': 'Lateral Tool Transfer'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ "\\\\\\\\.*\\\\\\C\$.*"',
+ ],
+ 'attck_hit':['T1080'],
+ 'score': 10,
+ 'name': 'Taint Shared Content'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*icacls.exe"',
+ ],
+ 'attck_hit':['T1222.001'],
+ 'score': 10,
+ 'name': 'Windows File and Directory Permissions Modification'
+ },
+ {
+ 'rules': [
+ 'parentimage =~ ".*services.exe"',
+ ],
+ 'attck_hit':['T1543.003'],
+ 'score': 10,
+ 'name': 'Create or Modify System Process: Windows Service'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*werfault.exe" and parentimage =~ ".*svchost.exe"',
+ ],
+ 'attck_hit':['T1218'],
+ 'score': 10,
+ 'name': 'System Binary Proxy Execution'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*wscript.exe"',
+ 'originalfilename =~ ".*cscript.exe"',
+ ],
+ 'attck_hit':['T1059.005'],
+ 'score': 10,
+ 'name': 'Command and Scripting Interpreter: Visual Basic'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*mofcomp.exe.*"'
+ ],
+ 'attck_hit':['T1546.015'],
+ 'score': 10,
+ 'name':'Event Triggered Execution: Component Object Model Hijacking'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*csc.exe.*"'
+ ],
+ 'attck_hit':['T1027.004'],
+ 'score': 10,
+ 'name':'Compile After Delivery'
+ },
+ # https://attack.mitre.org/software/S0552/
+ {
+ 'rules': [
+ 'originalfilename =~ ".*adfind.exe.*"'
+ ],
+ 'attck_hit':['T1018'],
+ 'score': 10,
+ 'name':'Remote System Discovery'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*wmic.exe.*"'
+ ],
+ 'attck_hit':['T1559.001'],
+ 'score': 30,
+ 'name':'Windows Management Instrumentation'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*rundll32.exe.*"'
+ ],
+ 'attck_hit':['T1218.011'],
+ 'score': 10,
+ 'name':'System Binary Proxy Execution: Rundll32'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*powershell.exe"'
+ ],
+ 'attck_hit':['T1059.001'],
+ 'score': 10,
+ 'name':'Command and Scripting Interpreter: PowerShell'
+ },
+]
diff --git a/Server/rules/py/ioa/action.py b/Server/rules/py/ioa/action.py
new file mode 100644
index 0000000..134207e
--- /dev/null
+++ b/Server/rules/py/ioa/action.py
@@ -0,0 +1,50 @@
+rule = [
+ {
+ 'rules': [
+ 'action == "processaccess" and targetimage =~ ".*lsass.exe" and grantedaccess & 0x0010 and sourceimage =~ ".*rundll32.exe"',
+ ],
+ 'attck_hit':['T1003.002'],
+ 'score': 100,
+ 'name': '已知内存加载mimikazt行为'
+ },
+ {
+ 'rules': [
+ 'action == "processaccess" and sourceimage =~ ".*office16.*" and calltrace =~ ".*kernelbase\.dll.*"',
+ ],
+ 'attck_hit':['T1003.002'],
+ 'score': 60,
+ 'name': 'office异常进程内存'
+ },
+ {
+ 'rules': [
+ 'action == "pipecreate" and pipename =~ ".*msagent.*"',
+ 'action == "pipecreate" and pipename =~ ".*msse.*"',
+ 'action == "pipecreate" and pipename =~ ".*postex_.*"',
+ 'action == "pipecreate" and pipename =~ ".*postex_ssh.*"',
+ 'action == "pipecreate" and pipename =~ ".*status_.*"',
+ ],
+ 'attck_hit':['T1003.002'],
+ 'score': 100,
+ 'name': '已知CobalStrike'
+ },
+ {
+ 'rules': [
+ 'action == "pipecreate" and pipename =~ ".*paexec.*"',
+ 'action == "pipecreate" and pipename =~ ".*remcom.*"',
+ 'action == "pipecreate" and pipename =~ ".*csexec.*"'
+ ],
+ 'attck_hit':['T1003.002'],
+ 'score': 100,
+ 'name': '已知内网横向工具'
+ },
+ {
+ 'rules': [
+ 'action == "pipecreate" and pipename =~ ".*lsadump.*"',
+ 'action == "pipecreate" and pipename =~ ".*cachedump.*"',
+ 'action == "pipecreate" and pipename =~ ".*wceservicepipe.*"'
+ ],
+ 'attck_hit':['T1003.002'],
+ 'score': 100,
+ 'name': '已知mimikazt内存dump'
+ },
+]
diff --git a/Server/rules/py/ioa/process.py b/Server/rules/py/ioa/process.py
new file mode 100644
index 0000000..07f2554
--- /dev/null
+++ b/Server/rules/py/ioa/process.py
@@ -0,0 +1,35 @@
+rule = [
+ {
+ 'rules': [
+ 'originalfilename =~ ".*todesk_service.*" or originalfilename =~ ".*sunloginclient.*" or originalfilename =~ ".*teamviewer_service.exe.*" or originalfilename =~ ".*logmein.*" or originalfilename =~ ".*dwrcs.*" or originalfilename =~ ".*aa_v3.*" or originalfilename =~ ".*screenconnect.*" or originalfilename =~ ".*tvnserver.*" or originalfilename =~ ".*vncserver.*"',
+ ],
+ 'attck_hit':['T1133'],
+ 'score': 30,
+ 'name': '已知远程协助程序'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ ".*phoenixminer.*" or originalfilename =~ ".*ccminer.*" or originalfilename =~ ".*csminer.exe.*" or originalfilename =~ ".*xmrig.*" or originalfilename =~ ".*xmr-stak.*"',
+ ],
+ 'attck_hit':['T1496'],
+ 'score': 100,
+ 'name': '已知挖矿程序'
+ },
+ {
+ 'rules': [
+ 'originalfilename =~ "\\\\\\.*" and parentimage =~ ".*services.exe"',
+ ],
+ 'attck_hit':['T1021.006'],
+ 'score': 100,
+ 'name': '远程服务被创建'
+ },
+ {
+ 'rules': [
+ 'commandline =~ ".*__\d{10}\."',
+ 'originalfilename =~ ".*wmi_share.exe"',
+ ],
+ 'attck_hit':['T00000'],
+ 'score': 100,
+ 'name': 'wmic内网横向移动被触发'
+ },
+]
diff --git a/Server/rules/py/process.py b/Server/rules/py/process.py
deleted file mode 100644
index f8b937b..0000000
--- a/Server/rules/py/process.py
+++ /dev/null
@@ -1,405 +0,0 @@
-rule = [
- {
- 'rules': [
- 'originalfilename =~ ".*taskill.exe.*"',
- 'originalfilename =~ ".*net.exe.*" and commandline =~ ".*stop.*"',
- 'originalfilename =~ ".*sc.exe.*" and commandline =~ ".*config.*" and commandline =~ ".*disabled.*"',
- ],
- 'score': 40,
- 'name': '通过系统程序关闭进程'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*curl.exe" or originalfilename =~ ".*wget.exe" or originalfilename =~ ".*dget.exe"'
- ],
- 'score': 40,
- 'name':'通过应用下载文件'
- },
- {
- 'rules': [
- 'image =~ ".*\.doc\.exe"',
- 'image =~ ".*\.docx\.exe"',
- 'image =~ ".*\.ppt\.exe"',
- 'image =~ ".*\.pdf\.exe"',
- 'image =~ ".*\.html\.exe"',
- 'image =~ ".*\.htm\.exe"',
- 'image =~ ".*\.zip\.exe"',
- 'image =~ ".*\.rar\.exe"'
- ],
- 'score': 30,
- 'name':'启动双扩展名文件'
- },
- {
- 'rules': [
- 'commandline =~ ".*-k dcomlaunch.*"'
- ],
- 'score': 30,
- 'name':'通过DCOM启动了进程'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*wbadmin.exe.*" and commandline =~ ".*delete.*"',
- ],
- 'score': 70,
- 'name': '通过wbadmin删除备份'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*net.exe.*" and commandline =~ ".*view.*"',
- ],
- 'score': 70,
- 'name': '通过net进行远程系统发现'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*fsutil.exe.*" and commandline =~ ".*deletejournal.*"',
- ],
- 'score': 70,
- 'name': '通过系统工具删除USN'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*net.exe.*" and commandline =~ ".*user.*"',
- ],
- 'score': 70,
- 'name': '通过net进行系统用户发现'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*schtasks.exe.*" and commandline =~ ".*create.*"',
- ],
- 'score': 70,
- 'name': '通过系统应用创建计划任务'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*schtasks.exe.*" and commandline =~ ".*delete.*"',
- ],
- 'score': 40,
- 'name': '通过系统应用删除计划任务'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*vssadmin.exe.*" and commandline =~ ".*create.*"',
- ],
- 'score': 40,
- 'name': '通过系统程序创建卷影备份'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*todesk_service.*" or originalfilename =~ ".*sunloginclient.*" or originalfilename =~ ".*teamviewer_service.exe.*" or originalfilename =~ ".*logmein.*" or originalfilename =~ ".*dwrcs.*" or originalfilename =~ ".*aa_v3.*" or originalfilename =~ ".*screenconnect.*" or originalfilename =~ ".*tvnserver.*" or originalfilename =~ ".*vncserver.*"',
- ],
- 'score': 20,
- 'name': '已知远程协助程序'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*phoenixminer.*" or originalfilename =~ ".*ccminer.*" or originalfilename =~ ".*csminer.exe.*" or originalfilename =~ ".*xmrig.*" or originalfilename =~ ".*xmr-stak.*"',
- ],
- 'score': 300,
- 'name': '已知挖矿程序'
- },
- {
- 'rules': [
- 'image =~ ".*\\\\\\\\appdata\\\\\\\\local\\\\\\\\temp\\\\\\\\.*" or image =~ ".*\\\\\\\\windows\\\\\\\\temp\\\\\\\\.*"',
- ],
- 'score': 40,
- 'name': '从临时文件创建进程'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*rubeus.*" and commandline =~ ".*domain.*"',
- ],
- 'score': 100,
- 'name': '通过系统工具获取域登陆令牌'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*whoami.*"',
- ],
- 'score': 70,
- 'name': 'whoami被执行'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*\u202e.*"',
- ],
- 'score': 100,
- 'name': '伪装名字程序被执行'
- },
- {
- 'rules': [
- 'parentimage =~ ".*mmc.exe" and commandline =~ ".*eventvwr\.msc.*"',
- ],
- 'score': 40,
- 'name': '高权限进程被创建'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*bcdedit.exe" and commandline =~ ".*recoveryenabled.*no.*"',
- 'originalfilename =~ ".*bcdedit.exe" and commandline =~ ".*bootstatuspolicy.*ignoreallfailures.*"',
- ],
- 'score': 80,
- 'name': '通过系统工具关闭系统恢复'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*wmic.exe" and commandline =~ ".*useraccount.*"',
- ],
- 'score': 70,
- 'name': '通过wmic进行系统用户发现'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*wmic.exe" and commandline =~ ".*startup.*"',
- ],
- 'score': 70,
- 'name': '通过wmic查看系统启动项'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*wmic.exe" and commandline =~ ".*share.*"',
- ],
- 'score': 70,
- 'name': '通过wmic查看系统共享'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*wmic.exe" and commandline =~ ".*shadowcopy.*" and commandline =~ ".*delete.*"',
- ],
- 'score': 70,
- 'name': 'wmic删除卷影备份'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*vssadmin.exe" and commandline =~ ".*shadows.*" and commandline =~ ".*delete.*"',
- ],
- 'score': 70,
- 'name': 'vssadmin删除卷影备份'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*tasklist.exe"',
- ],
- 'score': 50,
- 'name': '通过tasklist查看系统信息'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*systeminfo.exe"',
- ],
- 'score': 70,
- 'name': '通过systeminfo查看系统信息'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*query.exe"',
- ],
- 'score': 70,
- 'name': '通过query进行系统用户发现'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*net.exe" and commandline =~ ".*domain.*"',
- 'originalfilename =~ ".*net.exe" and commandline =~ ".*view.*"',
- 'originalfilename =~ ".*net.exe" and commandline =~ ".*workstation.*"'
- ],
- 'score': 70,
- 'name': '通过net进行本地系统用户发现'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*setspn.exe"',
- ],
- 'score': 70,
- 'name': '通过setspn进行本地系统用户发现'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*netsh.exe" and commandline =~ ".*firewall.*"',
- ],
- 'score': 70,
- 'name': '通过netsh关闭防火墙'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*cmd.exe" and commandline =~ ".*ipconfig.*"',
- ],
- 'score': 80,
- 'name': 'cmd启动ipconfig'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*cmd.exe" and commandline =~ ".*net.*"',
- ],
- 'score': 60,
- 'name': 'cmd启动net'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*netstat.exe"',
- ],
- 'score': 40,
- 'name': 'netstat被运行'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*ping.exe"',
- ],
- 'score': 40,
- 'name': 'ping被运行'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*ipconfig.exe"',
- ],
- 'score': 40,
- 'name': 'ipconfig被运行'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*attrib.exe"',
- ],
- 'score': 40,
- 'name': 'attrib被运行'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*PSEXESVC.exe"',
- ],
- 'score': 100,
- 'name': 'PSEXESVC内网横向移动'
- },
- {
- 'rules': [
- 'originalfilename =~ "\\\\\\\\.*\\\\\\C\$.*"',
- ],
- 'score': 100,
- 'name': 'SMB共享启动进程'
- },
- {
- 'rules': [
- 'commandline =~ ".*__\d{10}\."',
- 'originalfilename =~ ".*wmi_share.exe"',
- ],
- 'score': 100,
- 'name': 'wmic内网横向移动被触发'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*icacls.exe"',
- ],
- 'score': 40,
- 'name': 'icacls被运行'
- },
- {
- 'rules': [
- 'originalfilename =~ "\\\\\\.*" and parentimage =~ ".*services.exe"',
- ],
- 'score': 100,
- 'name': '远程服务被创建'
- },
- {
- 'rules': [
- 'parentimage =~ ".*services.exe"',
- ],
- 'score': 30,
- 'name': '从服务创建的进程'
- },
- {
- 'rules': [
- 'parentimage =~ ".*svchost.exe"',
- 'originalfilename =~ ".*werfault.exe"'
- ],
- 'score': 60,
- 'name': 'svchost.exe启动了werfault'
- },
- {
- 'rules': [
- 'parentimage =~ ".*werfault.exe"',
- ],
- 'score': 30,
- 'name': '从werfault创建的进程'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*wscript.exe"',
- 'originalfilename =~ ".*cscript.exe"',
- ],
- 'score': 40,
- 'name': '脚本程序被运行'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*mofcomp.exe.*"'
- ],
- 'score': 80,
- 'name':'注册WMI订阅'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*csc.exe.*"'
- ],
- 'score': 80,
- 'name':'.NET编译器被启动'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*cmdkey.exe.*"'
- ],
- 'score': 100,
- 'name':'通过系统应用查询本机账户'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*adfind.exe.*"'
- ],
- 'score': 80,
- 'name':'通过系统程序发现域信息'
- },
- # 这些是保底规则 必须放到最底下才匹配
- {
- 'rules': [
- 'originalfilename =~ ".*cmd.exe"'
- ],
- 'score': 30,
- 'name':'执行CMD命令'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*chcp.com"'
- ],
- 'score': 30,
- 'name':'执行chcp.com'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*wmic.exe.*"'
- ],
- 'score': 80,
- 'name':'执行wmic'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*rundll32.exe.*"'
- ],
- 'score': 20,
- 'name':'通过rundll32启动进程'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*certutil.exe"',
- 'originalfilename =~ ".*curl.exe"',
- 'originalfilename =~ ".*powershell.exe" and commandline =~ ".*invoke-webrequest.*"'
- ],
- 'score': 80,
- 'name':'通过系统命令下载文件'
- },
- {
- 'rules': [
- 'originalfilename =~ ".*powershell.exe"'
- ],
- 'score': 80,
- 'name':'Powershell被执行'
- },
-]
diff --git a/Server/sql.py b/Server/sql.py
index 058e870..9aef1d1 100644
--- a/Server/sql.py
+++ b/Server/sql.py
@@ -87,6 +87,8 @@ class threat_log(g_base):
risk_score = Column(Integer)
# 命中的规则
hit_rule = Column(String)
+ # attck命中
+ attck_hit_list = Column(String)
# json字段
data = Column(String)
# 时间戳
@@ -262,7 +264,7 @@ def select_threat_by_chain_id(host, process_chain_hash, type):
def update_threat_log(
- host, risk_score, hit_rule_json, process_chain_hash, raw_json, type, is_end
+ host, risk_score, hit_rule_json, attck_hit_list_json, process_chain_hash, raw_json, type, is_end
):
global g_threat_table
global g_engine
@@ -272,6 +274,7 @@ def update_threat_log(
.values(
risk_score=risk_score,
hit_rule=hit_rule_json,
+ attck_hit_list=attck_hit_list_json,
data=raw_json,
is_end=int(is_end),
)
@@ -335,6 +338,7 @@ def query_all_threat_log(query_type):
threat_log.is_end,
threat_log.start_process_info,
threat_log.handle_type,
+ threat_log.attck_hit_list,
)
.all()
)
@@ -353,6 +357,7 @@ def query_all_threat_log(query_type):
threat_log.is_end,
threat_log.start_process_info,
threat_log.handle_type,
+ threat_log.attck_hit_list
)
.filter_by(handle_type=query_type)
.all()
@@ -365,6 +370,7 @@ def push_threat_log(
host,
risk_score,
hit_rule_json,
+ attck_hit_list_json,
process_chain_hash,
raw_json,
type,
@@ -378,6 +384,7 @@ def push_threat_log(
risk_score=risk_score,
process_chain_hash=process_chain_hash,
hit_rule=hit_rule_json,
+ attck_hit_list=attck_hit_list_json,
type=type,
data=raw_json,
timestamp=int(round(time.time() * 1000)),
diff --git a/Server/templates/index.html b/Server/templates/index.html
index ed97024..87d8951 100644
--- a/Server/templates/index.html
+++ b/Server/templates/index.html
@@ -1 +1 @@
-
Duck Sys Eye
\ No newline at end of file
+Duck Sys Eye
\ No newline at end of file
diff --git a/Server/templates/js/56.dc9e32b8.js b/Server/templates/js/56.dc9e32b8.js
new file mode 100644
index 0000000..7f6ce9b
--- /dev/null
+++ b/Server/templates/js/56.dc9e32b8.js
@@ -0,0 +1 @@
+"use strict";(globalThis["webpackChunksyseye"]=globalThis["webpackChunksyseye"]||[]).push([[56],{8056:(t,e,a)=>{a.r(e),a.d(e,{default:()=>nt});var i=a(3673),l=a(2323);const s={class:"q-gutter-md q-mb-sm q-pa-lg"},o={class:"row q-col-gutter-sm"},n={class:"row"},r=(0,i._)("div",{class:"col"},null,-1),d={class:"col"},h={class:"row q-gutter-md q-mb-sm q-pa-lg"},c={key:0},u=(0,i._)("div",{class:"bg-red-5"}," ",-1),w=(0,i.Uk)(" 分数: "),p=(0,i.Uk)(" 活动状态: "),m=(0,i.Uk)(" ATTCK命中: "),g=(0,i.Uk)(" 产生的威胁: "),A=(0,i.Uk)(" 机器学习引擎 "),_=(0,i.Uk)(" 查看详情 "),k=(0,i.Uk)(" 在VT上搜索 "),f=(0,i.Uk)(" 确认威胁 "),C=(0,i.Uk)(" 忽略威胁 "),b=(0,i.Uk)(" 删除报警 "),v=(0,i._)("div",{class:"col"},null,-1),D=(0,i._)("div",{class:"text-h6"},"填写缘由",-1),W=(0,i.Uk)("Close"),B={class:"row",style:{width:"100%",height:"100%"}},U={ref:"main_draw",style:{width:"100%",height:"100%","margin-left":"5%"}},q=(0,i.Uk)("进程命中的规则: "),y=(0,i.Uk)(" 无 "),Q=(0,i.Uk)("attck矩阵: "),V=(0,i.Uk)(" 无 ");function S(t,e,a,S,I,x){const Z=(0,i.up)("q-icon"),K=(0,i.up)("q-item-section"),E=(0,i.up)("q-item-label"),Y=(0,i.up)("q-item"),z=(0,i.up)("q-card-section"),H=(0,i.up)("q-card"),j=(0,i.up)("q-chip"),N=(0,i.up)("q-btn"),O=(0,i.up)("q-card-actions"),F=(0,i.up)("q-timeline-entry"),L=(0,i.up)("q-timeline"),T=(0,i.up)("q-input"),X=(0,i.up)("q-dialog"),J=(0,i.up)("q-space"),P=(0,i.up)("q-tooltip"),R=(0,i.up)("q-bar"),G=(0,i.up)("q-separator"),M=(0,i.up)("q-list"),$=(0,i.up)("q-drawer"),tt=(0,i.Q2)("close-popup");return(0,i.wg)(),(0,i.iD)(i.HY,null,[(0,i._)("div",null,[(0,i._)("div",s,[(0,i.Wm)(H,{class:"bg-transparent no-shadow no-border"},{default:(0,i.w5)((()=>[(0,i.Wm)(z,{class:"q-pa-none"},{default:(0,i.w5)((()=>[(0,i._)("div",o,[((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(t.Threatitems,((t,e)=>((0,i.wg)(),(0,i.iD)("div",{key:e,class:"col-md-3 col-sm-12 col-xs-12"},[(0,i.Wm)(Y,{style:(0,l.j5)(`background-color: ${t.color1}`),class:"q-pa-none"},{default:(0,i.w5)((()=>[(0,i.Wm)(K,{side:"",style:(0,l.j5)(`background-color: ${t.color2}`),class:"q-pa-lg q-mr-none text-white"},{default:(0,i.w5)((()=>[(0,i.Wm)(Z,{name:t.icon,color:"white",size:"24px"},null,8,["name"])])),_:2},1032,["style"]),(0,i.Wm)(K,{class:"q-pa-md q-ml-none text-white"},{default:(0,i.w5)((()=>[(0,i.Wm)(E,{class:"text-white text-h6 text-weight-bolder"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(t.value),1)])),_:2},1024),(0,i.Wm)(E,null,{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(t.title),1)])),_:2},1024)])),_:2},1024)])),_:2},1032,["style"])])))),128))])])),_:1})])),_:1})]),(0,i._)("div",n,[r,(0,i._)("div",d,[(0,i._)("div",h,[(0,i.Wm)(L,{layout:"dense",side:"right",color:"red"},{default:(0,i.w5)((()=>[t.server_threat.data&&0!=t.server_threat.data.length?(0,i.kq)("",!0):((0,i.wg)(),(0,i.iD)("h4",c,"暂无可用数据,下次刷新时间 "+(0,l.zw)(t.last_refresh)+"...",1)),((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(t.server_threat.data,((e,a)=>((0,i.wg)(),(0,i.j4)(F,{key:a,subtitle:"主机:"+e.host,side:"left"},{default:(0,i.w5)((()=>[(0,i._)("div",null,[(0,i.Wm)(H,{flat:"",bordered:"",style:{overflow:"auto"},"thumb-style":t.thumbStyle,"bar-style":t.barStyle},{default:(0,i.w5)((()=>[(0,i.Wm)(z,{horizontal:""},{default:(0,i.w5)((()=>[u,(0,i.Wm)(O,{vertical:"",class:"justify-around q-px-md"},{default:(0,i.w5)((()=>[(0,i._)("div",null,"进程链hash: "+(0,l.zw)(e.chain_hash),1),(0,i._)("div",null,"进程: "+(0,l.zw)(e.start_process.path),1),(0,i._)("div",null,"用户: "+(0,l.zw)(e.start_process.user),1),(0,i._)("div",null,[w,(0,i.Wm)(j,{square:"",color:"orange","text-color":"white","icon-right":"visibility"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(e.risk_score),1)])),_:2},1024)]),(0,i._)("div",null,[p,(0,i.Wm)(j,{square:"",color:1==e.is_end?"negative":"red","text-color":"white"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(1==e.is_end?"已结束":"进行中"),1)])),_:2},1032,["color"])]),(0,i._)("div",null,[m,((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(e.attck_hit_list,((t,e)=>((0,i.wg)(),(0,i.j4)(j,{key:t,square:"",color:"rgb(239,243,246)"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(e)+" ("+(0,l.zw)(t)+") ",1)])),_:2},1024)))),128))]),(0,i._)("div",null,[g,((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(e.hit_rule,((t,e)=>((0,i.wg)(),(0,i.j4)(j,{key:t,square:"",color:"red","text-color":"white"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(e)+" ("+(0,l.zw)(t)+") ",1)])),_:2},1024)))),128)),"{}"==JSON.stringify(e.hit_rule)?((0,i.wg)(),(0,i.j4)(j,{key:0,square:"",color:"negative","text-color":"white"},{default:(0,i.w5)((()=>[A])),_:1})):(0,i.kq)("",!0)]),(0,i._)("div",null,[(0,i.Wm)(N,{flat:"",color:"accent",onClick:a=>t.show_details(e.id),icon:"open_in_new"},{default:(0,i.w5)((()=>[_])),_:2},1032,["onClick"]),(0,i.Wm)(N,{flat:"",color:"accent",onClick:a=>t.search_vt(e.start_process.hash),icon:"search"},{default:(0,i.w5)((()=>[k])),_:2},1032,["onClick"]),(0,i.Wm)(N,{flat:"",color:"accent",onClick:a=>t.handle_threat(e.id,1),icon:"done"},{default:(0,i.w5)((()=>[f])),_:2},1032,["onClick"]),(0,i.Wm)(N,{flat:"",color:"accent",onClick:a=>t.handle_threat(e.id,2),icon:"texture"},{default:(0,i.w5)((()=>[C])),_:2},1032,["onClick"]),(0,i.Wm)(N,{flat:"",color:"accent",icon:"close",onClick:a=>t.delete_threat(e.id)},{default:(0,i.w5)((()=>[b])),_:2},1032,["onClick"])])])),_:2},1024)])),_:2},1024)])),_:2},1032,["thumb-style","bar-style"])])])),_:2},1032,["subtitle"])))),128))])),_:1})])]),v])]),(0,i.Wm)(X,{modelValue:t.addwhiteListHash,"onUpdate:modelValue":e[3]||(e[3]=e=>t.addwhiteListHash=e),persistent:"","transition-show":"scale","transition-hide":"scale"},{default:(0,i.w5)((()=>[(0,i.Wm)(H,{style:{"min-width":"350px"}},{default:(0,i.w5)((()=>[(0,i.Wm)(z,null,{default:(0,i.w5)((()=>[D])),_:1}),(0,i.Wm)(z,{class:"q-pt-none"},{default:(0,i.w5)((()=>[(0,i.Wm)(T,{dense:"",modelValue:this.whiteListPostData.reason,"onUpdate:modelValue":e[0]||(e[0]=t=>this.whiteListPostData.reason=t),autofocus:""},null,8,["modelValue"])])),_:1}),(0,i.Wm)(O,{align:"right",class:"text-primary"},{default:(0,i.w5)((()=>[(0,i.wy)((0,i.Wm)(N,{flat:"",label:"取消",onClick:e[1]||(e[1]=e=>t.addwhiteListHash=!1)},null,512),[[tt]]),(0,i.wy)((0,i.Wm)(N,{flat:"",label:"加入白名单",onClick:e[2]||(e[2]=e=>t.add_to_white_hash_post())},null,512),[[tt]])])),_:1})])),_:1})])),_:1},8,["modelValue"]),(0,i.Wm)(X,{modelValue:t.dialog,"onUpdate:modelValue":e[8]||(e[8]=e=>t.dialog=e),persistent:"",maximized:t.maximizedToggle,"transition-show":"slide-up","transition-hide":"slide-down"},{default:(0,i.w5)((()=>[(0,i.Wm)(H,{class:"text-white"},{default:(0,i.w5)((()=>[(0,i.Wm)(R,null,{default:(0,i.w5)((()=>[(0,i.Wm)(J),(0,i.wy)(((0,i.wg)(),(0,i.j4)(N,{dense:"",flat:"",icon:"close"},{default:(0,i.w5)((()=>[(0,i.Wm)(P,{"content-class":"bg-white text-primary"},{default:(0,i.w5)((()=>[W])),_:1})])),_:1})),[[tt]])])),_:1}),(0,i._)("div",B,[(0,i._)("div",U," 1 ",512)]),t.processChainShowDetails?((0,i.wg)(),(0,i.j4)($,{key:0,"show-if-above":"",modelValue:t.processChainShowDetails,"onUpdate:modelValue":e[7]||(e[7]=e=>t.processChainShowDetails=e),side:"right",bordered:"",width:"350",class:"text-dark"},{default:(0,i.w5)((()=>[(0,i.Wm)(M,{style:{width:"100%","word-break":"break-all"}},{default:(0,i.w5)((()=>[(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[(0,i.Uk)("活跃状态: "+(0,l.zw)(t.processChainDetails.active?"运行中":"已结束"),1)])),_:1})])),_:1}),(0,i.Wm)(G),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程名字: "+(0,l.zw)(t.processChainDetails.name),1)])),_:1})])),_:1}),(0,i.Wm)(G),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程路径: "+(0,l.zw)(t.processChainDetails.path),1)])),_:1})])),_:1}),(0,i.Wm)(G),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程参数: "+(0,l.zw)(t.processChainDetails.params),1)])),_:1})])),_:1}),(0,i.Wm)(G),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程id: "+(0,l.zw)(t.processChainDetails.pid),1)])),_:1})])),_:1}),(0,i.Wm)(G),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[(0,i.Uk)("父进程id: "+(0,l.zw)(t.processChainDetails.ppid),1)])),_:1})])),_:1}),(0,i.Wm)(G),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程hash: "+(0,l.zw)(t.processChainDetails.md5),1)])),_:1})])),_:1}),(0,i.Wm)(G),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[(0,i.Uk)("是否在白名单中: "+(0,l.zw)(t.processChainDetails.isWhite?"是":"否"),1)])),_:1})])),_:1}),(0,i.Wm)(G),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[q,((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(t.processChainDetails.hitRules,((t,e)=>((0,i.wg)(),(0,i.j4)(j,{key:t,square:"",color:"rgb(239,243,246)"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(e)+" ("+(0,l.zw)(t)+") ",1)])),_:2},1024)))),128)),"{}"==JSON.stringify(t.processChainDetails.hitRules)?((0,i.wg)(),(0,i.j4)(j,{key:0,square:"",color:"rgb(239,243,246)"},{default:(0,i.w5)((()=>[y])),_:1})):(0,i.kq)("",!0)])),_:1})])),_:1}),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,null,{default:(0,i.w5)((()=>[Q,((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(t.processChainDetails.hitAttck,((t,e)=>((0,i.wg)(),(0,i.j4)(j,{key:t,square:"",color:"rgb(239,243,246)"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(e)+" ("+(0,l.zw)(t)+") ",1)])),_:2},1024)))),128)),"{}"==JSON.stringify(t.processChainDetails.hitAttck)?((0,i.wg)(),(0,i.j4)(j,{key:0,square:"",color:"rgb(239,243,246)"},{default:(0,i.w5)((()=>[V])),_:1})):(0,i.kq)("",!0)])),_:1})])),_:1}),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[(0,i.Wm)(N,{icon:"search",outline:"",style:{color:"grey",width:"100%"},label:"搜索hash",onClick:e[4]||(e[4]=e=>t.search_vt(t.processChainDetails.md5))})])),_:1}),(0,i.Wm)(Y,null,{default:(0,i.w5)((()=>[0==t.processChainDetails.isWhite?((0,i.wg)(),(0,i.j4)(N,{key:0,icon:"texture",outline:"",style:{color:"grey",width:"100%"},label:"加入白名单",onClick:e[5]||(e[5]=e=>t.add_to_white_hash_pre(t.processChainDetails.path,t.processChainDetails.md5))})):((0,i.wg)(),(0,i.j4)(N,{key:1,icon:"clear",outline:"",style:{color:"grey",width:"100%"},label:"从白名单中删除",onClick:e[6]||(e[6]=e=>t.delete_white_hash(t.processChainDetails.md5))}))])),_:1})])),_:1})])),_:1},8,["modelValue"])):(0,i.kq)("",!0)])),_:1})])),_:1},8,["modelValue","maximized"])],64)}var I=a(52),x=a.n(I),Z=a(2256);const K=(0,i.aZ)({name:"PageIndex",data:function(){return{addwhiteListHash:!1,whiteListPostData:{path:"",hash:"",reason:""},processChainShowDetails:!1,last_refresh:360,processChainDetails:{hash:"",prams:"",hitRules:[],hitAttck:[],isWhite:!1,whiteListReason:""},thumbStyle:{right:"4px",borderRadius:"5px",backgroundColor:"#027be3",width:"5px",opacity:.75},barStyle:{right:"2px",borderRadius:"9px",backgroundColor:"#027be3",width:"9px",opacity:.2},threatStatistics:{all:1,confirm:0,ingore:1,working:0},Threatitems:[{title:"发现的威胁",icon:"remove_red_eye",value:"200",color1:"#5064b5",color2:"#3e51b5"},{title:"确认的威胁",icon:"flash_on",value:"500",color1:"#f37169",color2:"#f34636"},{title:"忽略的威胁",icon:"texture",value:"50",color1:"#ea6a7f",color2:"#ea4b64"},{title:"进行中的威胁",icon:"bar_chart",value:"1020",color1:"#a270b1",color2:"#9f52b1"}],dialog:!1,maximizedToggle:!0,server_threat:{},select_chain_data:{}}},methods:{delete_white_hash(t){x().get("/api/v1/del/white_list?hash="+t).then((t=>{this.processChainDetails.isWhite=!1}))},query_white_hash(t){x().get("/api/v1/query/white_list?hash="+t).then((t=>{this.processChainDetails.isWhite=1===t.data.result}))},add_to_white_hash_pre(t,e){this.whiteListPostData={path:t,hash:e,reason:""},this.addwhiteListHash=!0,console.log("addwhiteListHash",this.addwhiteListHash)},add_to_white_hash_post(){x().post("/api/v1/set/white_list",this.whiteListPostData).then((t=>{this.processChainDetails.isWhite=!0}))},set_chain_data(t){if(t.path){const e=t.path.split("\\");t.name=e[e.length-1],console.log(t.name);for(const a in t.children)this.set_chain_data(t.children[a])}},draw_tree(){this.set_chain_data(this.select_chain_data);const t=this.$refs.main_draw,e=Z.S1(t),a={tooltip:{trigger:"item",triggerOn:"mousemove",formatter:function(t){const e=t.data;let a="参数: "+e.params+"
hash: "+e.md5+"
命名规则列表: ";0===e.operationlist.length&&(a+="无");for(const i in e.operationlist)a+=" "+i+"["+e.operationlist[i]+"] ";return a+="
",a}},series:[{roam:!0,type:"tree",id:0,name:"tree1",data:[this.select_chain_data],top:"5%",left:"15%",bottom:"22%",right:"20%",edgeShape:"polyline",edgeForkPosition:"63%",initialTreeDepth:60,lineStyle:{width:2},label:{backgroundColor:"#fff",position:"left",verticalAlign:"middle",align:"right"},leaves:{label:{position:"right",verticalAlign:"middle",align:"left"}},emphasis:{focus:"descendant"},symbolSize:[30,30],symbol:"image://",expandAndCollapse:!1,animationDuration:350,animationDurationUpdate:450}]};e.setOption(a),e.on("click",(t=>{const e=t.data;this.processChainDetails={path:e.path,active:e.active,md5:e.md5,name:e.name,params:e.params,pid:e.pid,ppid:e.ppid,hitRules:void 0===e.operationlist?{}:e.operationlist,hitAttck:void 0===e.attck_hit_list?{}:e.attck_hit_list,isWhite:!1},this.query_white_hash(e.md5),this.processChainShowDetails=!0}))},search_vt(t){window.open("https://www.virustotal.com/gui/search/"+t,"_blank")},delete_threat(t){x().get("/api/v1/get/process_chain/delete?id="+t,{"Content-Type":"application/json"}).then((t=>{this.get_clientids()}))},handle_threat(t,e){x().get("/api/v1/get/process_chain/handle?id="+t+"&handletype="+e,{"Content-Type":"application/json"}).then((t=>{this.get_clientids()}))},show_details(t){x().get("/api/v1/get/process_chain/pull?id="+t,{"Content-Type":"application/json"}).then((t=>{const e=t.data;e.data&&(this.select_chain_data=e.data.chain.process_node,this.dialog=!0,console.log("this.select_chain_data",this.select_chain_data),this.$nextTick((()=>{this.draw_tree()})))}))},get_threatStatistics(){x().get("/api/v1/get/threat_statistics",{"Content-Type":"application/json"}).then((t=>{const e=t.data;e.data&&(this.threatStatistics=e.data,this.Threatitems[0].value=this.threatStatistics.all,this.Threatitems[1].value=this.threatStatistics.confirm,this.Threatitems[2].value=this.threatStatistics.ingore,this.Threatitems[3].value=this.threatStatistics.working)}))},get_clientids(){const t=this.$route.params.queryIndex,e=null===t||void 0===t?0:t;x().get("/api/v1/get/process_chain/all?query_type="+e,{"Content-Type":"application/json"}).then((t=>{const e=t.data;e.data&&(this.server_threat={data:[]},this.server_threat.data=e.data,this.get_threatStatistics())}))}},mounted(){this.get_clientids(),setInterval((()=>{this.last_refresh-=1,this.last_refresh<=0&&(this.get_clientids(),this.last_refresh=360)}),1e3)},watch:{$route(t,e){this.get_clientids()}}});var E=a(4260),Y=a(151),z=a(5589),H=a(3414),j=a(2035),N=a(4554),O=a(2350),F=a(1432),L=a(3424),T=a(9367),X=a(7030),J=a(8240),P=a(6778),R=a(4842),G=a(846),M=a(2025),$=a(8870),tt=a(2901),et=a(7011),at=a(5869),it=a(677),lt=a(7518),st=a.n(lt);const ot=(0,E.Z)(K,[["render",S]]),nt=ot;st()(K,"components",{QCard:Y.Z,QCardSection:z.Z,QItem:H.Z,QItemSection:j.Z,QIcon:N.Z,QItemLabel:O.Z,QTimeline:F.Z,QTimelineEntry:L.Z,QCardActions:T.Z,QChip:X.Z,QBtn:J.Z,QDialog:P.Z,QInput:R.Z,QBar:G.Z,QSpace:M.Z,QTooltip:$.Z,QDrawer:tt.Z,QList:et.Z,QSeparator:at.Z}),st()(K,"directives",{ClosePopup:it.Z})}}]);
\ No newline at end of file
diff --git a/Server/templates/js/56.dc9e32b8.js.gz b/Server/templates/js/56.dc9e32b8.js.gz
new file mode 100644
index 0000000..a1bb863
Binary files /dev/null and b/Server/templates/js/56.dc9e32b8.js.gz differ
diff --git a/Server/templates/js/698.7639c919.js b/Server/templates/js/698.7639c919.js
deleted file mode 100644
index 70b6bc7..0000000
--- a/Server/templates/js/698.7639c919.js
+++ /dev/null
@@ -1 +0,0 @@
-"use strict";(globalThis["webpackChunksyseye"]=globalThis["webpackChunksyseye"]||[]).push([[698],{698:(t,e,a)=>{a.r(e),a.d(e,{default:()=>at});var i=a(3673),l=a(2323);const s={class:"q-gutter-md q-mb-sm q-pa-lg"},o={class:"row q-col-gutter-sm"},n={class:"row"},d=(0,i._)("div",{class:"col"},null,-1),r={class:"col"},h={class:"row q-gutter-md q-mb-sm q-pa-lg"},c={key:0},u=(0,i._)("div",{class:"bg-red-5"}," ",-1),p=(0,i.Uk)(" 分数: "),w=(0,i.Uk)(" 活动状态: "),m=(0,i.Uk)(" 产生的威胁: "),A=(0,i.Uk)(" 查看详情 "),g=(0,i.Uk)(" 在VT上搜索 "),_=(0,i.Uk)(" 确认威胁 "),C=(0,i.Uk)(" 忽略威胁 "),f=(0,i.Uk)(" 删除报警 "),k=(0,i._)("div",{class:"col"},null,-1),b=(0,i._)("div",{class:"text-h6"},"填写缘由",-1),v=(0,i.Uk)("Close"),W={class:"row",style:{width:"100%",height:"100%"}},B={ref:"main_draw",style:{width:"100%",height:"100%","margin-left":"5%"}},D=(0,i.Uk)("进程命中的规则: ");function Q(t,e,a,Q,U,q){const y=(0,i.up)("q-icon"),V=(0,i.up)("q-item-section"),S=(0,i.up)("q-item-label"),I=(0,i.up)("q-item"),x=(0,i.up)("q-card-section"),Z=(0,i.up)("q-card"),E=(0,i.up)("q-chip"),K=(0,i.up)("q-btn"),Y=(0,i.up)("q-card-actions"),z=(0,i.up)("q-timeline-entry"),H=(0,i.up)("q-timeline"),F=(0,i.up)("q-input"),N=(0,i.up)("q-dialog"),j=(0,i.up)("q-space"),L=(0,i.up)("q-tooltip"),O=(0,i.up)("q-bar"),X=(0,i.up)("q-separator"),T=(0,i.up)("q-list"),P=(0,i.up)("q-drawer"),J=(0,i.Q2)("close-popup");return(0,i.wg)(),(0,i.iD)(i.HY,null,[(0,i._)("div",null,[(0,i._)("div",s,[(0,i.Wm)(Z,{class:"bg-transparent no-shadow no-border"},{default:(0,i.w5)((()=>[(0,i.Wm)(x,{class:"q-pa-none"},{default:(0,i.w5)((()=>[(0,i._)("div",o,[((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(t.Threatitems,((t,e)=>((0,i.wg)(),(0,i.iD)("div",{key:e,class:"col-md-3 col-sm-12 col-xs-12"},[(0,i.Wm)(I,{style:(0,l.j5)(`background-color: ${t.color1}`),class:"q-pa-none"},{default:(0,i.w5)((()=>[(0,i.Wm)(V,{side:"",style:(0,l.j5)(`background-color: ${t.color2}`),class:"q-pa-lg q-mr-none text-white"},{default:(0,i.w5)((()=>[(0,i.Wm)(y,{name:t.icon,color:"white",size:"24px"},null,8,["name"])])),_:2},1032,["style"]),(0,i.Wm)(V,{class:"q-pa-md q-ml-none text-white"},{default:(0,i.w5)((()=>[(0,i.Wm)(S,{class:"text-white text-h6 text-weight-bolder"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(t.value),1)])),_:2},1024),(0,i.Wm)(S,null,{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(t.title),1)])),_:2},1024)])),_:2},1024)])),_:2},1032,["style"])])))),128))])])),_:1})])),_:1})]),(0,i._)("div",n,[d,(0,i._)("div",r,[(0,i._)("div",h,[(0,i.Wm)(H,{layout:"dense",side:"right",color:"red"},{default:(0,i.w5)((()=>[t.server_threat.data&&0!=t.server_threat.data.length?(0,i.kq)("",!0):((0,i.wg)(),(0,i.iD)("h4",c,"暂无可用数据,下次刷新时间 "+(0,l.zw)(t.last_refresh)+"...",1)),((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(t.server_threat.data,((e,a)=>((0,i.wg)(),(0,i.j4)(z,{key:a,subtitle:"主机:"+e.host,side:"left"},{default:(0,i.w5)((()=>[(0,i._)("div",null,[(0,i.Wm)(Z,{flat:"",bordered:"",style:{overflow:"auto"},"thumb-style":t.thumbStyle,"bar-style":t.barStyle},{default:(0,i.w5)((()=>[(0,i.Wm)(x,{horizontal:""},{default:(0,i.w5)((()=>[u,(0,i.Wm)(Y,{vertical:"",class:"justify-around q-px-md"},{default:(0,i.w5)((()=>[(0,i._)("div",null,"进程链hash: "+(0,l.zw)(e.chain_hash),1),(0,i._)("div",null,"进程: "+(0,l.zw)(e.start_process.path),1),(0,i._)("div",null,"用户: "+(0,l.zw)(e.start_process.user),1),(0,i._)("div",null,[p,(0,i.Wm)(E,{square:"",color:"orange","text-color":"white","icon-right":"visibility"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(e.risk_score),1)])),_:2},1024)]),(0,i._)("div",null,[w,(0,i.Wm)(E,{square:"",color:1==e.is_end?"negative":"red","text-color":"white"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(1==e.is_end?"已结束":"进行中"),1)])),_:2},1032,["color"])]),(0,i._)("div",null,[m,((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(e.hit_rule,((t,e)=>((0,i.wg)(),(0,i.j4)(E,{key:t,square:"",color:"rgb(239,243,246)"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(e)+" ("+(0,l.zw)(t)+") ",1)])),_:2},1024)))),128))]),(0,i._)("div",null,[(0,i.Wm)(K,{flat:"",color:"accent",onClick:a=>t.show_details(e.id),icon:"open_in_new"},{default:(0,i.w5)((()=>[A])),_:2},1032,["onClick"]),(0,i.Wm)(K,{flat:"",color:"accent",onClick:a=>t.search_vt(e.start_process.hash),icon:"search"},{default:(0,i.w5)((()=>[g])),_:2},1032,["onClick"]),(0,i.Wm)(K,{flat:"",color:"accent",onClick:a=>t.handle_threat(e.id,1),icon:"done"},{default:(0,i.w5)((()=>[_])),_:2},1032,["onClick"]),(0,i.Wm)(K,{flat:"",color:"accent",onClick:a=>t.handle_threat(e.id,2),icon:"texture"},{default:(0,i.w5)((()=>[C])),_:2},1032,["onClick"]),(0,i.Wm)(K,{flat:"",color:"accent",icon:"close",onClick:a=>t.delete_threat(e.id)},{default:(0,i.w5)((()=>[f])),_:2},1032,["onClick"])])])),_:2},1024)])),_:2},1024)])),_:2},1032,["thumb-style","bar-style"])])])),_:2},1032,["subtitle"])))),128))])),_:1})])]),k])]),(0,i.Wm)(N,{modelValue:t.addwhiteListHash,"onUpdate:modelValue":e[3]||(e[3]=e=>t.addwhiteListHash=e),persistent:"","transition-show":"scale","transition-hide":"scale"},{default:(0,i.w5)((()=>[(0,i.Wm)(Z,{style:{"min-width":"350px"}},{default:(0,i.w5)((()=>[(0,i.Wm)(x,null,{default:(0,i.w5)((()=>[b])),_:1}),(0,i.Wm)(x,{class:"q-pt-none"},{default:(0,i.w5)((()=>[(0,i.Wm)(F,{dense:"",modelValue:this.whiteListPostData.reason,"onUpdate:modelValue":e[0]||(e[0]=t=>this.whiteListPostData.reason=t),autofocus:""},null,8,["modelValue"])])),_:1}),(0,i.Wm)(Y,{align:"right",class:"text-primary"},{default:(0,i.w5)((()=>[(0,i.wy)((0,i.Wm)(K,{flat:"",label:"取消",onClick:e[1]||(e[1]=e=>t.addwhiteListHash=!1)},null,512),[[J]]),(0,i.wy)((0,i.Wm)(K,{flat:"",label:"加入白名单",onClick:e[2]||(e[2]=e=>t.add_to_white_hash_post())},null,512),[[J]])])),_:1})])),_:1})])),_:1},8,["modelValue"]),(0,i.Wm)(N,{modelValue:t.dialog,"onUpdate:modelValue":e[8]||(e[8]=e=>t.dialog=e),persistent:"",maximized:t.maximizedToggle,"transition-show":"slide-up","transition-hide":"slide-down"},{default:(0,i.w5)((()=>[(0,i.Wm)(Z,{class:"text-white"},{default:(0,i.w5)((()=>[(0,i.Wm)(O,null,{default:(0,i.w5)((()=>[(0,i.Wm)(j),(0,i.wy)(((0,i.wg)(),(0,i.j4)(K,{dense:"",flat:"",icon:"close"},{default:(0,i.w5)((()=>[(0,i.Wm)(L,{"content-class":"bg-white text-primary"},{default:(0,i.w5)((()=>[v])),_:1})])),_:1})),[[J]])])),_:1}),(0,i._)("div",W,[(0,i._)("div",B," 1 ",512)]),t.processChainShowDetails?((0,i.wg)(),(0,i.j4)(P,{key:0,"show-if-above":"",modelValue:t.processChainShowDetails,"onUpdate:modelValue":e[7]||(e[7]=e=>t.processChainShowDetails=e),side:"right",bordered:"",width:"350",class:"text-dark"},{default:(0,i.w5)((()=>[(0,i.Wm)(T,{style:{width:"100%","word-break":"break-all"}},{default:(0,i.w5)((()=>[(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[(0,i.Uk)("活跃状态: "+(0,l.zw)(t.processChainDetails.active?"运行中":"已结束"),1)])),_:1})])),_:1}),(0,i.Wm)(X),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程名字: "+(0,l.zw)(t.processChainDetails.name),1)])),_:1})])),_:1}),(0,i.Wm)(X),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程路径: "+(0,l.zw)(t.processChainDetails.path),1)])),_:1})])),_:1}),(0,i.Wm)(X),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程参数: "+(0,l.zw)(t.processChainDetails.params),1)])),_:1})])),_:1}),(0,i.Wm)(X),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程id: "+(0,l.zw)(t.processChainDetails.pid),1)])),_:1})])),_:1}),(0,i.Wm)(X),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[(0,i.Uk)("父进程id: "+(0,l.zw)(t.processChainDetails.ppid),1)])),_:1})])),_:1}),(0,i.Wm)(X),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[(0,i.Uk)("进程hash: "+(0,l.zw)(t.processChainDetails.md5),1)])),_:1})])),_:1}),(0,i.Wm)(X),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[(0,i.Uk)("是否在白名单中: "+(0,l.zw)(t.processChainDetails.isWhite?"是":"否"),1)])),_:1})])),_:1}),(0,i.Wm)(X),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(V,null,{default:(0,i.w5)((()=>[D,((0,i.wg)(!0),(0,i.iD)(i.HY,null,(0,i.Ko)(t.processChainDetails.hitRules,((t,e)=>((0,i.wg)(),(0,i.j4)(E,{key:t,square:"",color:"rgb(239,243,246)"},{default:(0,i.w5)((()=>[(0,i.Uk)((0,l.zw)(e)+" ("+(0,l.zw)(t)+") ",1)])),_:2},1024)))),128))])),_:1})])),_:1}),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[(0,i.Wm)(K,{icon:"search",outline:"",style:{color:"grey",width:"100%"},label:"搜索hash",onClick:e[4]||(e[4]=e=>t.search_vt(t.processChainDetails.md5))})])),_:1}),(0,i.Wm)(I,null,{default:(0,i.w5)((()=>[0==t.processChainDetails.isWhite?((0,i.wg)(),(0,i.j4)(K,{key:0,icon:"texture",outline:"",style:{color:"grey",width:"100%"},label:"加入白名单",onClick:e[5]||(e[5]=e=>t.add_to_white_hash_pre(t.processChainDetails.path,t.processChainDetails.md5))})):((0,i.wg)(),(0,i.j4)(K,{key:1,icon:"clear",outline:"",style:{color:"grey",width:"100%"},label:"从白名单中删除",onClick:e[6]||(e[6]=e=>t.delete_white_hash(t.processChainDetails.md5))}))])),_:1})])),_:1})])),_:1},8,["modelValue"])):(0,i.kq)("",!0)])),_:1})])),_:1},8,["modelValue","maximized"])],64)}var U=a(52),q=a.n(U),y=a(2256);const V=(0,i.aZ)({name:"PageIndex",data:function(){return{addwhiteListHash:!1,whiteListPostData:{path:"",hash:"",reason:""},processChainShowDetails:!1,last_refresh:360,processChainDetails:{hash:"",prams:"",hitRule:[],isWhite:!1,whiteListReason:""},thumbStyle:{right:"4px",borderRadius:"5px",backgroundColor:"#027be3",width:"5px",opacity:.75},barStyle:{right:"2px",borderRadius:"9px",backgroundColor:"#027be3",width:"9px",opacity:.2},threatStatistics:{all:1,confirm:0,ingore:1,working:0},Threatitems:[{title:"发现的威胁",icon:"remove_red_eye",value:"200",color1:"#5064b5",color2:"#3e51b5"},{title:"确认的威胁",icon:"flash_on",value:"500",color1:"#f37169",color2:"#f34636"},{title:"忽略的威胁",icon:"texture",value:"50",color1:"#ea6a7f",color2:"#ea4b64"},{title:"进行中的威胁",icon:"bar_chart",value:"1020",color1:"#a270b1",color2:"#9f52b1"}],dialog:!1,maximizedToggle:!0,server_threat:{},select_chain_data:{}}},methods:{delete_white_hash(t){q().get("/api/v1/del/white_list?hash="+t).then((t=>{this.processChainDetails.isWhite=!1}))},query_white_hash(t){q().get("/api/v1/query/white_list?hash="+t).then((t=>{this.processChainDetails.isWhite=1===t.data.result}))},add_to_white_hash_pre(t,e){this.whiteListPostData={path:t,hash:e,reason:""},this.addwhiteListHash=!0,console.log("addwhiteListHash",this.addwhiteListHash)},add_to_white_hash_post(){q().post("/api/v1/set/white_list",this.whiteListPostData).then((t=>{this.processChainDetails.isWhite=!0}))},set_chain_data(t){if(t.path){const e=t.path.split("\\");t.name=e[e.length-1],console.log(t.name);for(const a in t.children)this.set_chain_data(t.children[a])}},draw_tree(){this.set_chain_data(this.select_chain_data);const t=this.$refs.main_draw,e=y.S1(t),a={tooltip:{trigger:"item",triggerOn:"mousemove",formatter:function(t){const e=t.data;let a="参数: "+e.params+"
hash: "+e.md5+"
命名规则列表: ";0===e.operationlist.length&&(a+="无");for(const i in e.operationlist)a+=" "+i+"["+e.operationlist[i]+"] ";return a+="
",a}},series:[{roam:!0,type:"tree",id:0,name:"tree1",data:[this.select_chain_data],top:"5%",left:"15%",bottom:"22%",right:"20%",edgeShape:"polyline",edgeForkPosition:"63%",initialTreeDepth:60,lineStyle:{width:2},label:{backgroundColor:"#fff",position:"left",verticalAlign:"middle",align:"right"},leaves:{label:{position:"right",verticalAlign:"middle",align:"left"}},emphasis:{focus:"descendant"},symbolSize:[30,30],symbol:"image://",expandAndCollapse:!1,animationDuration:350,animationDurationUpdate:450}]};e.setOption(a),e.on("click",(t=>{const e=t.data;this.processChainDetails={path:e.path,active:e.active,md5:e.md5,name:e.name,params:e.params,pid:e.pid,ppid:e.ppid,hitRules:e.operationlist,isWhite:!1},this.query_white_hash(e.md5),this.processChainShowDetails=!0}))},search_vt(t){window.open("https://www.virustotal.com/gui/search/"+t,"_blank")},delete_threat(t){q().get("/api/v1/get/process_chain/delete?id="+t,{"Content-Type":"application/json"}).then((t=>{this.get_clientids()}))},handle_threat(t,e){q().get("/api/v1/get/process_chain/handle?id="+t+"&handletype="+e,{"Content-Type":"application/json"}).then((t=>{this.get_clientids()}))},show_details(t){q().get("/api/v1/get/process_chain/pull?id="+t,{"Content-Type":"application/json"}).then((t=>{const e=t.data;e.data&&(this.select_chain_data=e.data.chain.process_node,this.dialog=!0,console.log("this.select_chain_data",this.select_chain_data),this.$nextTick((()=>{this.draw_tree()})))}))},get_threatStatistics(){q().get("/api/v1/get/threat_statistics",{"Content-Type":"application/json"}).then((t=>{const e=t.data;e.data&&(this.threatStatistics=e.data,this.Threatitems[0].value=this.threatStatistics.all,this.Threatitems[1].value=this.threatStatistics.confirm,this.Threatitems[2].value=this.threatStatistics.ingore,this.Threatitems[3].value=this.threatStatistics.working)}))},get_clientids(){const t=this.$route.params.queryIndex,e=null===t||void 0===t?0:t;q().get("/api/v1/get/process_chain/all?query_type="+e,{"Content-Type":"application/json"}).then((t=>{const e=t.data;e.data&&(this.server_threat={data:[]},this.server_threat.data=e.data,this.get_threatStatistics())}))}},mounted(){this.get_clientids(),setInterval((()=>{this.last_refresh-=1,this.last_refresh<=0&&(this.get_clientids(),this.last_refresh=360)}),1e3)},watch:{$route(t,e){this.get_clientids()}}});var S=a(4260),I=a(151),x=a(5589),Z=a(3414),E=a(2035),K=a(4554),Y=a(2350),z=a(1432),H=a(3424),F=a(9367),N=a(7030),j=a(8240),L=a(6778),O=a(4842),X=a(846),T=a(2025),P=a(8870),J=a(2901),R=a(7011),G=a(5869),M=a(677),$=a(7518),tt=a.n($);const et=(0,S.Z)(V,[["render",Q]]),at=et;tt()(V,"components",{QCard:I.Z,QCardSection:x.Z,QItem:Z.Z,QItemSection:E.Z,QIcon:K.Z,QItemLabel:Y.Z,QTimeline:z.Z,QTimelineEntry:H.Z,QCardActions:F.Z,QChip:N.Z,QBtn:j.Z,QDialog:L.Z,QInput:O.Z,QBar:X.Z,QSpace:T.Z,QTooltip:P.Z,QDrawer:J.Z,QList:R.Z,QSeparator:G.Z}),tt()(V,"directives",{ClosePopup:M.Z})}}]);
\ No newline at end of file
diff --git a/Server/templates/js/698.7639c919.js.gz b/Server/templates/js/698.7639c919.js.gz
deleted file mode 100644
index b71265d..0000000
Binary files a/Server/templates/js/698.7639c919.js.gz and /dev/null differ
diff --git a/Server/templates/js/app.8fbb593d.js b/Server/templates/js/app.8fbb593d.js
deleted file mode 100644
index 329416f..0000000
--- a/Server/templates/js/app.8fbb593d.js
+++ /dev/null
@@ -1 +0,0 @@
-(()=>{"use strict";var e={9942:(e,t,r)=>{var n=r(8880),o=r(9782),a=r(3673);function i(e,t,r,n,o,i){const s=(0,a.up)("router-view");return(0,a.wg)(),(0,a.j4)(s)}const s=(0,a.aZ)({name:"App"});var l=r(4260);const c=(0,l.Z)(s,[["render",i]]),d=c;var u=r(3340),p=r(8339);r(71);const h=[{path:"/",component:()=>Promise.all([r.e(736),r.e(69)]).then(r.bind(r,2069)),children:[{path:"",component:()=>Promise.all([r.e(736),r.e(698)]).then(r.bind(r,698))}]},{path:"/page",component:()=>Promise.all([r.e(736),r.e(69)]).then(r.bind(r,2069)),children:[{path:"dashboard",component:()=>r.e(904).then(r.bind(r,6904))},{path:"index",name:"index",component:()=>Promise.all([r.e(736),r.e(698)]).then(r.bind(r,698))},{path:"index",name:"whitelist",component:()=>Promise.all([r.e(736),r.e(219)]).then(r.bind(r,4219))}]},{path:"/:catchAll(.*)*",component:()=>Promise.all([r.e(736),r.e(193)]).then(r.bind(r,2193))}],f=h,m=(0,u.BC)((function(){const e=p.r5,t=(0,p.p7)({scrollBehavior:()=>({left:0,top:0}),routes:f,history:e("")});return t}));async function v(e,t){const r="function"===typeof m?await m({}):m,n=e(d);return n.use(o.Z,t),{app:n,router:r}}const b={config:{}};async function g({app:e,router:t}){e.use(t),e.mount("#q-app")}v(n.ri,b).then(g)}},t={};function r(n){var o=t[n];if(void 0!==o)return o.exports;var a=t[n]={exports:{}};return e[n](a,a.exports,r),a.exports}r.m=e,(()=>{var e=[];r.O=(t,n,o,a)=>{if(!n){var i=1/0;for(d=0;d=a)&&Object.keys(r.O).every((e=>r.O[e](n[l])))?n.splice(l--,1):(s=!1,a0&&e[d-1][2]>a;d--)e[d]=e[d-1];e[d]=[n,o,a]}})(),(()=>{r.n=e=>{var t=e&&e.__esModule?()=>e["default"]:()=>e;return r.d(t,{a:t}),t}})(),(()=>{r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})}})(),(()=>{r.f={},r.e=e=>Promise.all(Object.keys(r.f).reduce(((t,n)=>(r.f[n](e,t),t)),[]))})(),(()=>{r.u=e=>"js/"+e+"."+{69:"c1368261",193:"cfdf09ec",219:"1dcc27ca",698:"7639c919",904:"f590aa3d"}[e]+".js"})(),(()=>{r.miniCssF=e=>"css/"+({143:"app",736:"vendor"}[e]||e)+"."+{69:"8be8f613",143:"31d6cfe0",736:"5b8581f0"}[e]+".css"})(),(()=>{r.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}()})(),(()=>{r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t)})(),(()=>{var e={},t="syseye:";r.l=(n,o,a,i)=>{if(e[n])e[n].push(o);else{var s,l;if(void 0!==a)for(var c=document.getElementsByTagName("script"),d=0;d{s.onerror=s.onload=null,clearTimeout(h);var o=e[n];if(delete e[n],s.parentNode&&s.parentNode.removeChild(s),o&&o.forEach((e=>e(r))),t)return t(r)},h=setTimeout(p.bind(null,void 0,{type:"timeout",target:s}),12e4);s.onerror=p.bind(null,s.onerror),s.onload=p.bind(null,s.onload),l&&document.head.appendChild(s)}}})(),(()=>{r.r=e=>{"undefined"!==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}})(),(()=>{r.p=""})(),(()=>{var e=(e,t,r,n)=>{var o=document.createElement("link");o.rel="stylesheet",o.type="text/css";var a=a=>{if(o.onerror=o.onload=null,"load"===a.type)r();else{var i=a&&("load"===a.type?"missing":a.type),s=a&&a.target&&a.target.href||t,l=new Error("Loading CSS chunk "+e+" failed.\n("+s+")");l.code="CSS_CHUNK_LOAD_FAILED",l.type=i,l.request=s,o.parentNode.removeChild(o),n(l)}};return o.onerror=o.onload=a,o.href=t,document.head.appendChild(o),o},t=(e,t)=>{for(var r=document.getElementsByTagName("link"),n=0;nnew Promise(((o,a)=>{var i=r.miniCssF(n),s=r.p+i;if(t(i,s))return o();e(n,s,o,a)})),o={143:0};r.f.miniCss=(e,t)=>{var r={69:1};o[e]?t.push(o[e]):0!==o[e]&&r[e]&&t.push(o[e]=n(e).then((()=>{o[e]=0}),(t=>{throw delete o[e],t})))}})(),(()=>{var e={143:0};r.f.j=(t,n)=>{var o=r.o(e,t)?e[t]:void 0;if(0!==o)if(o)n.push(o[2]);else{var a=new Promise(((r,n)=>o=e[t]=[r,n]));n.push(o[2]=a);var i=r.p+r.u(t),s=new Error,l=n=>{if(r.o(e,t)&&(o=e[t],0!==o&&(e[t]=void 0),o)){var a=n&&("load"===n.type?"missing":n.type),i=n&&n.target&&n.target.src;s.message="Loading chunk "+t+" failed.\n("+a+": "+i+")",s.name="ChunkLoadError",s.type=a,s.request=i,o[1](s)}};r.l(i,l,"chunk-"+t,t)}},r.O.j=t=>0===e[t];var t=(t,n)=>{var o,a,[i,s,l]=n,c=0;if(i.some((t=>0!==e[t]))){for(o in s)r.o(s,o)&&(r.m[o]=s[o]);if(l)var d=l(r)}for(t&&t(n);cr(9942)));n=r.O(n)})();
\ No newline at end of file
diff --git a/Server/templates/js/app.b7308b45.js b/Server/templates/js/app.b7308b45.js
new file mode 100644
index 0000000..d907371
--- /dev/null
+++ b/Server/templates/js/app.b7308b45.js
@@ -0,0 +1 @@
+(()=>{"use strict";var e={9942:(e,t,r)=>{var n=r(8880),o=r(9782),a=r(3673);function i(e,t,r,n,o,i){const s=(0,a.up)("router-view");return(0,a.wg)(),(0,a.j4)(s)}const s=(0,a.aZ)({name:"App"});var l=r(4260);const d=(0,l.Z)(s,[["render",i]]),c=d;var u=r(3340),p=r(8339);r(71);const h=[{path:"/",component:()=>Promise.all([r.e(736),r.e(69)]).then(r.bind(r,2069)),children:[{path:"",component:()=>Promise.all([r.e(736),r.e(56)]).then(r.bind(r,8056))}]},{path:"/page",component:()=>Promise.all([r.e(736),r.e(69)]).then(r.bind(r,2069)),children:[{path:"dashboard",component:()=>r.e(904).then(r.bind(r,6904))},{path:"index",name:"index",component:()=>Promise.all([r.e(736),r.e(56)]).then(r.bind(r,8056))},{path:"index",name:"whitelist",component:()=>Promise.all([r.e(736),r.e(219)]).then(r.bind(r,4219))}]},{path:"/:catchAll(.*)*",component:()=>Promise.all([r.e(736),r.e(193)]).then(r.bind(r,2193))}],f=h,m=(0,u.BC)((function(){const e=p.r5,t=(0,p.p7)({scrollBehavior:()=>({left:0,top:0}),routes:f,history:e("")});return t}));async function v(e,t){const r="function"===typeof m?await m({}):m,n=e(c);return n.use(o.Z,t),{app:n,router:r}}const b={config:{}};async function g({app:e,router:t}){e.use(t),e.mount("#q-app")}v(n.ri,b).then(g)}},t={};function r(n){var o=t[n];if(void 0!==o)return o.exports;var a=t[n]={exports:{}};return e[n](a,a.exports,r),a.exports}r.m=e,(()=>{var e=[];r.O=(t,n,o,a)=>{if(!n){var i=1/0;for(c=0;c=a)&&Object.keys(r.O).every((e=>r.O[e](n[l])))?n.splice(l--,1):(s=!1,a0&&e[c-1][2]>a;c--)e[c]=e[c-1];e[c]=[n,o,a]}})(),(()=>{r.n=e=>{var t=e&&e.__esModule?()=>e["default"]:()=>e;return r.d(t,{a:t}),t}})(),(()=>{r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})}})(),(()=>{r.f={},r.e=e=>Promise.all(Object.keys(r.f).reduce(((t,n)=>(r.f[n](e,t),t)),[]))})(),(()=>{r.u=e=>"js/"+e+"."+{56:"dc9e32b8",69:"c1368261",193:"cfdf09ec",219:"1dcc27ca",904:"f590aa3d"}[e]+".js"})(),(()=>{r.miniCssF=e=>"css/"+({143:"app",736:"vendor"}[e]||e)+"."+{69:"8be8f613",143:"31d6cfe0",736:"5b8581f0"}[e]+".css"})(),(()=>{r.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}()})(),(()=>{r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t)})(),(()=>{var e={},t="syseye:";r.l=(n,o,a,i)=>{if(e[n])e[n].push(o);else{var s,l;if(void 0!==a)for(var d=document.getElementsByTagName("script"),c=0;c{s.onerror=s.onload=null,clearTimeout(h);var o=e[n];if(delete e[n],s.parentNode&&s.parentNode.removeChild(s),o&&o.forEach((e=>e(r))),t)return t(r)},h=setTimeout(p.bind(null,void 0,{type:"timeout",target:s}),12e4);s.onerror=p.bind(null,s.onerror),s.onload=p.bind(null,s.onload),l&&document.head.appendChild(s)}}})(),(()=>{r.r=e=>{"undefined"!==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}})(),(()=>{r.p=""})(),(()=>{var e=(e,t,r,n)=>{var o=document.createElement("link");o.rel="stylesheet",o.type="text/css";var a=a=>{if(o.onerror=o.onload=null,"load"===a.type)r();else{var i=a&&("load"===a.type?"missing":a.type),s=a&&a.target&&a.target.href||t,l=new Error("Loading CSS chunk "+e+" failed.\n("+s+")");l.code="CSS_CHUNK_LOAD_FAILED",l.type=i,l.request=s,o.parentNode.removeChild(o),n(l)}};return o.onerror=o.onload=a,o.href=t,document.head.appendChild(o),o},t=(e,t)=>{for(var r=document.getElementsByTagName("link"),n=0;nnew Promise(((o,a)=>{var i=r.miniCssF(n),s=r.p+i;if(t(i,s))return o();e(n,s,o,a)})),o={143:0};r.f.miniCss=(e,t)=>{var r={69:1};o[e]?t.push(o[e]):0!==o[e]&&r[e]&&t.push(o[e]=n(e).then((()=>{o[e]=0}),(t=>{throw delete o[e],t})))}})(),(()=>{var e={143:0};r.f.j=(t,n)=>{var o=r.o(e,t)?e[t]:void 0;if(0!==o)if(o)n.push(o[2]);else{var a=new Promise(((r,n)=>o=e[t]=[r,n]));n.push(o[2]=a);var i=r.p+r.u(t),s=new Error,l=n=>{if(r.o(e,t)&&(o=e[t],0!==o&&(e[t]=void 0),o)){var a=n&&("load"===n.type?"missing":n.type),i=n&&n.target&&n.target.src;s.message="Loading chunk "+t+" failed.\n("+a+": "+i+")",s.name="ChunkLoadError",s.type=a,s.request=i,o[1](s)}};r.l(i,l,"chunk-"+t,t)}},r.O.j=t=>0===e[t];var t=(t,n)=>{var o,a,[i,s,l]=n,d=0;if(i.some((t=>0!==e[t]))){for(o in s)r.o(s,o)&&(r.m[o]=s[o]);if(l)var c=l(r)}for(t&&t(n);dr(9942)));n=r.O(n)})();
\ No newline at end of file
diff --git a/Server/webserver.py b/Server/webserver.py
index 8135559..d420808 100644
--- a/Server/webserver.py
+++ b/Server/webserver.py
@@ -155,8 +155,9 @@ def pull_chain_data():
"type": threat_data[3],
"risk_score": threat_data[4],
"hit_rule": json.loads(threat_data[5]),
- "chain": json.loads(threat_data[6]),
- "is_end": threat_data[7],
+ "hit_attck": json.loads(threat_data[6]),
+ "chain": json.loads(threat_data[7]),
+ "is_end": threat_data[8],
}
return {"data": return_data}
@@ -181,6 +182,7 @@ def process_chain():
"id": iter[6],
"is_end": iter[7],
"start_process": json.loads(iter[8]),
+ "attck_hit_list": json.loads(iter[10]),
}
)
return {"data": return_data}
diff --git a/Web/syseye/src/pages/Index.vue b/Web/syseye/src/pages/Index.vue
index 7d4f973..8b55a6e 100644
--- a/Web/syseye/src/pages/Index.vue
+++ b/Web/syseye/src/pages/Index.vue
@@ -52,13 +52,27 @@
- 产生的威胁:
-
+ ATTCK命中:
+
{{ operation }} ({{ index }})
+
+ 产生的威胁:
+
+
+ {{ operation }} ({{ index }})
+
+
+
+
+
+ 机器学习引擎
+
+
+
查看详情
@@ -152,11 +166,32 @@
- 进程命中的规则:
+ 进程命中的规则:
+
{{ operation }} ({{ index }})
-
+
+
+
+ 无
+
+
+
+
+
+ attck矩阵:
+
+
+ {{ operation }} ({{ index }})
+
+
+
+
+ 无
+
+
+
@@ -197,7 +232,8 @@ export default defineComponent({
processChainDetails: {
hash: '',
prams: '',
- hitRule: [],
+ hitRules: [],
+ hitAttck: [],
isWhite: false,
whiteListReason: ''
},
@@ -371,7 +407,8 @@ export default defineComponent({
params: data.params,
pid: data.pid,
ppid: data.ppid,
- hitRules: data.operationlist,
+ hitRules: data.operationlist === undefined ? {} : data.operationlist,
+ hitAttck: data.attck_hit_list === undefined ? {} : data.attck_hit_list,
isWhite: false
}
this.query_white_hash(data.md5)
diff --git a/sysmon.xml b/sysmon.xml
index c5f2b75..dcffde9 100644
--- a/sysmon.xml
+++ b/sysmon.xml
@@ -353,6 +353,8 @@
nmap.exe
psinfo.exe
+ 80
+ 443
22
23
25