using System.Collections.Concurrent; using System.Collections.Generic; using System.IO; using BurnOutSharp.ExecutableType.Microsoft.NE; using BurnOutSharp.ExecutableType.Microsoft.PE; using BurnOutSharp.ExecutableType.Microsoft.PE.Headers; using BurnOutSharp.Matching; namespace BurnOutSharp.ProtectionType { public class SmartE : IContentCheck, IPathCheck { /// public string CheckContents(string file, byte[] fileContent, bool includeDebug, PortableExecutable pex, NewExecutable nex) { // Get the sections from the executable, if possible var sections = pex?.SectionTable; if (sections == null) return null; // Get the .edata section, if it exists string match = GetMatchForSection(file, pex.ExportDataSectionRaw, includeDebug); if (!string.IsNullOrWhiteSpace(match)) return match; // Get the .idata section, if it exists match = GetMatchForSection(file, pex.ImportDataSectionRaw, includeDebug); if (!string.IsNullOrWhiteSpace(match)) return match; // Get the .rdata section, if it exists match = GetMatchForSection(file, pex.ResourceDataSectionRaw, includeDebug); if (!string.IsNullOrWhiteSpace(match)) return match; // Get the .tls section, if it exists var tlsSectionRaw = pex.ReadRawSection(fileContent, ".tls", first: false); match = GetMatchForSection(file, tlsSectionRaw, includeDebug); if (!string.IsNullOrWhiteSpace(match)) return match; return null; } /// public ConcurrentQueue CheckDirectoryPath(string path, IEnumerable files) { var matchers = new List { new PathMatchSet(new List { new PathMatch($"{Path.DirectorySeparatorChar}00001.TMP", useEndsWith: true), new PathMatch($"{Path.DirectorySeparatorChar}00002.TMP", useEndsWith: true) }, "SmartE"), }; return MatchUtil.GetAllMatches(files, matchers, any: true); } /// public string CheckFilePath(string path) { var matchers = new List { new PathMatchSet(new PathMatch($"{Path.DirectorySeparatorChar}00001.TMP", useEndsWith: true), "SmartE"), new PathMatchSet(new PathMatch($"{Path.DirectorySeparatorChar}00002.TMP", useEndsWith: true), "SmartE"), }; return MatchUtil.GetFirstMatch(path, matchers, any: true); } /// /// Check a section for the SmartE string(s) /// private string GetMatchForSection(SectionHeader section, string file, byte[] sectionContent, bool includeDebug) { if (section == null) return null; int sectionAddr = (int)section.PointerToRawData; int sectionEnd = sectionAddr + (int)section.VirtualSize; var matchers = new List { // BITARTS new ContentMatchSet( new ContentMatch(new byte?[] { 0x42, 0x49, 0x54, 0x41, 0x52, 0x54, 0x53 }, start: sectionAddr, end: sectionEnd), "SmartE"), }; return MatchUtil.GetFirstMatch(file, sectionContent, matchers, includeDebug); } /// /// Check a section for the SmartE string(s) /// private string GetMatchForSection(string file, byte[] sectionContent, bool includeDebug) { if (sectionContent == null) return null; var matchers = new List { // BITARTS new ContentMatchSet(new byte?[] { 0x42, 0x49, 0x54, 0x41, 0x52, 0x54, 0x53 }, "SmartE"), }; return MatchUtil.GetFirstMatch(file, sectionContent, matchers, includeDebug); } } }