mirror of
https://github.com/sp-tarkov/assembly-tool.git
synced 2025-02-13 09:30:46 -05:00
Adds the source code used for this modification, this de4dot source code has been cleaned of any things not needed for deobfuscating the tarkov assembly Co-authored-by: 静穏靄 <170472707+seionmoya@users.noreply.github.com>
110 lines
3.3 KiB
C#
110 lines
3.3 KiB
C#
/*
|
|
Copyright (C) 2011-2015 de4dot@gmail.com
|
|
|
|
This file is part of de4dot.
|
|
|
|
de4dot is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
de4dot is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with de4dot. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using dnlib.PE;
|
|
using dnlib.DotNet;
|
|
using dnlib.DotNet.Writer;
|
|
using de4dot.blocks;
|
|
using de4dot.blocks.cflow;
|
|
using de4dot.code.renamer;
|
|
|
|
namespace de4dot.code.deobfuscators {
|
|
public interface IDeobfuscatorOptions {
|
|
bool RenameResourcesInCode { get; }
|
|
}
|
|
|
|
public enum DecrypterType {
|
|
Default,
|
|
None,
|
|
Static,
|
|
Delegate,
|
|
Emulate,
|
|
}
|
|
|
|
[Flags]
|
|
public enum StringFeatures {
|
|
AllowNoDecryption = 1,
|
|
AllowStaticDecryption = 2,
|
|
AllowDynamicDecryption = 4,
|
|
AllowAll = AllowNoDecryption | AllowStaticDecryption | AllowDynamicDecryption,
|
|
}
|
|
|
|
[Flags]
|
|
public enum RenamingOptions {
|
|
RemoveNamespaceIfOneType = 1,
|
|
RenameResourceKeys = 2,
|
|
}
|
|
|
|
public interface IDeobfuscator : INameChecker, IDisposable {
|
|
string Type { get; }
|
|
string TypeLong { get; }
|
|
string Name { get; }
|
|
IDeobfuscatorOptions TheOptions { get; }
|
|
IOperations Operations { get; set; }
|
|
MetadataFlags MetadataFlags { get; }
|
|
StringFeatures StringFeatures { get; }
|
|
RenamingOptions RenamingOptions { get; }
|
|
DecrypterType DefaultDecrypterType { get; }
|
|
IEnumerable<IBlocksDeobfuscator> BlocksDeobfuscators { get; }
|
|
|
|
// This is non-null only in detect() and deobfuscateBegin().
|
|
IDeobfuscatedFile DeobfuscatedFile { get; set; }
|
|
|
|
// Returns null or the unpacked .NET PE file
|
|
byte[] UnpackNativeFile(IPEImage peImage);
|
|
|
|
void Initialize(ModuleDefMD module);
|
|
|
|
// Returns 0 if it's not detected, or > 0 if detected (higher value => more likely true).
|
|
// This method is always called.
|
|
int Detect();
|
|
|
|
// If the obfuscator has encrypted parts of the file, then this method should return the
|
|
// decrypted file. true is returned if args have been initialized, false otherwise.
|
|
bool GetDecryptedModule(int count, ref byte[] newFileData, ref DumpedMethods dumpedMethods);
|
|
|
|
// This is only called if getDecryptedModule() != null, and after the module has been
|
|
// reloaded. Should return a new IDeobfuscator with the same options and the new module.
|
|
IDeobfuscator ModuleReloaded(ModuleDefMD module);
|
|
|
|
// Called before all other deobfuscation methods
|
|
void DeobfuscateBegin();
|
|
|
|
// Called before the code is deobfuscated
|
|
void DeobfuscateMethodBegin(Blocks blocks);
|
|
|
|
// Return true if we should deobfuscate control flow again
|
|
bool DeobfuscateOther(Blocks blocks);
|
|
|
|
// Called after deobfuscateMethodBegin() but before deobfuscateMethodEnd()
|
|
void DeobfuscateStrings(Blocks blocks);
|
|
|
|
// Called after the code has been deobfuscated
|
|
void DeobfuscateMethodEnd(Blocks blocks);
|
|
|
|
// Called after all deobfuscation methods
|
|
void DeobfuscateEnd();
|
|
|
|
// Returns all string decrypter method tokens
|
|
IEnumerable<int> GetStringDecrypterMethods();
|
|
}
|
|
}
|