177 lines
6.2 KiB
C++
Raw Normal View History

2024-11-06 06:46:35 +08:00
#include "host.h"
#define C_LUNA_API extern "C" __declspec(dllexport)
BOOL APIENTRY DllMain(HMODULE hModule,
DWORD ul_reason_for_call,
LPVOID lpReserved)
{
switch (ul_reason_for_call)
{
case DLL_PROCESS_ATTACH:
case DLL_THREAD_ATTACH:
case DLL_THREAD_DETACH:
case DLL_PROCESS_DETACH:
break;
}
return TRUE;
}
typedef void (*ProcessEvent)(DWORD pid);
typedef void (*ThreadEvent_maybe_embed)(const wchar_t *hookcode, const char *hookname, ThreadParam, bool isembedable);
typedef void (*ThreadEvent)(const wchar_t *hookcode, const char *hookname, ThreadParam);
typedef bool (*OutputCallback)(const wchar_t *hookcode, const char *hookname, ThreadParam, const wchar_t *text);
2024-11-28 16:59:08 +08:00
typedef void (*HostInfoHandler)(HOSTINFO type, const wchar_t *log);
2024-11-06 07:27:43 +08:00
typedef void (*HookInsertHandler)(DWORD pid, uint64_t address, const wchar_t *hookcode);
2024-11-06 06:46:35 +08:00
typedef void (*EmbedCallback)(const wchar_t *text, ThreadParam);
typedef void (*findhookcallback_t)(wchar_t *hookcode, const wchar_t *text);
template <typename T>
std::optional<T> checkoption(bool check, T &&t)
{
if (check)
return std::move(t);
return {};
}
2024-12-16 01:48:39 +08:00
2024-11-28 16:59:08 +08:00
C_LUNA_API void Luna_Start(ProcessEvent Connect, ProcessEvent Disconnect, ThreadEvent_maybe_embed Create, ThreadEvent Destroy, OutputCallback Output, HostInfoHandler hostinfo, HookInsertHandler hookinsert, EmbedCallback embed)
2024-11-06 06:46:35 +08:00
{
Host::StartEx(
checkoption(Connect, std::function<void(DWORD)>(Connect)),
checkoption(Disconnect, std::function<void(DWORD)>(Disconnect)),
checkoption(Create, [=](const TextThread &thread)
{ Create(thread.hp.hookcode, thread.hp.name, thread.tp, thread.hp.type & EMBED_ABLE); }),
checkoption(Destroy, [=](const TextThread &thread)
{ Destroy(thread.hp.hookcode, thread.hp.name, thread.tp); }),
checkoption(Output, [=](const TextThread &thread, std::wstring &output)
{ return Output(thread.hp.hookcode, thread.hp.name, thread.tp, output.c_str()); }),
2024-11-28 16:59:08 +08:00
false,
checkoption(hostinfo, [=](HOSTINFO type, const std::wstring &output)
{ hostinfo(type, output.c_str()); }),
2024-11-06 06:46:35 +08:00
checkoption(hookinsert, [=](DWORD pid, uint64_t addr, const std::wstring &hookcode)
{ hookinsert(pid, addr, hookcode.c_str()); }),
checkoption(embed, [=](const std::wstring &output, const ThreadParam &tp)
2024-11-28 16:59:08 +08:00
{ embed(output.c_str(), tp); }));
2024-11-06 06:46:35 +08:00
}
2025-01-01 19:52:20 +08:00
#if 0
2024-11-06 06:46:35 +08:00
C_LUNA_API void Luna_Inject(DWORD pid, LPCWSTR basepath)
{
Host::InjectProcess(pid, basepath);
}
2025-01-01 19:52:20 +08:00
#endif
2024-11-06 06:46:35 +08:00
C_LUNA_API bool Luna_CreatePipeAndCheck(DWORD pid)
{
return Host::CreatePipeAndCheck(pid);
}
C_LUNA_API void Luna_Detach(DWORD pid)
{
Host::DetachProcess(pid);
}
C_LUNA_API void Luna_Settings(int flushDelay, bool filterRepetition, int defaultCodepage, int maxBufferSize, int maxHistorySize)
{
TextThread::flushDelay = flushDelay;
TextThread::filterRepetition = filterRepetition;
Host::defaultCodepage = defaultCodepage;
TextThread::maxBufferSize = maxBufferSize;
TextThread::maxHistorySize = maxHistorySize;
}
2025-01-04 17:59:00 +08:00
C_LUNA_API void Luna_SetLanguage(const char *lang)
2024-12-16 01:48:39 +08:00
{
Host::SetLanguage(lang);
}
2024-11-14 20:32:39 +08:00
C_LUNA_API void Luna_InsertPCHooks(DWORD pid, int which)
{
Host::InsertPCHooks(pid, which);
}
2024-11-06 06:46:35 +08:00
C_LUNA_API bool Luna_InsertHookCode(DWORD pid, LPCWSTR hookcode)
{
auto hp = HookCode::Parse(hookcode);
if (hp)
Host::InsertHook(pid, hp.value());
return hp.has_value();
}
C_LUNA_API void Luna_QueryThreadHistory(ThreadParam tp, void (*callback)(const wchar_t *))
{
auto s = Host::GetThread(tp).storage.Acquire();
callback(s->c_str());
}
C_LUNA_API void Luna_RemoveHook(DWORD pid, uint64_t addr)
{
Host::RemoveHook(pid, addr);
}
C_LUNA_API void Luna_FindHooks(DWORD pid, SearchParam sp, findhookcallback_t findhookcallback)
{
Host::FindHooks(pid, sp, [=](HookParam hp, std::wstring text)
{
wchar_t hookcode[HOOKCODE_LEN];
wcscpy_s(hookcode,HOOKCODE_LEN, hp.hookcode);
findhookcallback(hookcode,text.c_str()); });
}
2024-12-21 22:46:35 +08:00
C_LUNA_API void Luna_EmbedSettings(DWORD pid, UINT32 waittime, UINT8 fontCharSet, bool fontCharSetEnabled, wchar_t *fontFamily, Displaymode displaymode, bool fastskipignore)
2024-11-06 06:46:35 +08:00
{
auto sm = Host::GetCommonSharedMem(pid);
if (!sm)
return;
sm->waittime = waittime;
sm->fontCharSet = fontCharSet;
sm->fontCharSetEnabled = fontCharSetEnabled;
2025-01-04 17:59:00 +08:00
wcscpy_s(sm->fontFamily, ARRAYSIZE(sm->fontFamily), fontFamily);
2024-12-21 22:46:35 +08:00
sm->displaymode = displaymode;
2024-11-06 06:46:35 +08:00
sm->fastskipignore = fastskipignore;
}
C_LUNA_API bool Luna_checkisusingembed(ThreadParam tp)
{
2024-11-06 07:27:43 +08:00
return Host::CheckIsUsingEmbed(tp);
2024-11-06 06:46:35 +08:00
}
C_LUNA_API void Luna_useembed(ThreadParam tp, bool use)
{
auto sm = Host::GetCommonSharedMem(tp.processId);
if (!sm)
return;
sm->codepage = Host::defaultCodepage;
for (int i = 0; i < ARRAYSIZE(sm->embedtps); i++)
{
if (sm->embedtps[i].use && (sm->embedtps[i].tp == tp))
if (!use)
ZeroMemory(sm->embedtps + i, sizeof(sm->embedtps[i]));
}
if (use)
for (int i = 0; i < ARRAYSIZE(sm->embedtps); i++)
{
if (!sm->embedtps[i].use)
{
sm->embedtps[i].use = true;
sm->embedtps[i].tp = tp;
break;
}
}
}
C_LUNA_API void Luna_embedcallback(ThreadParam tp, LPCWSTR text, LPCWSTR trans)
{
auto sm = Host::GetCommonSharedMem(tp.processId);
if (!sm)
return;
wcsncpy(sm->text, trans, ARRAYSIZE(sm->text));
char eventname[1000];
sprintf(eventname, LUNA_EMBED_notify_event, tp.processId, simplehash::djb2_n2((const unsigned char *)(text), wcslen(text) * 2));
win_event event1(eventname);
event1.signal(true);
}
C_LUNA_API void Luna_SyncThread(ThreadParam tp, bool sync)
{
// 必须放到线程里去异步做不然GetThread死锁
std::thread([=]()
{
try
{
auto &&t=Host::GetThread(tp);
if (sync)
TextThread::syncThreads->insert(&t);
else
TextThread::syncThreads->erase(&t);
}
catch (...)
{
} })
.detach();
}