aboutsummaryrefslogtreecommitdiff
path: root/NorthstarDedicatedTest/serverauthentication.cpp
diff options
context:
space:
mode:
authorKawe Mazidjatari <48657826+Mauler125@users.noreply.github.com>2022-03-24 00:55:20 +0100
committerGitHub <noreply@github.com>2022-03-24 00:55:20 +0100
commitb5405b462656b83a37bf1eb41b049b0913980a13 (patch)
treeb9e48626b49782161ddaff84ae257bfece72c257 /NorthstarDedicatedTest/serverauthentication.cpp
parent178f1deca8fe94167307e1717cee7250a3f3b8b4 (diff)
parentde7deafc7e6ba53deec8dd3c05d2ea5e7cf42264 (diff)
downloadNorthstarLauncher-b5405b462656b83a37bf1eb41b049b0913980a13.tar.gz
NorthstarLauncher-b5405b462656b83a37bf1eb41b049b0913980a13.zip
Merge branch 'main' into NetCon
Diffstat (limited to 'NorthstarDedicatedTest/serverauthentication.cpp')
-rw-r--r--NorthstarDedicatedTest/serverauthentication.cpp49
1 files changed, 21 insertions, 28 deletions
diff --git a/NorthstarDedicatedTest/serverauthentication.cpp b/NorthstarDedicatedTest/serverauthentication.cpp
index 03c3e765..c3cdbe88 100644
--- a/NorthstarDedicatedTest/serverauthentication.cpp
+++ b/NorthstarDedicatedTest/serverauthentication.cpp
@@ -12,6 +12,7 @@
#include "dedicated.h"
#include "configurables.h"
#include "host_state.h"
+#include "NSMem.h"
const char* AUTHSERVER_VERIFY_STRING = "I am a northstar server!";
@@ -621,47 +622,39 @@ void InitialiseServerAuthentication(HMODULE baseAddress)
CCommand__Tokenize = (CCommand__TokenizeType)((char*)baseAddress + 0x418380);
+ uintptr_t ba = (uintptr_t)baseAddress;
+
// patch to disable kicking based on incorrect serverfilter in connectclient, since we repurpose it for use as an auth token
{
- void* ptr = (char*)baseAddress + 0x114655;
- TempReadWrite rw(ptr);
- *((char*)ptr) = (char)0xEB; // jz => jmp
+ NSMem::BytePatch(ba + 0x114655, {
+ 0xEB // jz => jmp
+ });
}
// patch to disable fairfight marking players as cheaters and kicking them
{
- void* ptr = (char*)baseAddress + 0x101012;
- TempReadWrite rw(ptr);
- *((char*)ptr) = (char)0xE9; // jz => jmp
- *((char*)ptr + 1) = (char)0x90;
- *((char*)ptr + 2) = (char)0x0;
+ NSMem::BytePatch(ba + 0x101012, {
+ 0xE9, // jz => jmp
+ 0x90,
+ 0x0
+ });
}
// patch to allow same of multiple account
{
- void* ptr = (char*)baseAddress + 0x114510;
- TempReadWrite rw(ptr);
- *((char*)ptr) = (char)0xEB; // jz => jmp
+ NSMem::BytePatch(ba + 0x114510, {
+ 0xEB, // jz => jmp
+ });
}
// patch to set bWasWritingStringTableSuccessful in CNetworkStringTableContainer::WriteBaselines if it fails
{
- bool* writeAddress = (bool*)(&bWasWritingStringTableSuccessful - ((bool*)baseAddress + 0x234EDC));
-
- void* ptr = (char*)baseAddress + 0x234ED2;
- TempReadWrite rw(ptr);
- *((char*)ptr) = (char)0xC7;
- *((char*)ptr + 1) = (char)0x05;
- *(int*)((char*)ptr + 2) = (int)writeAddress;
- *((char*)ptr + 6) = (char)0x00;
- *((char*)ptr + 7) = (char)0x00;
- *((char*)ptr + 8) = (char)0x00;
- *((char*)ptr + 9) = (char)0x00;
-
- *((char*)ptr + 10) = (char)0x90;
- *((char*)ptr + 11) = (char)0x90;
- *((char*)ptr + 12) = (char)0x90;
- *((char*)ptr + 13) = (char)0x90;
- *((char*)ptr + 14) = (char)0x90;
+ uintptr_t writeAddress = (uintptr_t)(&bWasWritingStringTableSuccessful - (ba + 0x234EDC));
+
+ auto addr = ba + 0x234ED2;
+ NSMem::BytePatch(addr, { 0xC7, 0x05 });
+ NSMem::BytePatch(addr + 2, (BYTE*)&writeAddress, sizeof(writeAddress));
+ NSMem::BytePatch(addr + 6, {0, 0, 0, 0});
+ NSMem::NOP(addr + 10, 5);
}
}