Files
creamlinux/main.cpp
2022-11-20 22:12:40 +02:00

617 lines
29 KiB
C++

#include <cstddef>
#include <iostream>
#include <fstream>
#include "ext/steam/isteamapps.h"
#include "ext/steam/isteamclient.h"
#include "ext/steam/isteamuser.h"
#include "spdlog/spdlog.h"
#include "ext/ini.h"
#include <string>
#include <cassert>
#include <vector>
#include <map>
#include <unistd.h>
using namespace std;
#ifndef _GNU_SOURCE
#define _GNU_SOURCE
#endif
#include <dlfcn.h>
#include <link.h>
#include <stdio.h>
vector<tuple<int, string>> dlcs;
mINI::INIStructure ini;
class Hookey_SteamApps_Class : public ISteamApps {
public:
bool BIsSubscribed() { return true; }
bool BIsLowViolence() { return false; }
bool BIsCybercafe() { return false; }
bool BIsVACBanned() { return false; }
int GetDLCCount() {
spdlog::info("ISteamApps->GetDLCCount called PID {0}", getpid());
auto count = dlcs.size();
auto content = dlcs;
return dlcs.size();
}
bool BIsDlcInstalled(AppId_t appID) {
spdlog::info("ISteamApps->BIsDlcInstalled called");
auto reslt = std::find_if(
std::begin(dlcs),
std::end(dlcs),
[&] (const tuple<int, string> a) { return std::get<0>(a) == appID; }) != std::end(dlcs);
if (reslt) {
spdlog::info("BIsDlcInstalled unlocked {}", appID);
return true;
} else {
return false;
}
}
bool BGetDLCDataByIndex(int iDLC, AppId_t* pAppID, bool* pbAvailable, char* pchName, int cchNameBufferSize) {
spdlog::info("ISteamApps->BGetDLCDataByIndex called");
if ((size_t)iDLC >= dlcs.size()) {
return false;
}
*pAppID = std::get<0>(dlcs[iDLC]);
*pbAvailable = true;
const char* name = std::get<1>(dlcs[iDLC]).c_str();
size_t slen = std::min((size_t)cchNameBufferSize - 1, std::get<1>(dlcs[iDLC]).size());
memcpy((void*)pchName, (void*)name, slen);
*(pchName + slen) = 0x0;
return true;
}
const char* GetCurrentGameLanguage() { return real_steamApps->GetCurrentGameLanguage(); }
const char* GetAvailableGameLanguages() { return real_steamApps->GetAvailableGameLanguages(); }
CSteamID GetAppOwner() { return real_steamApps->GetAppOwner(); }
int GetAppBuildId() { return real_steamApps->GetAppBuildId(); }
void RequestAllProofOfPurchaseKeys() {
spdlog::info("ISteamApps->RequestAllProofOfPurchaseKeys called");
return real_steamApps->RequestAllProofOfPurchaseKeys();
}
bool BIsSubscribedFromFamilySharing() { return real_steamApps->BIsSubscribedFromFamilySharing(); }
bool BIsSubscribedFromFreeWeekend() { return real_steamApps->BIsSubscribedFromFreeWeekend(); }
bool BIsSubscribedApp(AppId_t appID) {
spdlog::info("ISteamApps->BIsSubscribedApp called");
if (ini["methods"]["disable_steamapps_issubscribedapp"] == "true") {
spdlog::info("BIsSubscribedApp function override disabled");
return real_steamApps->BIsSubscribedApp(appID);
} else {
spdlog::info("BIsSubscribedApp creamified called");
auto reslt = std::find_if(
std::begin(dlcs),
std::end(dlcs),
[&] (const tuple<int, string> a) { return std::get<0>(a) == appID; }) != std::end(dlcs);
if (reslt) {
spdlog::info("BIsSubscribedApp unlocked {}", appID);
return true;
} else {
if (ini["config"]["issubscribedapp_on_false_use_real"] == "true") {
return real_steamApps->BIsSubscribedApp(appID);
}
return false;
}
}
}
bool BIsAppInstalled(AppId_t appID) {
spdlog::info("ISteamApps->BIsAppInstalled {0} called", appID);
return real_steamApps->BIsAppInstalled(appID);
}
uint32 GetEarliestPurchaseUnixTime(AppId_t appID) { return real_steamApps->GetEarliestPurchaseUnixTime(appID); }
void InstallDLC(AppId_t appID) { real_steamApps->InstallDLC(appID); }
void UninstallDLC(AppId_t appID) { real_steamApps->UninstallDLC(appID); }
void RequestAppProofOfPurchaseKey(AppId_t appID) { real_steamApps->RequestAppProofOfPurchaseKey(appID); }
bool GetCurrentBetaName(char* pchName, int cchNameBufferSize) { return real_steamApps->GetCurrentBetaName(pchName, cchNameBufferSize); }
bool MarkContentCorrupt(bool bMissingFilesOnly) { return real_steamApps->MarkContentCorrupt(bMissingFilesOnly); }
uint32 GetInstalledDepots(AppId_t appID, DepotId_t* pvecDepots, uint32 cMaxDepots) { return real_steamApps->GetInstalledDepots(appID, pvecDepots, cMaxDepots); }
uint32 GetAppInstallDir(AppId_t appID, char* pchFolder, uint32 cchFolderBufferSize) { return real_steamApps->GetAppInstallDir(appID, pchFolder, cchFolderBufferSize); }
const char* GetLaunchQueryParam(const char* pchKey) { return real_steamApps->GetLaunchQueryParam(pchKey); }
bool GetDlcDownloadProgress(AppId_t nAppID, uint64* punBytesDownloaded, uint64* punBytesTotal) { return real_steamApps->GetDlcDownloadProgress(nAppID, punBytesDownloaded, punBytesTotal); }
SteamAPICall_t GetFileDetails(const char* pszFileName) { return real_steamApps->GetFileDetails(pszFileName); }
int GetLaunchCommandLine(char* pszCommandLine, int cubCommandLine) { return real_steamApps->GetLaunchCommandLine(pszCommandLine, cubCommandLine); }
virtual bool BIsTimedTrial( uint32* punSecondsAllowed, uint32* punSecondsPlayed ) { return real_steamApps->BIsTimedTrial(punSecondsAllowed, punSecondsPlayed); }
ISteamApps* real_steamApps;
};
class Hookey_SteamUser_Class : public ISteamUser {
public:
HSteamUser GetHSteamUser() {
return real_steamUser->GetHSteamUser();
};
bool BLoggedOn() {
return real_steamUser->BLoggedOn();
};
CSteamID GetSteamID() {
return real_steamUser->GetSteamID();
};
int InitiateGameConnection_DEPRECATED( void *pAuthBlob, int cbMaxAuthBlob, CSteamID steamIDGameServer, uint32 unIPServer, uint16 usPortServer, bool bSecure ) {
return real_steamUser->InitiateGameConnection_DEPRECATED(pAuthBlob, cbMaxAuthBlob, steamIDGameServer, unIPServer, usPortServer, bSecure);
};
void TerminateGameConnection_DEPRECATED( uint32 unIPServer, uint16 usPortServer ) {
return real_steamUser->TerminateGameConnection_DEPRECATED(unIPServer, usPortServer);
};
int InitiateGameConnection( void *pAuthBlob, int cbMaxAuthBlob, CSteamID steamIDGameServer, uint32 unIPServer, uint16 usPortServer, bool bSecure ) {
return real_steamUser->InitiateGameConnection_DEPRECATED(pAuthBlob, cbMaxAuthBlob, steamIDGameServer, unIPServer, usPortServer, bSecure);
};
void TerminateGameConnection( uint32 unIPServer, uint16 usPortServer ) {
return real_steamUser->TerminateGameConnection_DEPRECATED(unIPServer, usPortServer);
};
void TrackAppUsageEvent( CGameID gameID, int eAppUsageEvent, const char *pchExtraInfo = "" ) {
return real_steamUser->TrackAppUsageEvent(gameID, eAppUsageEvent, pchExtraInfo);
};
bool GetUserDataFolder( char *pchBuffer, int cubBuffer ) {
return real_steamUser->GetUserDataFolder(pchBuffer, cubBuffer);
};
void StartVoiceRecording( ) {
return real_steamUser->StartVoiceRecording();
};
void StopVoiceRecording( ) {
return real_steamUser->StopVoiceRecording();
};
EVoiceResult GetAvailableVoice( uint32 *pcbCompressed, uint32 *pcbUncompressed_Deprecated, uint32 nUncompressedVoiceDesiredSampleRate_Deprecated) {
return real_steamUser->GetAvailableVoice(pcbCompressed, pcbUncompressed_Deprecated, nUncompressedVoiceDesiredSampleRate_Deprecated);
};
EVoiceResult GetVoice( bool bWantCompressed, void *pDestBuffer, uint32 cbDestBufferSize, uint32 *nBytesWritten, bool bWantUncompressed_Deprecated, void *pUncompressedDestBuffer_Deprecated, uint32 cbUncompressedDestBufferSize_Deprecated, uint32 *nUncompressBytesWritten_Deprecated, uint32 nUncompressedVoiceDesiredSampleRate_Deprecated ) {
return real_steamUser->GetVoice(bWantCompressed, pDestBuffer, cbDestBufferSize, nBytesWritten, bWantUncompressed_Deprecated, pUncompressedDestBuffer_Deprecated, cbUncompressedDestBufferSize_Deprecated, nUncompressBytesWritten_Deprecated, nUncompressedVoiceDesiredSampleRate_Deprecated);
};
EVoiceResult DecompressVoice( const void *pCompressed, uint32 cbCompressed, void *pDestBuffer, uint32 cbDestBufferSize, uint32 *nBytesWritten, uint32 nDesiredSampleRate ) {
return real_steamUser->DecompressVoice(pCompressed, cbCompressed, pDestBuffer, cbDestBufferSize, nBytesWritten, nDesiredSampleRate);
};
uint32 GetVoiceOptimalSampleRate() {
return real_steamUser->GetVoiceOptimalSampleRate();
};
HAuthTicket GetAuthSessionTicket( void *pTicket, int cbMaxTicket, uint32 *pcbTicket ) {
return real_steamUser->GetAuthSessionTicket(pTicket, cbMaxTicket, pcbTicket);
};
EBeginAuthSessionResult BeginAuthSession( const void *pAuthTicket, int cbAuthTicket, CSteamID steamID ) {
return real_steamUser->BeginAuthSession(pAuthTicket, cbAuthTicket, steamID);
};
void EndAuthSession( CSteamID steamID ) {
return real_steamUser->EndAuthSession(steamID);
};
void CancelAuthTicket( HAuthTicket hAuthTicket ) {
return real_steamUser->CancelAuthTicket(hAuthTicket);
};
EUserHasLicenseForAppResult UserHasLicenseForApp( CSteamID steamID, AppId_t appID ) {
spdlog::info("ISteamUser->UserHasLicenseForApp {} called", appID);
auto reslt = std::find_if(
std::begin(dlcs),
std::end(dlcs),
[&] (const tuple<int, string> a) { return std::get<0>(a) == appID; }) != std::end(dlcs);
if (reslt) {
spdlog::info("ISteamUser_UserHasLicenseForApp result: owned");
return (EUserHasLicenseForAppResult)0;
} else {
spdlog::info("ISteamUser_UserHasLicenseForApp result: not owned");
return (EUserHasLicenseForAppResult)2;
}
};
bool BIsBehindNAT() {
return real_steamUser->BIsBehindNAT();
};
void AdvertiseGame( CSteamID steamIDGameServer, uint32 unIPServer, uint16 usPortServer ) {
return real_steamUser->AdvertiseGame(steamIDGameServer, unIPServer, usPortServer);
};
SteamAPICall_t RequestEncryptedAppTicket( void *pDataToInclude, int cbDataToInclude ) {
return real_steamUser->RequestEncryptedAppTicket(pDataToInclude, cbDataToInclude);
};
bool GetEncryptedAppTicket( void *pTicket, int cbMaxTicket, uint32 *pcbTicket ) {
return real_steamUser->GetEncryptedAppTicket(pTicket, cbMaxTicket, pcbTicket);
};
int GetGameBadgeLevel( int nSeries, bool bFoil ) {
return real_steamUser->GetGameBadgeLevel(nSeries, bFoil);
};
int GetPlayerSteamLevel() {
return real_steamUser->GetPlayerSteamLevel();
};
SteamAPICall_t RequestStoreAuthURL( const char *pchRedirectURL ) {
return real_steamUser->RequestStoreAuthURL(pchRedirectURL);
};
bool BIsPhoneVerified() {
return real_steamUser->BIsPhoneVerified();
};
bool BIsTwoFactorEnabled() {
return real_steamUser->BIsTwoFactorEnabled();
};
bool BIsPhoneIdentifying() {
return real_steamUser->BIsPhoneIdentifying();
};
bool BIsPhoneRequiringVerification() {
return real_steamUser->BIsPhoneRequiringVerification();
};
SteamAPICall_t GetMarketEligibility() {
return real_steamUser->GetMarketEligibility();
};
virtual SteamAPICall_t GetDurationControl() {
return real_steamUser->GetDurationControl();
}
virtual bool BSetDurationControlOnlineState( EDurationControlOnlineState eNewState ) {
return real_steamUser->BSetDurationControlOnlineState(eNewState);
};
ISteamUser* real_steamUser;
};
static std::shared_ptr<Hookey_SteamApps_Class> steamapps_instance;
ISteamApps* Hookey_SteamApps(ISteamApps* real_steamApps) {
if (steamapps_instance != NULL) {
ISteamApps* ptraccess = steamapps_instance.get();
auto debg = ptraccess->GetDLCCount();
return steamapps_instance.get();
} else {
Hookey_SteamApps_Class nhooky;
nhooky.real_steamApps = real_steamApps;
steamapps_instance = std::make_shared<Hookey_SteamApps_Class>(nhooky);
return Hookey_SteamApps(real_steamApps);
}
}
static std::shared_ptr<Hookey_SteamUser_Class> steamuser_instance;
ISteamUser* Hookey_SteamUser(ISteamUser* real_steamUser) {
if (steamuser_instance != NULL) {
return steamuser_instance.get();
} else {
Hookey_SteamUser_Class nhooky;
nhooky.real_steamUser = real_steamUser;
steamuser_instance = std::make_shared<Hookey_SteamUser_Class>(nhooky);
return Hookey_SteamUser(real_steamUser);
}
}
class Hookey_SteamClient_Class : public ISteamClient {
public:
HSteamPipe CreateSteamPipe() {
return real_steamClient->CreateSteamPipe();
}
bool BReleaseSteamPipe( HSteamPipe hSteamPipe ) {
return real_steamClient->BReleaseSteamPipe(hSteamPipe);
}
HSteamUser ConnectToGlobalUser( HSteamPipe hSteamPipe ) {
return real_steamClient->ConnectToGlobalUser(hSteamPipe);
}
HSteamUser CreateLocalUser( HSteamPipe *phSteamPipe, EAccountType eAccountType ) {
return real_steamClient->CreateLocalUser(phSteamPipe, eAccountType);
}
void ReleaseUser( HSteamPipe hSteamPipe, HSteamUser hUser ) {
return real_steamClient->ReleaseUser(hSteamPipe, hUser);
}
ISteamUser *GetISteamUser( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
spdlog::info("ISteamClient->GetISteamUser {0} called (hooked)", pchVersion);
return Hookey_SteamUser(real_steamClient->GetISteamUser(hSteamUser, hSteamPipe, pchVersion));
//return real_steamClient->GetISteamUser(hSteamUser, hSteamPipe, pchVersion);
}
ISteamGameServer *GetISteamGameServer( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamGameServer(hSteamUser, hSteamPipe, pchVersion);
}
void SetLocalIPBinding( const SteamIPAddress_t &unIP, uint16 usPort ) {
return real_steamClient->SetLocalIPBinding(unIP, usPort);
}
ISteamFriends *GetISteamFriends( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamFriends(hSteamUser, hSteamPipe, pchVersion);
}
ISteamUtils *GetISteamUtils( HSteamPipe hSteamPipe, const char *pchVersion ) {
spdlog::info("ISteamClient->GetISteamUtils called");
return real_steamClient->GetISteamUtils(hSteamPipe, pchVersion);
}
ISteamMatchmaking *GetISteamMatchmaking( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamMatchmaking(hSteamUser, hSteamPipe, pchVersion);
}
ISteamMatchmakingServers *GetISteamMatchmakingServers( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamMatchmakingServers(hSteamUser, hSteamPipe, pchVersion);
}
void *GetISteamGenericInterface( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
spdlog::info("ISteamClient->GetISteamGenericInterface {0} called (you're in for a wild ride)", pchVersion);
return real_steamClient->GetISteamGenericInterface(hSteamUser, hSteamPipe, pchVersion);
}
ISteamUserStats *GetISteamUserStats( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamUserStats(hSteamUser, hSteamPipe, pchVersion);
}
ISteamGameServerStats *GetISteamGameServerStats( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamGameServerStats(hSteamUser, hSteamPipe, pchVersion);
}
ISteamApps *GetISteamApps( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
spdlog::info("ISteamClient->GetISteamApps {0} called (hooked)", pchVersion);
return Hookey_SteamApps(real_steamClient->GetISteamApps(hSteamUser, hSteamPipe, pchVersion));
//return real_steamClient->GetISteamApps(hSteamUser, hSteamPipe, pchVersion);
}
ISteamNetworking *GetISteamNetworking( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamNetworking(hSteamUser, hSteamPipe, pchVersion);
}
ISteamRemoteStorage *GetISteamRemoteStorage( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamRemoteStorage(hSteamuser, hSteamPipe, pchVersion);
}
ISteamScreenshots *GetISteamScreenshots( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamScreenshots(hSteamuser, hSteamPipe, pchVersion);
}
ISteamGameSearch *GetISteamGameSearch( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamGameSearch(hSteamuser, hSteamPipe, pchVersion);
}
uint32 GetIPCCallCount() {
return real_steamClient->GetIPCCallCount();
}
void SetWarningMessageHook( SteamAPIWarningMessageHook_t pFunction ) {
return real_steamClient->SetWarningMessageHook(pFunction);
}
bool BShutdownIfAllPipesClosed() {
return real_steamClient->BShutdownIfAllPipesClosed();
}
ISteamHTTP *GetISteamHTTP( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamHTTP(hSteamuser, hSteamPipe, pchVersion);
}
ISteamController *GetISteamController( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamController(hSteamUser, hSteamPipe, pchVersion);
}
ISteamUGC *GetISteamUGC( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamUGC(hSteamUser, hSteamPipe, pchVersion);
}
ISteamAppList *GetISteamAppList( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
spdlog::info("ISteamClient->GetISteamAppList called");
return real_steamClient->GetISteamAppList(hSteamUser, hSteamPipe, pchVersion);
}
ISteamMusic *GetISteamMusic( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamMusic(hSteamuser, hSteamPipe, pchVersion);
}
ISteamMusicRemote *GetISteamMusicRemote(HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion) {
return real_steamClient->GetISteamMusicRemote(hSteamuser, hSteamPipe, pchVersion);
}
ISteamHTMLSurface *GetISteamHTMLSurface(HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion) {
return real_steamClient->GetISteamHTMLSurface(hSteamuser, hSteamPipe, pchVersion);
}
ISteamInventory *GetISteamInventory( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamInventory(hSteamuser, hSteamPipe, pchVersion);
}
ISteamVideo *GetISteamVideo( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamVideo(hSteamuser, hSteamPipe, pchVersion);
}
ISteamParentalSettings *GetISteamParentalSettings( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamParentalSettings(hSteamuser, hSteamPipe, pchVersion);
}
ISteamInput *GetISteamInput( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamInput(hSteamUser, hSteamPipe, pchVersion);
}
ISteamParties *GetISteamParties( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamParties(hSteamUser, hSteamPipe, pchVersion);
}
ISteamRemotePlay *GetISteamRemotePlay( HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->GetISteamRemotePlay(hSteamUser, hSteamPipe, pchVersion);
}
void RunFrame() {
return real_steamClient->RunFrame();
}
void *DEPRECATED_GetISteamUnifiedMessages( HSteamUser hSteamuser, HSteamPipe hSteamPipe, const char *pchVersion ) {
return real_steamClient->DEPRECATED_GetISteamUnifiedMessages(hSteamuser, hSteamPipe, pchVersion);
}
void DEPRECATED_Set_SteamAPI_CPostAPIResultInProcess( void (*)() ) {
return real_steamClient->DEPRECATED_Set_SteamAPI_CPostAPIResultInProcess(NULL);
}
void DEPRECATED_Remove_SteamAPI_CPostAPIResultInProcess( void (*)() ) {
return real_steamClient->DEPRECATED_Remove_SteamAPI_CPostAPIResultInProcess(NULL);
}
void Set_SteamAPI_CCheckCallbackRegisteredInProcess( SteamAPI_CheckCallbackRegistered_t func ) {
return real_steamClient->Set_SteamAPI_CCheckCallbackRegisteredInProcess(func);
}
void DestroyAllInterfaces() {
return real_steamClient->DestroyAllInterfaces();
}
ISteamClient* real_steamClient;
};
static std::shared_ptr<Hookey_SteamClient_Class> steamclient_instance;
ISteamClient* Hookey_SteamClient(ISteamClient* real_steamClient) {
if (steamclient_instance != NULL) {
return steamclient_instance.get();
} else {
Hookey_SteamClient_Class nhooky;
nhooky.real_steamClient = real_steamClient;
steamclient_instance = std::make_shared<Hookey_SteamClient_Class>(nhooky);
return Hookey_SteamClient(real_steamClient);
}
}
#define STEAMAPPS_INTERFACE_VERSION_N008 "STEAMAPPS_INTERFACE_VERSION008"
#define STEAMUSER_INTERFACE_VERSION_020 "SteamUser020"
#define STEAMUSER_INTERFACE_VERSION_021 "SteamUser021"
#define STEAMCLIENT_INTERFACE_VERSION_017 "SteamClient017"
extern "C" void* CreateInterface(const char *pName, int *pReturnCode) {
void* S_CALLTYPE (*real)(const char *pName, int *pReturnCode);
*(void**)(&real) = dlsym(RTLD_NEXT, "CreateInterface");
spdlog::info("CreateInterface called pszVersion: {}", pName);
return real(pName, pReturnCode);
}
extern "C" void Steam_LogOn(HSteamUser hUser, HSteamPipe hSteamPipe, uint64 ulSteamID) {
void* S_CALLTYPE (*real)(HSteamUser hUser, HSteamPipe hSteamPipe, uint64 ulSteamID);
*(void**)(&real) = dlsym(RTLD_NEXT, "SteamAPI_LogOn");
spdlog::info("SteamAPI_LogOn called {0} {1} {2}",hUser, hSteamPipe, ulSteamID );
real(hUser, hSteamPipe, ulSteamID);
}
extern "C" bool SteamAPI_ISteamApps_BGetDLCDataByIndex(int iDLC, AppId_t* pAppID, bool* pbAvailable, char* pchName, int cchNameBufferSize) {
spdlog::info("SteamAPI_ISteamApps_BGetDLCDataByIndex called");
if ((size_t)iDLC >= dlcs.size()) {
return false;
}
*pAppID = std::get<0>(dlcs[iDLC]);
*pbAvailable = true;
const char* name = std::get<1>(dlcs[iDLC]).c_str();
size_t slen = std::min((size_t)cchNameBufferSize - 1, std::get<1>(dlcs[iDLC]).size());
memcpy((void*)pchName, (void*)name, slen);
*(pchName + slen) = 0x0;
return true;
}
extern "C" void* S_CALLTYPE SteamInternal_FindOrCreateUserInterface(HSteamUser hSteamUser, const char *pszVersion) {
void* S_CALLTYPE (*real)(HSteamUser hSteamUser, const char *pszVersion);
*(void**)(&real) = dlsym(RTLD_NEXT, "SteamInternal_FindOrCreateUserInterface");
spdlog::info("SteamInternal_FindOrCreateUserInterface called pszVersion: {}", pszVersion);
// Steamapps Interface call is hooked here
if (strstr(pszVersion, STEAMAPPS_INTERFACE_VERSION_N008) == pszVersion) {
ISteamApps* val = (ISteamApps*)real(hSteamUser, pszVersion);
spdlog::info("SteamInternal_FindOrCreateUserInterface hooked ISteamApps");
return Hookey_SteamApps(val);
}
// Steamuser interface call is hooked here
if (strstr(pszVersion, STEAMUSER_INTERFACE_VERSION) == pszVersion) {
ISteamUser* val = (ISteamUser*)real(hSteamUser, pszVersion);
spdlog::info("SteamInternal_FindOrCreateUserInterface ISteamUser hook");
return Hookey_SteamUser(val);
}
if (strstr(pszVersion, STEAMUSER_INTERFACE_VERSION_020) == pszVersion) {
ISteamUser* val = (ISteamUser*)real(hSteamUser, pszVersion);
spdlog::info("SteamInternal_FindOrCreateUserInterface ISteamUser(legacy) hook");
return Hookey_SteamUser(val);
}
auto val = real(hSteamUser, pszVersion);
return val;
}
extern "C" void* S_CALLTYPE SteamInternal_CreateInterface(const char *pszVersion) {
void* S_CALLTYPE (*real)(const char *pszVersion);
*(void**)(&real) = dlsym(RTLD_NEXT, "SteamInternal_CreateInterface");
spdlog::info("SteamInternal_CreateInterface called pszVersion: {}", pszVersion);
// Steamapps Interface call is hooked here
if (strstr(pszVersion, STEAMAPPS_INTERFACE_VERSION_N008) == pszVersion) {
ISteamApps* val = (ISteamApps*)real(pszVersion);
spdlog::info("SteamInternal_CreateInterface hooked ISteamApps");
return Hookey_SteamApps(val);
}
// Steamuser interface call is hooked here
if (strstr(pszVersion, STEAMUSER_INTERFACE_VERSION) == pszVersion) {
ISteamUser* val = (ISteamUser*)real(pszVersion);
spdlog::info("SteamInternal_CreateInterface ISteamUser hook");
return Hookey_SteamUser(val);
}
if (strstr(pszVersion, STEAMUSER_INTERFACE_VERSION_020) == pszVersion) {
ISteamUser* val = (ISteamUser*)real(pszVersion);
spdlog::info("SteamInternal_CreateInterface ISteamUser(legacy) hook");
return Hookey_SteamUser(val);
}
if (strstr(pszVersion, STEAMCLIENT_INTERFACE_VERSION_017) == pszVersion) {
ISteamClient* val = (ISteamClient*)real(pszVersion);
spdlog::info("SteamInternal_CreateInterface ISteamClient(legacy) hook");
return Hookey_SteamClient(val);
}
auto val = real(pszVersion);
return val;
}
extern "C" void * steamclient_CreateInterface(const char *name, int *return_code) {
void* S_CALLTYPE (*real)(const char *name, int *return_code);
*(void**)(&real) = dlsym(RTLD_NEXT, "steamclient_CreateInterface");
spdlog::info("steamclient_CreateInterface called pszVersion: {}", name);
return real(name, return_code);
}
extern "C" EUserHasLicenseForAppResult SteamAPI_ISteamUser_UserHasLicenseForApp(CSteamID steamID, AppId_t appId) {
// LOG(TRACE) << "SteamAPI_ISteamUser_UserHasLicenseForApp called!!" << endl;
spdlog::info("ISteamUser_UserHasLicenseForApp called");
return (EUserHasLicenseForAppResult)0;
}
// for older games
extern "C" ISteamApps *S_CALLTYPE SteamApps() {
spdlog::info("SteamApps() called");
//get isteamapps
void* S_CALLTYPE (*real)();
*(void**)(&real) = dlsym(RTLD_NEXT, "SteamApps");
ISteamApps* val = (ISteamApps*)real();
return Hookey_SteamApps(val);
}
// for older games
extern "C" ISteamUser *S_CALLTYPE SteamUser() {
spdlog::info("SteamUser() called");
//get isteamuser
void* S_CALLTYPE (*real)();
*(void**)(&real) = dlsym(RTLD_NEXT, "SteamUser");
ISteamUser* val = (ISteamUser*)real();
return Hookey_SteamUser(val);
}
// for older games
extern "C" ISteamClient *S_CALLTYPE SteamClient() {
spdlog::info("SteamClient() called");
//get isteamuser
void* S_CALLTYPE (*real)();
*(void**)(&real) = dlsym(RTLD_NEXT, "SteamClient");
ISteamClient* val = (ISteamClient*)real();
return Hookey_SteamClient(val);
}
// anti-debugger shenanigans
long ptrace(int request, int pid, void *addr, void *data) {
return 0;
}
static bool hooked = false;
int printdliter(struct dl_phdr_info *info, size_t size, void *data) {
printf("%s\n", info->dlpi_name);
return 0;
}
extern "C" bool SteamAPI_Init() {
std::string creaminipath = "cream_api.ini";
auto env = std::getenv("CREAM_CONFIG_PATH");
//f env exists, use it
if (env != NULL) {
creaminipath = env;
}
spdlog::info("Reading config from {}", creaminipath);
mINI::INIFile file(creaminipath);
// Open ini file
file.read(ini);
// Find dlc's and add to vector
for (pair<string,string> entry : ini["dlc"]) {
auto dlctuple = std::make_tuple(stoi(entry.first), entry.second);
dlcs.push_back(dlctuple);
spdlog::info("Added dlc with id: {0}, name: {1}", entry.first, entry.second);
}
spdlog::info("SteamAPI_Init called in PID {0}", getpid());
// finish api call
// the spaghetti below this comment is calling the original Init function
// can probably be simplified but i'm no c++ expert
bool (*real)();
*(void**)(&real) = dlsym(RTLD_NEXT, "SteamAPI_Init");
char* errstr = dlerror();
if (errstr != NULL) {
spdlog::error("SteamAPI_Init failed; A dynamic linking error occurred: {0}", errstr);
spdlog::error("Listing open libraries.");
dl_iterate_phdr(printdliter, NULL);
return false;
}
auto retval = real();
spdlog::info("SteamAPI_Init returned");
return retval;
}
extern "C" ISteamApps * cppISteamClient_SteamClient020_GetISteamApps(void *linux_side, HSteamUser hSteamUser, HSteamPipe hSteamPipe, const char * pchVersion) {
spdlog::info("cppISteamClient_SteamClient020_GetISteamApps called");
void* S_CALLTYPE (*real)();
*(void**)(&real) = dlsym(RTLD_NEXT, "SteamApps");
ISteamApps* val = (ISteamApps*)real();
return Hookey_SteamApps(val);
}
int main() {
return 0;
}