@ai-jshook/mcp 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +38 -0
- package/CLAUDE.md +170 -0
- package/README.md +564 -0
- package/bun.lock +1484 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +57 -0
- package/dist/index.js.map +1 -0
- package/dist/modules/analyzer/AISummarizer.d.ts +41 -0
- package/dist/modules/analyzer/AISummarizer.d.ts.map +1 -0
- package/dist/modules/analyzer/AISummarizer.js +186 -0
- package/dist/modules/analyzer/AISummarizer.js.map +1 -0
- package/dist/modules/analyzer/CodeAnalyzer.d.ts +28 -0
- package/dist/modules/analyzer/CodeAnalyzer.d.ts.map +1 -0
- package/dist/modules/analyzer/CodeAnalyzer.js +1287 -0
- package/dist/modules/analyzer/CodeAnalyzer.js.map +1 -0
- package/dist/modules/analyzer/IntelligentAnalyzer.d.ts +114 -0
- package/dist/modules/analyzer/IntelligentAnalyzer.d.ts.map +1 -0
- package/dist/modules/analyzer/IntelligentAnalyzer.js +1176 -0
- package/dist/modules/analyzer/IntelligentAnalyzer.js.map +1 -0
- package/dist/modules/browser/BrowserModeManager.d.ts +31 -0
- package/dist/modules/browser/BrowserModeManager.d.ts.map +1 -0
- package/dist/modules/browser/BrowserModeManager.js +241 -0
- package/dist/modules/browser/BrowserModeManager.js.map +1 -0
- package/dist/modules/captcha/AICaptchaDetector.d.ts +32 -0
- package/dist/modules/captcha/AICaptchaDetector.d.ts.map +1 -0
- package/dist/modules/captcha/AICaptchaDetector.js +387 -0
- package/dist/modules/captcha/AICaptchaDetector.js.map +1 -0
- package/dist/modules/captcha/CaptchaDetector.d.ts +28 -0
- package/dist/modules/captcha/CaptchaDetector.d.ts.map +1 -0
- package/dist/modules/captcha/CaptchaDetector.js +513 -0
- package/dist/modules/captcha/CaptchaDetector.js.map +1 -0
- package/dist/modules/collector/CodeCache.d.ts +37 -0
- package/dist/modules/collector/CodeCache.d.ts.map +1 -0
- package/dist/modules/collector/CodeCache.js +188 -0
- package/dist/modules/collector/CodeCache.js.map +1 -0
- package/dist/modules/collector/CodeCollector.d.ts +107 -0
- package/dist/modules/collector/CodeCollector.d.ts.map +1 -0
- package/dist/modules/collector/CodeCollector.js +796 -0
- package/dist/modules/collector/CodeCollector.js.map +1 -0
- package/dist/modules/collector/CodeCompressor.d.ts +65 -0
- package/dist/modules/collector/CodeCompressor.d.ts.map +1 -0
- package/dist/modules/collector/CodeCompressor.js +245 -0
- package/dist/modules/collector/CodeCompressor.js.map +1 -0
- package/dist/modules/collector/DOMInspector.d.ts +51 -0
- package/dist/modules/collector/DOMInspector.d.ts.map +1 -0
- package/dist/modules/collector/DOMInspector.js +437 -0
- package/dist/modules/collector/DOMInspector.js.map +1 -0
- package/dist/modules/collector/PageController.d.ts +79 -0
- package/dist/modules/collector/PageController.d.ts.map +1 -0
- package/dist/modules/collector/PageController.js +287 -0
- package/dist/modules/collector/PageController.js.map +1 -0
- package/dist/modules/collector/SmartCodeCollector.d.ts +38 -0
- package/dist/modules/collector/SmartCodeCollector.d.ts.map +1 -0
- package/dist/modules/collector/SmartCodeCollector.js +208 -0
- package/dist/modules/collector/SmartCodeCollector.js.map +1 -0
- package/dist/modules/collector/StreamingCollector.d.ts +46 -0
- package/dist/modules/collector/StreamingCollector.d.ts.map +1 -0
- package/dist/modules/collector/StreamingCollector.js +127 -0
- package/dist/modules/collector/StreamingCollector.js.map +1 -0
- package/dist/modules/crypto/CryptoDetector.d.ts +22 -0
- package/dist/modules/crypto/CryptoDetector.d.ts.map +1 -0
- package/dist/modules/crypto/CryptoDetector.js +168 -0
- package/dist/modules/crypto/CryptoDetector.js.map +1 -0
- package/dist/modules/crypto/CryptoDetectorEnhanced.d.ts +31 -0
- package/dist/modules/crypto/CryptoDetectorEnhanced.d.ts.map +1 -0
- package/dist/modules/crypto/CryptoDetectorEnhanced.js +269 -0
- package/dist/modules/crypto/CryptoDetectorEnhanced.js.map +1 -0
- package/dist/modules/crypto/CryptoRules.d.ts +59 -0
- package/dist/modules/crypto/CryptoRules.d.ts.map +1 -0
- package/dist/modules/crypto/CryptoRules.js +234 -0
- package/dist/modules/crypto/CryptoRules.js.map +1 -0
- package/dist/modules/debugger/BlackboxManager.d.ts +14 -0
- package/dist/modules/debugger/BlackboxManager.d.ts.map +1 -0
- package/dist/modules/debugger/BlackboxManager.js +98 -0
- package/dist/modules/debugger/BlackboxManager.js.map +1 -0
- package/dist/modules/debugger/DebuggerManager.d.ts +138 -0
- package/dist/modules/debugger/DebuggerManager.d.ts.map +1 -0
- package/dist/modules/debugger/DebuggerManager.js +777 -0
- package/dist/modules/debugger/DebuggerManager.js.map +1 -0
- package/dist/modules/debugger/EventBreakpointManager.d.ts +30 -0
- package/dist/modules/debugger/EventBreakpointManager.d.ts.map +1 -0
- package/dist/modules/debugger/EventBreakpointManager.js +125 -0
- package/dist/modules/debugger/EventBreakpointManager.js.map +1 -0
- package/dist/modules/debugger/RuntimeInspector.d.ts +54 -0
- package/dist/modules/debugger/RuntimeInspector.d.ts.map +1 -0
- package/dist/modules/debugger/RuntimeInspector.js +277 -0
- package/dist/modules/debugger/RuntimeInspector.js.map +1 -0
- package/dist/modules/debugger/ScriptManager.d.ts +94 -0
- package/dist/modules/debugger/ScriptManager.d.ts.map +1 -0
- package/dist/modules/debugger/ScriptManager.js +433 -0
- package/dist/modules/debugger/ScriptManager.js.map +1 -0
- package/dist/modules/debugger/WatchExpressionManager.d.ts +52 -0
- package/dist/modules/debugger/WatchExpressionManager.d.ts.map +1 -0
- package/dist/modules/debugger/WatchExpressionManager.js +136 -0
- package/dist/modules/debugger/WatchExpressionManager.js.map +1 -0
- package/dist/modules/debugger/XHRBreakpointManager.d.ts +21 -0
- package/dist/modules/debugger/XHRBreakpointManager.d.ts.map +1 -0
- package/dist/modules/debugger/XHRBreakpointManager.js +81 -0
- package/dist/modules/debugger/XHRBreakpointManager.js.map +1 -0
- package/dist/modules/deobfuscator/ASTOptimizer.d.ts +12 -0
- package/dist/modules/deobfuscator/ASTOptimizer.d.ts.map +1 -0
- package/dist/modules/deobfuscator/ASTOptimizer.js +234 -0
- package/dist/modules/deobfuscator/ASTOptimizer.js.map +1 -0
- package/dist/modules/deobfuscator/AdvancedDeobfuscator.d.ts +52 -0
- package/dist/modules/deobfuscator/AdvancedDeobfuscator.d.ts.map +1 -0
- package/dist/modules/deobfuscator/AdvancedDeobfuscator.js +985 -0
- package/dist/modules/deobfuscator/AdvancedDeobfuscator.js.map +1 -0
- package/dist/modules/deobfuscator/Deobfuscator.d.ts +23 -0
- package/dist/modules/deobfuscator/Deobfuscator.d.ts.map +1 -0
- package/dist/modules/deobfuscator/Deobfuscator.js +487 -0
- package/dist/modules/deobfuscator/Deobfuscator.js.map +1 -0
- package/dist/modules/deobfuscator/JSVMPDeobfuscator.d.ts +19 -0
- package/dist/modules/deobfuscator/JSVMPDeobfuscator.d.ts.map +1 -0
- package/dist/modules/deobfuscator/JSVMPDeobfuscator.js +594 -0
- package/dist/modules/deobfuscator/JSVMPDeobfuscator.js.map +1 -0
- package/dist/modules/deobfuscator/JScramberDeobfuscator.d.ts +28 -0
- package/dist/modules/deobfuscator/JScramberDeobfuscator.d.ts.map +1 -0
- package/dist/modules/deobfuscator/JScramberDeobfuscator.js +239 -0
- package/dist/modules/deobfuscator/JScramberDeobfuscator.js.map +1 -0
- package/dist/modules/deobfuscator/PackerDeobfuscator.d.ts +38 -0
- package/dist/modules/deobfuscator/PackerDeobfuscator.d.ts.map +1 -0
- package/dist/modules/deobfuscator/PackerDeobfuscator.js +191 -0
- package/dist/modules/deobfuscator/PackerDeobfuscator.js.map +1 -0
- package/dist/modules/detector/ObfuscationDetector.d.ts +35 -0
- package/dist/modules/detector/ObfuscationDetector.d.ts.map +1 -0
- package/dist/modules/detector/ObfuscationDetector.js +278 -0
- package/dist/modules/detector/ObfuscationDetector.js.map +1 -0
- package/dist/modules/emulator/AIEnvironmentAnalyzer.d.ts +32 -0
- package/dist/modules/emulator/AIEnvironmentAnalyzer.d.ts.map +1 -0
- package/dist/modules/emulator/AIEnvironmentAnalyzer.js +548 -0
- package/dist/modules/emulator/AIEnvironmentAnalyzer.js.map +1 -0
- package/dist/modules/emulator/BrowserAPIDatabase.d.ts +34 -0
- package/dist/modules/emulator/BrowserAPIDatabase.d.ts.map +1 -0
- package/dist/modules/emulator/BrowserAPIDatabase.js +326 -0
- package/dist/modules/emulator/BrowserAPIDatabase.js.map +1 -0
- package/dist/modules/emulator/BrowserEnvironmentRules.d.ts +47 -0
- package/dist/modules/emulator/BrowserEnvironmentRules.d.ts.map +1 -0
- package/dist/modules/emulator/BrowserEnvironmentRules.js +493 -0
- package/dist/modules/emulator/BrowserEnvironmentRules.js.map +1 -0
- package/dist/modules/emulator/EnvironmentEmulator.d.ts +27 -0
- package/dist/modules/emulator/EnvironmentEmulator.d.ts.map +1 -0
- package/dist/modules/emulator/EnvironmentEmulator.js +1113 -0
- package/dist/modules/emulator/EnvironmentEmulator.js.map +1 -0
- package/dist/modules/emulator/EnvironmentEmulatorEnhanced.d.ts +26 -0
- package/dist/modules/emulator/EnvironmentEmulatorEnhanced.d.ts.map +1 -0
- package/dist/modules/emulator/EnvironmentEmulatorEnhanced.js +493 -0
- package/dist/modules/emulator/EnvironmentEmulatorEnhanced.js.map +1 -0
- package/dist/modules/emulator/templates/chrome-env.d.ts +260 -0
- package/dist/modules/emulator/templates/chrome-env.d.ts.map +1 -0
- package/dist/modules/emulator/templates/chrome-env.js +253 -0
- package/dist/modules/emulator/templates/chrome-env.js.map +1 -0
- package/dist/modules/hook/AIHookGenerator.d.ts +53 -0
- package/dist/modules/hook/AIHookGenerator.d.ts.map +1 -0
- package/dist/modules/hook/AIHookGenerator.js +353 -0
- package/dist/modules/hook/AIHookGenerator.js.map +1 -0
- package/dist/modules/hook/HookManager.d.ts +67 -0
- package/dist/modules/hook/HookManager.d.ts.map +1 -0
- package/dist/modules/hook/HookManager.js +1225 -0
- package/dist/modules/hook/HookManager.js.map +1 -0
- package/dist/modules/monitor/ConsoleMonitor.d.ts +140 -0
- package/dist/modules/monitor/ConsoleMonitor.d.ts.map +1 -0
- package/dist/modules/monitor/ConsoleMonitor.js +834 -0
- package/dist/modules/monitor/ConsoleMonitor.js.map +1 -0
- package/dist/modules/monitor/PerformanceMonitor.d.ts +65 -0
- package/dist/modules/monitor/PerformanceMonitor.d.ts.map +1 -0
- package/dist/modules/monitor/PerformanceMonitor.js +175 -0
- package/dist/modules/monitor/PerformanceMonitor.js.map +1 -0
- package/dist/modules/stealth/StealthScripts2025.d.ts +17 -0
- package/dist/modules/stealth/StealthScripts2025.d.ts.map +1 -0
- package/dist/modules/stealth/StealthScripts2025.js +274 -0
- package/dist/modules/stealth/StealthScripts2025.js.map +1 -0
- package/dist/modules/symbolic/JSVMPSymbolicExecutor.d.ts +69 -0
- package/dist/modules/symbolic/JSVMPSymbolicExecutor.d.ts.map +1 -0
- package/dist/modules/symbolic/JSVMPSymbolicExecutor.js +232 -0
- package/dist/modules/symbolic/JSVMPSymbolicExecutor.js.map +1 -0
- package/dist/modules/symbolic/SymbolicExecutor.d.ts +69 -0
- package/dist/modules/symbolic/SymbolicExecutor.d.ts.map +1 -0
- package/dist/modules/symbolic/SymbolicExecutor.js +346 -0
- package/dist/modules/symbolic/SymbolicExecutor.js.map +1 -0
- package/dist/server/AIHookToolDefinitions.d.ts +3 -0
- package/dist/server/AIHookToolDefinitions.d.ts.map +1 -0
- package/dist/server/AIHookToolDefinitions.js +284 -0
- package/dist/server/AIHookToolDefinitions.js.map +1 -0
- package/dist/server/AIHookToolHandlers.d.ts +50 -0
- package/dist/server/AIHookToolHandlers.d.ts.map +1 -0
- package/dist/server/AIHookToolHandlers.js +311 -0
- package/dist/server/AIHookToolHandlers.js.map +1 -0
- package/dist/server/AdvancedToolDefinitions.d.ts +3 -0
- package/dist/server/AdvancedToolDefinitions.d.ts.map +1 -0
- package/dist/server/AdvancedToolDefinitions.js +218 -0
- package/dist/server/AdvancedToolDefinitions.js.map +1 -0
- package/dist/server/AdvancedToolHandlers.d.ts +85 -0
- package/dist/server/AdvancedToolHandlers.d.ts.map +1 -0
- package/dist/server/AdvancedToolHandlers.js +431 -0
- package/dist/server/AdvancedToolHandlers.js.map +1 -0
- package/dist/server/BrowserToolDefinitions.d.ts +3 -0
- package/dist/server/BrowserToolDefinitions.d.ts.map +1 -0
- package/dist/server/BrowserToolDefinitions.js +841 -0
- package/dist/server/BrowserToolDefinitions.js.map +1 -0
- package/dist/server/BrowserToolHandlers.d.ts +290 -0
- package/dist/server/BrowserToolHandlers.d.ts.map +1 -0
- package/dist/server/BrowserToolHandlers.js +784 -0
- package/dist/server/BrowserToolHandlers.js.map +1 -0
- package/dist/server/CacheToolDefinitions.d.ts +3 -0
- package/dist/server/CacheToolDefinitions.d.ts.map +1 -0
- package/dist/server/CacheToolDefinitions.js +166 -0
- package/dist/server/CacheToolDefinitions.js.map +1 -0
- package/dist/server/DebuggerToolDefinitions.d.ts +3 -0
- package/dist/server/DebuggerToolDefinitions.d.ts.map +1 -0
- package/dist/server/DebuggerToolDefinitions.js +600 -0
- package/dist/server/DebuggerToolDefinitions.js.map +1 -0
- package/dist/server/DebuggerToolHandlers.d.ts +230 -0
- package/dist/server/DebuggerToolHandlers.d.ts.map +1 -0
- package/dist/server/DebuggerToolHandlers.js +935 -0
- package/dist/server/DebuggerToolHandlers.js.map +1 -0
- package/dist/server/MCPServer.d.ts +55 -0
- package/dist/server/MCPServer.d.ts.map +1 -0
- package/dist/server/MCPServer.js +1344 -0
- package/dist/server/MCPServer.js.map +1 -0
- package/dist/server/TokenBudgetToolDefinitions.d.ts +3 -0
- package/dist/server/TokenBudgetToolDefinitions.d.ts.map +1 -0
- package/dist/server/TokenBudgetToolDefinitions.js +114 -0
- package/dist/server/TokenBudgetToolDefinitions.js.map +1 -0
- package/dist/services/LLMService.d.ts +41 -0
- package/dist/services/LLMService.d.ts.map +1 -0
- package/dist/services/LLMService.js +792 -0
- package/dist/services/LLMService.js.map +1 -0
- package/dist/types/index.d.ts +527 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/AdaptiveDataSerializer.d.ts +27 -0
- package/dist/utils/AdaptiveDataSerializer.d.ts.map +1 -0
- package/dist/utils/AdaptiveDataSerializer.js +215 -0
- package/dist/utils/AdaptiveDataSerializer.js.map +1 -0
- package/dist/utils/CacheAdapters.d.ts +30 -0
- package/dist/utils/CacheAdapters.d.ts.map +1 -0
- package/dist/utils/CacheAdapters.js +83 -0
- package/dist/utils/CacheAdapters.js.map +1 -0
- package/dist/utils/TokenBudgetManager.d.ts +52 -0
- package/dist/utils/TokenBudgetManager.d.ts.map +1 -0
- package/dist/utils/TokenBudgetManager.js +190 -0
- package/dist/utils/TokenBudgetManager.js.map +1 -0
- package/dist/utils/UnifiedCacheManager.d.ts +55 -0
- package/dist/utils/UnifiedCacheManager.d.ts.map +1 -0
- package/dist/utils/UnifiedCacheManager.js +207 -0
- package/dist/utils/UnifiedCacheManager.js.map +1 -0
- package/dist/utils/cache.d.ts +13 -0
- package/dist/utils/cache.d.ts.map +1 -0
- package/dist/utils/cache.js +92 -0
- package/dist/utils/cache.js.map +1 -0
- package/dist/utils/config.d.ts +7 -0
- package/dist/utils/config.d.ts.map +1 -0
- package/dist/utils/config.js +93 -0
- package/dist/utils/config.js.map +1 -0
- package/dist/utils/detailedDataManager.d.ts +60 -0
- package/dist/utils/detailedDataManager.d.ts.map +1 -0
- package/dist/utils/detailedDataManager.js +204 -0
- package/dist/utils/detailedDataManager.js.map +1 -0
- package/dist/utils/logger.d.ts +16 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +47 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/parallel.d.ts +40 -0
- package/dist/utils/parallel.d.ts.map +1 -0
- package/dist/utils/parallel.js +148 -0
- package/dist/utils/parallel.js.map +1 -0
- package/package.json +94 -0
- package/server.json +39 -0
- package/tsconfig.dev.json +14 -0
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
import * as parser from '@babel/parser';
|
|
2
|
+
import traverse from '@babel/traverse';
|
|
3
|
+
import generate from '@babel/generator';
|
|
4
|
+
import * as t from '@babel/types';
|
|
5
|
+
import { logger } from '../../utils/logger.js';
|
|
6
|
+
export class JScramberDeobfuscator {
|
|
7
|
+
async deobfuscate(options) {
|
|
8
|
+
const { code, removeDeadCode = true, restoreControlFlow = true, decryptStrings = true, simplifyExpressions = true, } = options;
|
|
9
|
+
logger.info('🔓 开始JScrambler反混淆...');
|
|
10
|
+
const transformations = [];
|
|
11
|
+
const warnings = [];
|
|
12
|
+
let currentCode = code;
|
|
13
|
+
try {
|
|
14
|
+
const ast = parser.parse(currentCode, {
|
|
15
|
+
sourceType: 'unambiguous',
|
|
16
|
+
plugins: ['jsx', 'typescript'],
|
|
17
|
+
errorRecovery: true,
|
|
18
|
+
});
|
|
19
|
+
if (this.detectSelfDefending(ast)) {
|
|
20
|
+
this.removeSelfDefending(ast);
|
|
21
|
+
transformations.push('移除自我防御代码');
|
|
22
|
+
}
|
|
23
|
+
if (decryptStrings) {
|
|
24
|
+
const decrypted = this.decryptStrings(ast);
|
|
25
|
+
if (decrypted > 0) {
|
|
26
|
+
transformations.push(`解密字符串: ${decrypted}个`);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
if (restoreControlFlow) {
|
|
30
|
+
const restored = this.restoreControlFlow(ast);
|
|
31
|
+
if (restored > 0) {
|
|
32
|
+
transformations.push(`还原控制流: ${restored}个`);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
if (removeDeadCode) {
|
|
36
|
+
const removed = this.removeDeadCode(ast);
|
|
37
|
+
if (removed > 0) {
|
|
38
|
+
transformations.push(`移除死代码: ${removed}个`);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
if (simplifyExpressions) {
|
|
42
|
+
const simplified = this.simplifyExpressions(ast);
|
|
43
|
+
if (simplified > 0) {
|
|
44
|
+
transformations.push(`简化表达式: ${simplified}个`);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
const output = generate(ast, {
|
|
48
|
+
comments: true,
|
|
49
|
+
compact: false,
|
|
50
|
+
});
|
|
51
|
+
currentCode = output.code;
|
|
52
|
+
const confidence = this.calculateConfidence(transformations.length);
|
|
53
|
+
logger.info(`✅ JScrambler反混淆完成,应用了 ${transformations.length} 个转换`);
|
|
54
|
+
return {
|
|
55
|
+
code: currentCode,
|
|
56
|
+
success: true,
|
|
57
|
+
transformations,
|
|
58
|
+
warnings,
|
|
59
|
+
confidence,
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
catch (error) {
|
|
63
|
+
logger.error('JScrambler反混淆失败', error);
|
|
64
|
+
return {
|
|
65
|
+
code: currentCode,
|
|
66
|
+
success: false,
|
|
67
|
+
transformations,
|
|
68
|
+
warnings: [...warnings, String(error)],
|
|
69
|
+
confidence: 0,
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
detectSelfDefending(ast) {
|
|
74
|
+
let hasSelfDefending = false;
|
|
75
|
+
traverse(ast, {
|
|
76
|
+
FunctionDeclaration(path) {
|
|
77
|
+
if (path.node.body.body.some((stmt) => t.isDebuggerStatement(stmt))) {
|
|
78
|
+
hasSelfDefending = true;
|
|
79
|
+
}
|
|
80
|
+
const code = generate(path.node).code;
|
|
81
|
+
if (code.includes('toString') && code.includes('constructor')) {
|
|
82
|
+
hasSelfDefending = true;
|
|
83
|
+
}
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
return hasSelfDefending;
|
|
87
|
+
}
|
|
88
|
+
removeSelfDefending(ast) {
|
|
89
|
+
traverse(ast, {
|
|
90
|
+
DebuggerStatement(path) {
|
|
91
|
+
path.remove();
|
|
92
|
+
},
|
|
93
|
+
CallExpression(path) {
|
|
94
|
+
if (t.isIdentifier(path.node.callee) &&
|
|
95
|
+
(path.node.callee.name === 'setInterval' || path.node.callee.name === 'setTimeout')) {
|
|
96
|
+
const arg = path.node.arguments[0];
|
|
97
|
+
if (t.isFunctionExpression(arg) || t.isArrowFunctionExpression(arg)) {
|
|
98
|
+
const body = arg.body;
|
|
99
|
+
if (t.isBlockStatement(body)) {
|
|
100
|
+
if (body.body.some((stmt) => t.isDebuggerStatement(stmt))) {
|
|
101
|
+
path.remove();
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
},
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
decryptStrings(ast) {
|
|
110
|
+
let count = 0;
|
|
111
|
+
const decryptFunctions = this.findDecryptFunctions(ast);
|
|
112
|
+
traverse(ast, {
|
|
113
|
+
CallExpression(path) {
|
|
114
|
+
if (t.isIdentifier(path.node.callee)) {
|
|
115
|
+
const funcName = path.node.callee.name;
|
|
116
|
+
if (decryptFunctions.has(funcName)) {
|
|
117
|
+
try {
|
|
118
|
+
const decrypted = '[DECRYPTED_STRING]';
|
|
119
|
+
path.replaceWith(t.stringLiteral(decrypted));
|
|
120
|
+
count++;
|
|
121
|
+
}
|
|
122
|
+
catch {
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
},
|
|
127
|
+
});
|
|
128
|
+
return count;
|
|
129
|
+
}
|
|
130
|
+
findDecryptFunctions(ast) {
|
|
131
|
+
const decryptFunctions = new Set();
|
|
132
|
+
traverse(ast, {
|
|
133
|
+
FunctionDeclaration(path) {
|
|
134
|
+
const code = generate(path.node).code;
|
|
135
|
+
if (code.includes('charCodeAt') &&
|
|
136
|
+
code.includes('fromCharCode') &&
|
|
137
|
+
code.includes('split')) {
|
|
138
|
+
if (path.node.id) {
|
|
139
|
+
decryptFunctions.add(path.node.id.name);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
},
|
|
143
|
+
});
|
|
144
|
+
return decryptFunctions;
|
|
145
|
+
}
|
|
146
|
+
restoreControlFlow(ast) {
|
|
147
|
+
let count = 0;
|
|
148
|
+
const self = this;
|
|
149
|
+
traverse(ast, {
|
|
150
|
+
WhileStatement(path) {
|
|
151
|
+
if (self.isControlFlowFlatteningPattern(path.node)) {
|
|
152
|
+
try {
|
|
153
|
+
self.unflattenControlFlowPattern(path);
|
|
154
|
+
count++;
|
|
155
|
+
}
|
|
156
|
+
catch {
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
},
|
|
160
|
+
});
|
|
161
|
+
return count;
|
|
162
|
+
}
|
|
163
|
+
isControlFlowFlatteningPattern(node) {
|
|
164
|
+
if (!t.isBooleanLiteral(node.test) || !node.test.value) {
|
|
165
|
+
return false;
|
|
166
|
+
}
|
|
167
|
+
if (!t.isBlockStatement(node.body)) {
|
|
168
|
+
return false;
|
|
169
|
+
}
|
|
170
|
+
const firstStmt = node.body.body[0];
|
|
171
|
+
return t.isSwitchStatement(firstStmt);
|
|
172
|
+
}
|
|
173
|
+
unflattenControlFlowPattern(path) {
|
|
174
|
+
const whileStmt = path.node;
|
|
175
|
+
if (t.isBlockStatement(whileStmt.body)) {
|
|
176
|
+
const switchStmt = whileStmt.body.body[0];
|
|
177
|
+
if (t.isSwitchStatement(switchStmt)) {
|
|
178
|
+
path.replaceWithMultiple(switchStmt.cases.map((c) => c.consequent).flat());
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
removeDeadCode(ast) {
|
|
183
|
+
let count = 0;
|
|
184
|
+
traverse(ast, {
|
|
185
|
+
IfStatement(path) {
|
|
186
|
+
if (t.isBooleanLiteral(path.node.test)) {
|
|
187
|
+
if (path.node.test.value) {
|
|
188
|
+
path.replaceWith(path.node.consequent);
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
if (path.node.alternate) {
|
|
192
|
+
path.replaceWith(path.node.alternate);
|
|
193
|
+
}
|
|
194
|
+
else {
|
|
195
|
+
path.remove();
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
count++;
|
|
199
|
+
}
|
|
200
|
+
},
|
|
201
|
+
});
|
|
202
|
+
return count;
|
|
203
|
+
}
|
|
204
|
+
simplifyExpressions(ast) {
|
|
205
|
+
let count = 0;
|
|
206
|
+
traverse(ast, {
|
|
207
|
+
BinaryExpression(path) {
|
|
208
|
+
if (t.isNumericLiteral(path.node.left) && t.isNumericLiteral(path.node.right)) {
|
|
209
|
+
const left = path.node.left.value;
|
|
210
|
+
const right = path.node.right.value;
|
|
211
|
+
let result;
|
|
212
|
+
switch (path.node.operator) {
|
|
213
|
+
case '+':
|
|
214
|
+
result = left + right;
|
|
215
|
+
break;
|
|
216
|
+
case '-':
|
|
217
|
+
result = left - right;
|
|
218
|
+
break;
|
|
219
|
+
case '*':
|
|
220
|
+
result = left * right;
|
|
221
|
+
break;
|
|
222
|
+
case '/':
|
|
223
|
+
result = left / right;
|
|
224
|
+
break;
|
|
225
|
+
}
|
|
226
|
+
if (result !== undefined) {
|
|
227
|
+
path.replaceWith(t.numericLiteral(result));
|
|
228
|
+
count++;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
},
|
|
232
|
+
});
|
|
233
|
+
return count;
|
|
234
|
+
}
|
|
235
|
+
calculateConfidence(transformationCount) {
|
|
236
|
+
return Math.min(transformationCount / 5, 1.0);
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
//# sourceMappingURL=JScramberDeobfuscator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"JScramberDeobfuscator.js","sourceRoot":"","sources":["../../../src/modules/deobfuscator/JScramberDeobfuscator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
export interface PackerDeobfuscatorOptions {
|
|
2
|
+
code: string;
|
|
3
|
+
maxIterations?: number;
|
|
4
|
+
}
|
|
5
|
+
export interface PackerDeobfuscatorResult {
|
|
6
|
+
code: string;
|
|
7
|
+
success: boolean;
|
|
8
|
+
iterations: number;
|
|
9
|
+
warnings: string[];
|
|
10
|
+
}
|
|
11
|
+
export declare class PackerDeobfuscator {
|
|
12
|
+
static detect(code: string): boolean;
|
|
13
|
+
deobfuscate(options: PackerDeobfuscatorOptions): Promise<PackerDeobfuscatorResult>;
|
|
14
|
+
private unpack;
|
|
15
|
+
private parsePackerParams;
|
|
16
|
+
private executeUnpacker;
|
|
17
|
+
private base;
|
|
18
|
+
beautify(code: string): string;
|
|
19
|
+
}
|
|
20
|
+
export declare class AAEncodeDeobfuscator {
|
|
21
|
+
static detect(code: string): boolean;
|
|
22
|
+
deobfuscate(code: string): Promise<string>;
|
|
23
|
+
}
|
|
24
|
+
export declare class URLEncodeDeobfuscator {
|
|
25
|
+
static detect(code: string): boolean;
|
|
26
|
+
deobfuscate(code: string): Promise<string>;
|
|
27
|
+
}
|
|
28
|
+
export declare class UniversalUnpacker {
|
|
29
|
+
private packerDeobfuscator;
|
|
30
|
+
private aaencodeDeobfuscator;
|
|
31
|
+
private urlencodeDeobfuscator;
|
|
32
|
+
deobfuscate(code: string): Promise<{
|
|
33
|
+
code: string;
|
|
34
|
+
type: string;
|
|
35
|
+
success: boolean;
|
|
36
|
+
}>;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=PackerDeobfuscator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PackerDeobfuscator.d.ts","sourceRoot":"","sources":["../../../src/modules/deobfuscator/PackerDeobfuscator.ts"],"names":[],"mappings":"AAoBA,MAAM,WAAW,yBAAyB;IACxC,IAAI,EAAE,MAAM,CAAC;IACb,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAKD,MAAM,WAAW,wBAAwB;IACvC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAKD,qBAAa,kBAAkB;IAI7B,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAS9B,WAAW,CAAC,OAAO,EAAE,yBAAyB,GAAG,OAAO,CAAC,wBAAwB,CAAC;IA8CxF,OAAO,CAAC,MAAM;IA+Bd,OAAO,CAAC,iBAAiB;IAkCzB,OAAO,CAAC,eAAe;IAwBvB,OAAO,CAAC,IAAI;IAmBZ,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;CAc/B;AAMD,qBAAa,oBAAoB;IAI/B,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAQ9B,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAgBjD;AAMD,qBAAa,qBAAqB;IAIhC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAS9B,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAYjD;AAMD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,kBAAkB,CAA4B;IACtD,OAAO,CAAC,oBAAoB,CAA8B;IAC1D,OAAO,CAAC,qBAAqB,CAA+B;IAKtD,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC;QACvC,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,OAAO,CAAC;KAClB,CAAC;CA2CH"}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { logger } from '../../utils/logger.js';
|
|
2
|
+
export class PackerDeobfuscator {
|
|
3
|
+
static detect(code) {
|
|
4
|
+
const packerPattern = /eval\s*\(\s*function\s*\(\s*p\s*,\s*a\s*,\s*c\s*,\s*k\s*,\s*e\s*,\s*[dr]\s*\)/;
|
|
5
|
+
return packerPattern.test(code);
|
|
6
|
+
}
|
|
7
|
+
async deobfuscate(options) {
|
|
8
|
+
const { code, maxIterations = 5 } = options;
|
|
9
|
+
logger.info('📦 开始Packer反混淆...');
|
|
10
|
+
const warnings = [];
|
|
11
|
+
let currentCode = code;
|
|
12
|
+
let iterations = 0;
|
|
13
|
+
try {
|
|
14
|
+
while (PackerDeobfuscator.detect(currentCode) && iterations < maxIterations) {
|
|
15
|
+
const unpacked = this.unpack(currentCode);
|
|
16
|
+
if (!unpacked || unpacked === currentCode) {
|
|
17
|
+
warnings.push('解包失败或已达到最终状态');
|
|
18
|
+
break;
|
|
19
|
+
}
|
|
20
|
+
currentCode = unpacked;
|
|
21
|
+
iterations++;
|
|
22
|
+
logger.info(`📦 完成第 ${iterations} 次解包`);
|
|
23
|
+
}
|
|
24
|
+
logger.info(`✅ Packer反混淆完成,共 ${iterations} 次迭代`);
|
|
25
|
+
return {
|
|
26
|
+
code: currentCode,
|
|
27
|
+
success: true,
|
|
28
|
+
iterations,
|
|
29
|
+
warnings,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
logger.error('Packer反混淆失败', error);
|
|
34
|
+
return {
|
|
35
|
+
code: currentCode,
|
|
36
|
+
success: false,
|
|
37
|
+
iterations,
|
|
38
|
+
warnings: [...warnings, String(error)],
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
unpack(code) {
|
|
43
|
+
const match = code.match(/eval\s*\(\s*function\s*\(\s*p\s*,\s*a\s*,\s*c\s*,\s*k\s*,\s*e\s*,\s*[dr]\s*\)\s*{([\s\S]*?)}\s*\((.*?)\)\s*\)/);
|
|
44
|
+
if (!match || !match[2]) {
|
|
45
|
+
return code;
|
|
46
|
+
}
|
|
47
|
+
const args = match[2];
|
|
48
|
+
const params = this.parsePackerParams(args);
|
|
49
|
+
if (!params) {
|
|
50
|
+
return code;
|
|
51
|
+
}
|
|
52
|
+
try {
|
|
53
|
+
const unpacked = this.executeUnpacker(params);
|
|
54
|
+
return unpacked || code;
|
|
55
|
+
}
|
|
56
|
+
catch (error) {
|
|
57
|
+
logger.warn('解包执行失败', error);
|
|
58
|
+
return code;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
parsePackerParams(argsString) {
|
|
62
|
+
try {
|
|
63
|
+
const parseFunc = new Function(`return [${argsString}];`);
|
|
64
|
+
const params = parseFunc();
|
|
65
|
+
if (params.length < 4) {
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
return {
|
|
69
|
+
p: params[0] || '',
|
|
70
|
+
a: params[1] || 0,
|
|
71
|
+
c: params[2] || 0,
|
|
72
|
+
k: (params[3] || '').split('|'),
|
|
73
|
+
e: params[4] || function (c) { return c; },
|
|
74
|
+
d: params[5] || function () { return ''; },
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
catch {
|
|
78
|
+
return null;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
executeUnpacker(params) {
|
|
82
|
+
const { p, a, k } = params;
|
|
83
|
+
let { c } = params;
|
|
84
|
+
let result = p;
|
|
85
|
+
while (c--) {
|
|
86
|
+
const replacement = k[c];
|
|
87
|
+
if (replacement) {
|
|
88
|
+
const pattern = new RegExp('\\b' + this.base(c, a) + '\\b', 'g');
|
|
89
|
+
result = result.replace(pattern, replacement);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return result;
|
|
93
|
+
}
|
|
94
|
+
base(num, radix) {
|
|
95
|
+
const digits = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
|
|
96
|
+
if (num === 0) {
|
|
97
|
+
return '0';
|
|
98
|
+
}
|
|
99
|
+
let result = '';
|
|
100
|
+
while (num > 0) {
|
|
101
|
+
result = digits[num % radix] + result;
|
|
102
|
+
num = Math.floor(num / radix);
|
|
103
|
+
}
|
|
104
|
+
return result || '0';
|
|
105
|
+
}
|
|
106
|
+
beautify(code) {
|
|
107
|
+
let result = code;
|
|
108
|
+
result = result.replace(/;/g, ';\n');
|
|
109
|
+
result = result.replace(/{/g, '{\n');
|
|
110
|
+
result = result.replace(/}/g, '\n}\n');
|
|
111
|
+
result = result.replace(/\n\n+/g, '\n\n');
|
|
112
|
+
return result.trim();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
export class AAEncodeDeobfuscator {
|
|
116
|
+
static detect(code) {
|
|
117
|
+
return code.includes('゜-゜') || code.includes('ω゜') || code.includes('o゜)');
|
|
118
|
+
}
|
|
119
|
+
async deobfuscate(code) {
|
|
120
|
+
logger.info('😊 开始AAEncode反混淆...');
|
|
121
|
+
try {
|
|
122
|
+
const decoded = new Function(`return (${code})`)();
|
|
123
|
+
logger.info('✅ AAEncode反混淆完成');
|
|
124
|
+
return decoded;
|
|
125
|
+
}
|
|
126
|
+
catch (error) {
|
|
127
|
+
logger.error('AAEncode反混淆失败', error);
|
|
128
|
+
return code;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
export class URLEncodeDeobfuscator {
|
|
133
|
+
static detect(code) {
|
|
134
|
+
const percentCount = (code.match(/%[0-9A-Fa-f]{2}/g) || []).length;
|
|
135
|
+
return percentCount > 10;
|
|
136
|
+
}
|
|
137
|
+
async deobfuscate(code) {
|
|
138
|
+
logger.info('🔗 开始URLEncode反混淆...');
|
|
139
|
+
try {
|
|
140
|
+
const decoded = decodeURIComponent(code);
|
|
141
|
+
logger.info('✅ URLEncode反混淆完成');
|
|
142
|
+
return decoded;
|
|
143
|
+
}
|
|
144
|
+
catch (error) {
|
|
145
|
+
logger.error('URLEncode反混淆失败', error);
|
|
146
|
+
return code;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
export class UniversalUnpacker {
|
|
151
|
+
packerDeobfuscator = new PackerDeobfuscator();
|
|
152
|
+
aaencodeDeobfuscator = new AAEncodeDeobfuscator();
|
|
153
|
+
urlencodeDeobfuscator = new URLEncodeDeobfuscator();
|
|
154
|
+
async deobfuscate(code) {
|
|
155
|
+
logger.info('🔍 自动检测混淆类型...');
|
|
156
|
+
if (PackerDeobfuscator.detect(code)) {
|
|
157
|
+
logger.info('检测到: Packer混淆');
|
|
158
|
+
const result = await this.packerDeobfuscator.deobfuscate({ code });
|
|
159
|
+
return {
|
|
160
|
+
code: result.code,
|
|
161
|
+
type: 'Packer',
|
|
162
|
+
success: result.success,
|
|
163
|
+
};
|
|
164
|
+
}
|
|
165
|
+
if (AAEncodeDeobfuscator.detect(code)) {
|
|
166
|
+
logger.info('检测到: AAEncode混淆');
|
|
167
|
+
const decoded = await this.aaencodeDeobfuscator.deobfuscate(code);
|
|
168
|
+
return {
|
|
169
|
+
code: decoded,
|
|
170
|
+
type: 'AAEncode',
|
|
171
|
+
success: decoded !== code,
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
if (URLEncodeDeobfuscator.detect(code)) {
|
|
175
|
+
logger.info('检测到: URLEncode混淆');
|
|
176
|
+
const decoded = await this.urlencodeDeobfuscator.deobfuscate(code);
|
|
177
|
+
return {
|
|
178
|
+
code: decoded,
|
|
179
|
+
type: 'URLEncode',
|
|
180
|
+
success: decoded !== code,
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
logger.info('未检测到已知的混淆类型');
|
|
184
|
+
return {
|
|
185
|
+
code,
|
|
186
|
+
type: 'Unknown',
|
|
187
|
+
success: false,
|
|
188
|
+
};
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
//# sourceMappingURL=PackerDeobfuscator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PackerDeobfuscator.js","sourceRoot":"","sources":["../../../src/modules/deobfuscator/PackerDeobfuscator.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAuB/C,MAAM,OAAO,kBAAkB;IAI7B,MAAM,CAAC,MAAM,CAAC,IAAY;QAExB,MAAM,aAAa,GAAG,+EAA+E,CAAC;QACtG,OAAO,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAKD,KAAK,CAAC,WAAW,CAAC,OAAkC;QAClD,MAAM,EAAE,IAAI,EAAE,aAAa,GAAG,CAAC,EAAE,GAAG,OAAO,CAAC;QAE5C,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAEjC,MAAM,QAAQ,GAAa,EAAE,CAAC;QAC9B,IAAI,WAAW,GAAG,IAAI,CAAC;QACvB,IAAI,UAAU,GAAG,CAAC,CAAC;QAEnB,IAAI,CAAC;YAEH,OAAO,kBAAkB,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,UAAU,GAAG,aAAa,EAAE,CAAC;gBAC5E,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;gBAE1C,IAAI,CAAC,QAAQ,IAAI,QAAQ,KAAK,WAAW,EAAE,CAAC;oBAC1C,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;oBAC9B,MAAM;gBACR,CAAC;gBAED,WAAW,GAAG,QAAQ,CAAC;gBACvB,UAAU,EAAE,CAAC;gBACb,MAAM,CAAC,IAAI,CAAC,UAAU,UAAU,MAAM,CAAC,CAAC;YAC1C,CAAC;YAED,MAAM,CAAC,IAAI,CAAC,mBAAmB,UAAU,MAAM,CAAC,CAAC;YAEjD,OAAO;gBACL,IAAI,EAAE,WAAW;gBACjB,OAAO,EAAE,IAAI;gBACb,UAAU;gBACV,QAAQ;aACT,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;YACnC,OAAO;gBACL,IAAI,EAAE,WAAW;gBACjB,OAAO,EAAE,KAAK;gBACd,UAAU;gBACV,QAAQ,EAAE,CAAC,GAAG,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;aACvC,CAAC;QACJ,CAAC;IACH,CAAC;IAKO,MAAM,CAAC,IAAY;QAEzB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CACtB,+GAA+G,CAChH,CAAC;QAEF,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAGtB,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO,IAAI,CAAC;QACd,CAAC;QAGD,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;YAC9C,OAAO,QAAQ,IAAI,IAAI,CAAC;QAC1B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;YAC7B,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAKO,iBAAiB,CAAC,UAAkB;QAQ1C,IAAI,CAAC;YAGH,MAAM,SAAS,GAAG,IAAI,QAAQ,CAAC,WAAW,UAAU,IAAI,CAAC,CAAC;YAC1D,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;YAE3B,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACtB,OAAO,IAAI,CAAC;YACd,CAAC;YAED,OAAO;gBACL,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE;gBAClB,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC;gBACjB,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC;gBACjB,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC;gBAC/B,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,UAAU,CAAM,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC/C,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,cAAc,OAAO,EAAE,CAAC,CAAC,CAAC;aAC3C,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAKO,eAAe,CACrB,MAAkF;QAElF,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,MAAM,CAAC;QAC3B,IAAI,EAAE,CAAC,EAAE,GAAG,MAAM,CAAC;QAGnB,IAAI,MAAM,GAAG,CAAC,CAAC;QAGf,OAAO,CAAC,EAAE,EAAE,CAAC;YACX,MAAM,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,WAAW,EAAE,CAAC;gBAChB,MAAM,OAAO,GAAG,IAAI,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC;gBACjE,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;YAChD,CAAC;QACH,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAKO,IAAI,CAAC,GAAW,EAAE,KAAa;QACrC,MAAM,MAAM,GAAG,gEAAgE,CAAC;QAEhF,IAAI,GAAG,KAAK,CAAC,EAAE,CAAC;YACd,OAAO,GAAG,CAAC;QACb,CAAC;QAED,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,OAAO,GAAG,GAAG,CAAC,EAAE,CAAC;YACf,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,MAAM,CAAC;YACtC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,KAAK,CAAC,CAAC;QAChC,CAAC;QAED,OAAO,MAAM,IAAI,GAAG,CAAC;IACvB,CAAC;IAKD,QAAQ,CAAC,IAAY;QAEnB,IAAI,MAAM,GAAG,IAAI,CAAC;QAGlB,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACrC,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACrC,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAGvC,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAE1C,OAAO,MAAM,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;CACF;AAMD,MAAM,OAAO,oBAAoB;IAI/B,MAAM,CAAC,MAAM,CAAC,IAAY;QAExB,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC7E,CAAC;IAKD,KAAK,CAAC,WAAW,CAAC,IAAY;QAC5B,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAEnC,IAAI,CAAC;YAIH,MAAM,OAAO,GAAG,IAAI,QAAQ,CAAC,WAAW,IAAI,GAAG,CAAC,EAAE,CAAC;YAEnD,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC/B,OAAO,OAAO,CAAC;QACjB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;YACrC,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;CACF;AAMD,MAAM,OAAO,qBAAqB;IAIhC,MAAM,CAAC,MAAM,CAAC,IAAY;QAExB,MAAM,YAAY,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC;QACnE,OAAO,YAAY,GAAG,EAAE,CAAC;IAC3B,CAAC;IAKD,KAAK,CAAC,WAAW,CAAC,IAAY;QAC5B,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QAEpC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC;YACzC,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAChC,OAAO,OAAO,CAAC;QACjB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;YACtC,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;CACF;AAMD,MAAM,OAAO,iBAAiB;IACpB,kBAAkB,GAAG,IAAI,kBAAkB,EAAE,CAAC;IAC9C,oBAAoB,GAAG,IAAI,oBAAoB,EAAE,CAAC;IAClD,qBAAqB,GAAG,IAAI,qBAAqB,EAAE,CAAC;IAK5D,KAAK,CAAC,WAAW,CAAC,IAAY;QAK5B,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAG9B,IAAI,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;YACpC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC7B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;YACnE,OAAO;gBACL,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,MAAM,CAAC,OAAO;aACxB,CAAC;QACJ,CAAC;QAGD,IAAI,oBAAoB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;YACtC,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC/B,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAClE,OAAO;gBACL,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE,UAAU;gBAChB,OAAO,EAAE,OAAO,KAAK,IAAI;aAC1B,CAAC;QACJ,CAAC;QAGD,IAAI,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;YACvC,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAChC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YACnE,OAAO;gBACL,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE,WAAW;gBACjB,OAAO,EAAE,OAAO,KAAK,IAAI;aAC1B,CAAC;QACJ,CAAC;QAED,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC3B,OAAO;YACL,IAAI;YACJ,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,KAAK;SACf,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { ObfuscationType, VMFeatures } from '../../types/index.js';
|
|
2
|
+
export interface DetectionResult {
|
|
3
|
+
types: ObfuscationType[];
|
|
4
|
+
confidence: Record<ObfuscationType, number>;
|
|
5
|
+
features: string[];
|
|
6
|
+
recommendations: string[];
|
|
7
|
+
vmFeatures?: VMFeatures;
|
|
8
|
+
}
|
|
9
|
+
export declare class ObfuscationDetector {
|
|
10
|
+
private jsvmpDetector;
|
|
11
|
+
constructor();
|
|
12
|
+
detect(code: string): DetectionResult;
|
|
13
|
+
private detectVMProtectionDetailed;
|
|
14
|
+
private detectJavaScriptObfuscator;
|
|
15
|
+
private detectWebpack;
|
|
16
|
+
private detectUglify;
|
|
17
|
+
private detectVMProtection;
|
|
18
|
+
private detectInvisibleUnicode;
|
|
19
|
+
private detectControlFlowFlattening;
|
|
20
|
+
private detectStringArrayRotation;
|
|
21
|
+
private detectDeadCodeInjection;
|
|
22
|
+
private detectOpaquePredicates;
|
|
23
|
+
private detectJSFuck;
|
|
24
|
+
private detectAAEncode;
|
|
25
|
+
private detectJJEncode;
|
|
26
|
+
private detectPacker;
|
|
27
|
+
private detectEvalObfuscation;
|
|
28
|
+
private detectBase64Encoding;
|
|
29
|
+
private detectHexEncoding;
|
|
30
|
+
private detectSelfModifying;
|
|
31
|
+
private detectJScrambler;
|
|
32
|
+
private detectURLEncode;
|
|
33
|
+
generateReport(result: DetectionResult): string;
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=ObfuscationDetector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ObfuscationDetector.d.ts","sourceRoot":"","sources":["../../../src/modules/detector/ObfuscationDetector.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAInE,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,eAAe,EAAE,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC;IAC5C,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,UAAU,CAAC,EAAE,UAAU,CAAC;CACzB;AAED,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,aAAa,CAAoB;;IASzC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe;IAwLrC,OAAO,CAAC,0BAA0B;IAyBlC,OAAO,CAAC,0BAA0B;IAWlC,OAAO,CAAC,aAAa;IAQrB,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,kBAAkB;IAW1B,OAAO,CAAC,sBAAsB;IAK9B,OAAO,CAAC,2BAA2B;IAInC,OAAO,CAAC,yBAAyB;IAQjC,OAAO,CAAC,uBAAuB;IAO/B,OAAO,CAAC,sBAAsB;IAI9B,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,qBAAqB;IAK7B,OAAO,CAAC,oBAAoB;IAO5B,OAAO,CAAC,iBAAiB;IAKzB,OAAO,CAAC,mBAAmB;IAW3B,OAAO,CAAC,gBAAgB;IA6BxB,OAAO,CAAC,eAAe;IASvB,cAAc,CAAC,MAAM,EAAE,eAAe,GAAG,MAAM;CAqBhD"}
|