Detect Confuser 1.0 r48717 compressor

This commit is contained in:
de4dot 2012-08-10 17:14:06 +02:00
parent 731d7bcb73
commit 12f7034894

View File

@ -75,6 +75,7 @@ namespace de4dot.code.deobfuscators.Confuser {
enum ConfuserVersion { enum ConfuserVersion {
Unknown, Unknown,
v10_r42915, v10_r42915,
v10_r48717,
v14_r58564, v14_r58564,
v14_r58802, v14_r58802,
v14_r58852, v14_r58852,
@ -121,8 +122,12 @@ namespace de4dot.code.deobfuscators.Confuser {
if (decyptMethod == null) if (decyptMethod == null)
return; return;
var decryptLocals = new LocalTypes(decyptMethod); var decryptLocals = new LocalTypes(decyptMethod);
if (decryptLocals.exists("System.IO.MemoryStream")) if (decryptLocals.exists("System.IO.MemoryStream")) {
if (DotNetUtils.hasString(entryPoint, ".exe"))
version = ConfuserVersion.v10_r42915; version = ConfuserVersion.v10_r42915;
else
version = ConfuserVersion.v10_r48717;
}
else else
version = ConfuserVersion.v14_r58564; version = ConfuserVersion.v14_r58564;
@ -139,6 +144,7 @@ namespace de4dot.code.deobfuscators.Confuser {
switch (version) { switch (version) {
case ConfuserVersion.v10_r42915: case ConfuserVersion.v10_r42915:
case ConfuserVersion.v10_r48717:
break; break;
case ConfuserVersion.v14_r58564: case ConfuserVersion.v14_r58564:
@ -443,6 +449,7 @@ namespace de4dot.code.deobfuscators.Confuser {
var data = resource.GetResourceData(); var data = resource.GetResourceData();
switch (version) { switch (version) {
case ConfuserVersion.v10_r42915: return decrypt_v10_r42915(data); case ConfuserVersion.v10_r42915: return decrypt_v10_r42915(data);
case ConfuserVersion.v10_r48717: return decrypt_v10_r42915(data);
case ConfuserVersion.v14_r58564: return decrypt_v14_r58564(data); case ConfuserVersion.v14_r58564: return decrypt_v14_r58564(data);
case ConfuserVersion.v14_r58802: return decrypt_v14_r58564(data); case ConfuserVersion.v14_r58802: return decrypt_v14_r58564(data);
case ConfuserVersion.v14_r58852: return decrypt_v14_r58852(data); case ConfuserVersion.v14_r58852: return decrypt_v14_r58852(data);
@ -546,6 +553,11 @@ namespace de4dot.code.deobfuscators.Confuser {
case ConfuserVersion.v10_r42915: case ConfuserVersion.v10_r42915:
minRev = 42915; minRev = 42915;
maxRev = 48509;
return true;
case ConfuserVersion.v10_r48717:
minRev = 48717;
maxRev = 58446; maxRev = 58446;
return true; return true;