parent
4c0c35ba43
commit
0b0216e41e
@ -29,6 +29,8 @@ Manual usage instructions:
|
|||||||
|
|
||||||
This tool is capable of starting the games from a different process. This may be useful for spoofing the parent process (SR is known to report it). Use `wine jadeite.exe 'Z:\wine\path\to\game.exe' 'Z:\wine\path\to\launcher.exe'`. `explorer.exe` is used as the default.
|
This tool is capable of starting the games from a different process. This may be useful for spoofing the parent process (SR is known to report it). Use `wine jadeite.exe 'Z:\wine\path\to\game.exe' 'Z:\wine\path\to\launcher.exe'`. `explorer.exe` is used as the default.
|
||||||
|
|
||||||
|
To pass commandline arguments to the game, append them after the launcher path: `wine jadeite.exe 'Z:\wine\path\to\game.exe' 'Z:\wine\path\to\launcher.exe' -arg1 -arg2 -arg3`. To use the default launcher process, use `--`: `wine jadeite.exe 'Z:\wine\path\to\game.exe' -- -arg1 -arg2 -arg3`.
|
||||||
|
|
||||||
### Configuration
|
### Configuration
|
||||||
These environment variables can be used to configure the behaviour of the tool.
|
These environment variables can be used to configure the behaviour of the tool.
|
||||||
|
|
||||||
|
@ -1,7 +1,10 @@
|
|||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
|
||||||
const char ENV_EXE_PATH[] = "JADEITE_TARGET_EXE_PATH";
|
#define EPFX "__JADEITE_"
|
||||||
const char ENV_DLL_PATH[] = "JADEITE_INJECT_DLL_PATH";
|
|
||||||
|
const char ENV_EXE_PATH[] = EPFX"TARGET_EXE_PATH";
|
||||||
|
const char ENV_DLL_PATH[] = EPFX"INJECT_DLL_PATH";
|
||||||
|
const char ENV_PROC_CMD[] = EPFX"PROCESS_COMMAND";
|
||||||
|
|
||||||
static inline void write_protected_process_memory(HANDLE process, void *address, const void *buf, size_t size) {
|
static inline void write_protected_process_memory(HANDLE process, void *address, const void *buf, size_t size) {
|
||||||
DWORD oldProtect;
|
DWORD oldProtect;
|
||||||
|
@ -16,6 +16,9 @@ BOOL WINAPI DllMain(HINSTANCE inst, DWORD reason, LPVOID reserved) {
|
|||||||
// Get the path of the DLL to inject
|
// Get the path of the DLL to inject
|
||||||
char *injectDll = getenv(ENV_DLL_PATH);
|
char *injectDll = getenv(ENV_DLL_PATH);
|
||||||
|
|
||||||
|
// Get game commandline
|
||||||
|
char *cmdline = getenv(ENV_PROC_CMD);
|
||||||
|
|
||||||
// Compute the working directory path
|
// Compute the working directory path
|
||||||
char workdir[MAX_PATH];
|
char workdir[MAX_PATH];
|
||||||
strcpy(workdir, targetExe);
|
strcpy(workdir, targetExe);
|
||||||
@ -30,8 +33,8 @@ BOOL WINAPI DllMain(HINSTANCE inst, DWORD reason, LPVOID reserved) {
|
|||||||
ZeroMemory(&pi, sizeof(pi));
|
ZeroMemory(&pi, sizeof(pi));
|
||||||
|
|
||||||
if (!CreateProcessA(
|
if (!CreateProcessA(
|
||||||
targetExe,
|
|
||||||
NULL,
|
NULL,
|
||||||
|
cmdline,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
FALSE,
|
FALSE,
|
||||||
|
@ -7,27 +7,41 @@
|
|||||||
const char LAUNCHER_INJECT_DLL[] = "launcher_payload.dll";
|
const char LAUNCHER_INJECT_DLL[] = "launcher_payload.dll";
|
||||||
const char GAME_INJECT_DLL[] = "game_payload.dll";
|
const char GAME_INJECT_DLL[] = "game_payload.dll";
|
||||||
|
|
||||||
|
#define SHIFT(argc, argv) argc--, argv++
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
// Read arguments
|
// Read arguments
|
||||||
char *gamePath = NULL;
|
char *gamePath = NULL;
|
||||||
char *launcherPath = NULL;
|
char *launcherPath = NULL;
|
||||||
|
|
||||||
|
// Skip executable
|
||||||
|
SHIFT(argc, argv);
|
||||||
|
|
||||||
switch (argc) {
|
switch (argc) {
|
||||||
case 1:
|
case 0:
|
||||||
printf("Usage: wine jadeite.exe [game path] <launcher path>\n");
|
printf("Usage: wine jadeite.exe [game path] <launcher path>\n");
|
||||||
return 0;
|
return 0;
|
||||||
case 2:
|
case 1:
|
||||||
printf("No launcher process specified! Using explorer.exe\n");
|
gamePath = argv[0];
|
||||||
gamePath = argv[1];
|
SHIFT(argc, argv);
|
||||||
launcherPath = "C:\\Windows\\explorer.exe";
|
|
||||||
break;
|
launcherPath = "--";
|
||||||
case 3:
|
|
||||||
gamePath = argv[1];
|
|
||||||
launcherPath = argv[2];
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "Too many arguments! (%d)\n", argc);
|
gamePath = argv[0];
|
||||||
return 1;
|
SHIFT(argc, argv);
|
||||||
|
|
||||||
|
launcherPath = argv[0];
|
||||||
|
SHIFT(argc, argv);
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Default launcher path
|
||||||
|
if (strcmp(launcherPath, "--") == 0) {
|
||||||
|
printf("No launcher process specified! Using explorer.exe\n");
|
||||||
|
launcherPath = "C:\\Windows\\explorer.exe";
|
||||||
}
|
}
|
||||||
|
|
||||||
// cd into the injector directory
|
// cd into the injector directory
|
||||||
@ -48,13 +62,26 @@ int main(int argc, char **argv) {
|
|||||||
char launcherPayloadPath[MAX_PATH];
|
char launcherPayloadPath[MAX_PATH];
|
||||||
GetFullPathNameA(LAUNCHER_INJECT_DLL, sizeof(launcherPayloadPath), launcherPayloadPath, NULL);
|
GetFullPathNameA(LAUNCHER_INJECT_DLL, sizeof(launcherPayloadPath), launcherPayloadPath, NULL);
|
||||||
|
|
||||||
printf("Starting '%s' via '%s'\n", gameExePath, launcherPath);
|
// Construct commandline for the game process
|
||||||
|
char cmdline[8192];
|
||||||
|
sprintf(cmdline, "\"%s\"", gameExePath);
|
||||||
|
|
||||||
|
while (argc) {
|
||||||
|
char arg[8192];
|
||||||
|
sprintf(arg, " \"%s\"", argv[0]);
|
||||||
|
strcat(cmdline, arg);
|
||||||
|
|
||||||
|
SHIFT(argc, argv);
|
||||||
|
}
|
||||||
|
|
||||||
// Set envvars
|
// Set envvars
|
||||||
SetEnvironmentVariableA(ENV_EXE_PATH, gameExePath);
|
SetEnvironmentVariableA(ENV_EXE_PATH, gameExePath);
|
||||||
SetEnvironmentVariableA(ENV_DLL_PATH, gamePayloadPath);
|
SetEnvironmentVariableA(ENV_DLL_PATH, gamePayloadPath);
|
||||||
|
SetEnvironmentVariableA(ENV_PROC_CMD, cmdline);
|
||||||
|
|
||||||
// Start the launcher
|
// Start the launcher
|
||||||
|
printf("Starting '%s' via '%s'\n", gameExePath, launcherPath);
|
||||||
|
|
||||||
STARTUPINFO si;
|
STARTUPINFO si;
|
||||||
ZeroMemory(&si, sizeof(si));
|
ZeroMemory(&si, sizeof(si));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user