2019-02-01 00:41:43 +08:00
|
|
|
#include "host.h"
|
|
|
|
#include "util.h"
|
|
|
|
#include <io.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <iostream>
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
_setmode(_fileno(stdout), _O_U16TEXT);
|
|
|
|
_setmode(_fileno(stdin), _O_U16TEXT);
|
|
|
|
wprintf_s(L"Usage: {'attach'|'detach'|hookcode} -Pprocessid\n");
|
2019-02-01 22:18:07 +08:00
|
|
|
fflush(stdout);
|
2019-02-07 21:11:41 +08:00
|
|
|
Host::Start([](auto) {}, [](auto) {}, [](auto&) {}, [](auto&) {}, [](TextThread& thread, std::wstring& output)
|
2019-02-01 00:41:43 +08:00
|
|
|
{
|
2019-02-07 21:11:41 +08:00
|
|
|
wprintf_s(L"[%I64X:%I32X:%I64X:%I64X:%I64X:%s:%s] %s\n", thread.handle, thread.tp.processId, thread.tp.addr, thread.tp.ctx, thread.tp.ctx2, thread.name.c_str(), Util::GenerateCode(thread.hp, thread.tp.processId).c_str(), output.c_str());
|
2019-02-01 22:18:07 +08:00
|
|
|
fflush(stdout);
|
2019-02-01 00:41:43 +08:00
|
|
|
return false;
|
|
|
|
});
|
|
|
|
wchar_t input[500] = {};
|
|
|
|
while (fgetws(input, 500, stdin))
|
|
|
|
{
|
|
|
|
wchar_t command[500] = {};
|
|
|
|
DWORD processId = 0;
|
|
|
|
if (swscanf(input, L"%500s -P%d", command, &processId) != 2) ExitProcess(0);
|
|
|
|
if (_wcsicmp(command, L"attach") == 0) Host::InjectProcess(processId);
|
|
|
|
else if (_wcsicmp(command, L"detach") == 0) Host::DetachProcess(processId);
|
|
|
|
else if (auto hp = Util::ParseCode(command)) Host::InsertHook(processId, hp.value());
|
|
|
|
else ExitProcess(0);
|
|
|
|
}
|
|
|
|
ExitProcess(0);
|
|
|
|
}
|