aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Warden/Warden.h
diff options
context:
space:
mode:
authorleak <leak@bitmx.net>2012-02-19 13:51:16 +0100
committerleak <leak@bitmx.net>2012-02-19 13:51:16 +0100
commit8e3a4b956e8fcc3ec31240d847a7a630eaf2bba2 (patch)
treec7a797f883906019d9fa820b4d782eb7dfd4c1c5 /src/server/game/Warden/Warden.h
parentf0f68f15a86c5ac0c83c47c6db67786506f8460d (diff)
Core/Warden: Base implementation for Warden functionality
Note: The default config file action for clients failing the checks can be changed for each check via the characters.warden_action table Credits to TOM_RUS
Diffstat (limited to 'src/server/game/Warden/Warden.h')
-rw-r--r--src/server/game/Warden/Warden.h147
1 files changed, 147 insertions, 0 deletions
diff --git a/src/server/game/Warden/Warden.h b/src/server/game/Warden/Warden.h
new file mode 100644
index 00000000000..e800891df24
--- /dev/null
+++ b/src/server/game/Warden/Warden.h
@@ -0,0 +1,147 @@
+/*
+ * Copyright (C) 2008-2011 TrinityCore <http://www.trinitycore.org/>
+ * Copyright (C) 2005-2011 MaNGOS <http://getmangos.com/>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
+ * more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef _WARDEN_BASE_H
+#define _WARDEN_BASE_H
+
+#include <map>
+#include "Cryptography/ARC4.h"
+#include "Cryptography/BigNumber.h"
+#include "ByteBuffer.h"
+#include "WardenCheckMgr.h"
+
+enum WardenOpcodes
+{
+ // Client->Server
+ WARDEN_CMSG_MODULE_MISSING = 0,
+ WARDEN_CMSG_MODULE_OK = 1,
+ WARDEN_CMSG_CHEAT_CHECKS_RESULT = 2,
+ WARDEN_CMSG_MEM_CHECKS_RESULT = 3, // only sent if MEM_CHECK bytes doesn't match
+ WARDEN_CMSG_HASH_RESULT = 4,
+ WARDEN_CMSG_MODULE_FAILED = 5, // this is sent when client failed to load uploaded module due to cache fail
+
+ // Server->Client
+ WARDEN_SMSG_MODULE_USE = 0,
+ WARDEN_SMSG_MODULE_CACHE = 1,
+ WARDEN_SMSG_CHEAT_CHECKS_REQUEST = 2,
+ WARDEN_SMSG_MODULE_INITIALIZE = 3,
+ WARDEN_SMSG_MEM_CHECKS_REQUEST = 4, // byte len; while(!EOF) { byte unk(1); byte index(++); string module(can be 0); int offset; byte len; byte[] bytes_to_compare[len]; }
+ WARDEN_SMSG_HASH_REQUEST = 5
+};
+
+enum WardenCheckType
+{
+ MEM_CHECK = 0xF3, // 243: byte moduleNameIndex + uint Offset + byte Len (check to ensure memory isn't modified)
+ PAGE_CHECK_A = 0xB2, // 178: uint Seed + byte[20] SHA1 + uint Addr + byte Len (scans all pages for specified hash)
+ PAGE_CHECK_B = 0xBF, // 191: uint Seed + byte[20] SHA1 + uint Addr + byte Len (scans only pages starts with MZ+PE headers for specified hash)
+ MPQ_CHECK = 0x98, // 152: byte fileNameIndex (check to ensure MPQ file isn't modified)
+ LUA_STR_CHECK = 0x8B, // 139: byte luaNameIndex (check to ensure LUA string isn't used)
+ DRIVER_CHECK = 0x71, // 113: uint Seed + byte[20] SHA1 + byte driverNameIndex (check to ensure driver isn't loaded)
+ TIMING_CHECK = 0x57, // 87: empty (check to ensure GetTickCount() isn't detoured)
+ PROC_CHECK = 0x7E, // 126: uint Seed + byte[20] SHA1 + byte moluleNameIndex + byte procNameIndex + uint Offset + byte Len (check to ensure proc isn't detoured)
+ MODULE_CHECK = 0xD9, // 217: uint Seed + byte[20] SHA1 (check to ensure module isn't injected)
+};
+
+#if defined(__GNUC__)
+#pragma pack(1)
+#else
+#pragma pack(push,1)
+#endif
+
+struct WardenModuleUse
+{
+ uint8 Command;
+ uint8 ModuleId[16];
+ uint8 ModuleKey[16];
+ uint32 Size;
+};
+
+struct WardenModuleTransfer
+{
+ uint8 Command;
+ uint16 DataSize;
+ uint8 Data[500];
+};
+
+struct WardenHashRequest
+{
+ uint8 Command;
+ uint8 Seed[16];
+};
+
+#if defined(__GNUC__)
+#pragma pack()
+#else
+#pragma pack(pop)
+#endif
+
+struct ClientWardenModule
+{
+ uint8 Id[16];
+ uint8 Key[16];
+ uint32 CompressedSize;
+ uint8 *CompressedData;
+};
+
+class WorldSession;
+
+class Warden
+{
+ friend class WardenWin;
+ friend class WardenMac;
+
+ public:
+ Warden();
+ ~Warden();
+
+ virtual void Init(WorldSession* session, BigNumber* k);
+ virtual ClientWardenModule* GetModuleForClient(WorldSession* session);
+ virtual void InitializeModule();
+ virtual void RequestHash();
+ virtual void HandleHashResult(ByteBuffer &buff);
+ virtual void RequestData();
+ virtual void HandleData(ByteBuffer &buff);
+
+ void SendModuleToClient();
+ void RequestModule();
+ void Update();
+ void DecryptData(uint8* buffer, uint32 length);
+ void EncryptData(uint8* buffer, uint32 length);
+
+ static bool IsValidCheckSum(uint32 checksum, const uint8 *data, const uint16 length);
+ static uint32 BuildChecksum(const uint8 *data, uint32 length);
+
+ // If no check is passed, the default action from config is executed
+ std::string Penalty(WardenCheck* check = NULL);
+
+ private:
+ WorldSession *_session;
+ uint8 _inputKey[16];
+ uint8 _outputKey[16];
+ uint8 _seed[16];
+ ARC4 _inputCrypto;
+ ARC4 _outputCrypto;
+ uint32 _checkTimer; // Timer for sending check requests
+ bool _dataSent;
+ uint32 _clientResponseTimer; // Timer for client response delay
+ uint32 _previousTimestamp;
+ ClientWardenModule *_module;
+ bool _initialized;
+};
+
+#endif