2019-08-27 06:02:24 +00:00
|
|
|
/*******************************************************************************
|
|
|
|
*
|
2020-05-31 07:39:46 +00:00
|
|
|
* (C) COPYRIGHT AUTHORS, 2019 - 2020
|
2019-08-27 06:02:24 +00:00
|
|
|
*
|
|
|
|
* TITLE: MAIN.H
|
|
|
|
*
|
|
|
|
* VERSION: 1.00
|
|
|
|
*
|
2020-05-31 07:39:46 +00:00
|
|
|
* DATE: 29 May 2020
|
2019-08-27 06:02:24 +00:00
|
|
|
*
|
|
|
|
* WinObjEx64 example and test plugin.
|
|
|
|
*
|
|
|
|
* THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
|
|
|
|
* ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED
|
|
|
|
* TO THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
|
|
|
|
* PARTICULAR PURPOSE.
|
|
|
|
*
|
|
|
|
*******************************************************************************/
|
|
|
|
|
|
|
|
#include <Windows.h>
|
|
|
|
#include <strsafe.h>
|
|
|
|
|
|
|
|
#pragma warning(push)
|
|
|
|
#pragma warning(disable: 4005)
|
|
|
|
#include <ntstatus.h>
|
|
|
|
#pragma warning(pop)
|
|
|
|
#include "ntos/ntos.h"
|
|
|
|
#include "plugin_def.h"
|
|
|
|
|
|
|
|
BOOL g_StopPlugin = FALSE;
|
|
|
|
HANDLE g_hThread = NULL;
|
|
|
|
WINOBJEX_PARAM_BLOCK g_ParamBlock;
|
|
|
|
WINOBJEX_PLUGIN *g_Plugin;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* PluginThread
|
|
|
|
*
|
|
|
|
* Purpose:
|
|
|
|
*
|
|
|
|
* Plugin payload thread.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
DWORD WINAPI PluginThread(
|
|
|
|
_In_ PVOID Parameter
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UNREFERENCED_PARAMETER(Parameter);
|
|
|
|
|
|
|
|
MessageBox(GetDesktopWindow(), TEXT("This is message from example plugin, plugin will stop in 5 sec."), TEXT("ExamplePlugin"), MB_ICONINFORMATION);
|
|
|
|
|
|
|
|
Sleep(5000);
|
|
|
|
g_StopPlugin = TRUE;
|
|
|
|
|
|
|
|
g_Plugin->StateChangeCallback(g_Plugin, PluginStopped, NULL);
|
|
|
|
ExitThread(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* StartPlugin
|
|
|
|
*
|
|
|
|
* Purpose:
|
|
|
|
*
|
|
|
|
* Run actual plugin code in dedicated thread.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
NTSTATUS CALLBACK StartPlugin(
|
|
|
|
_In_ PWINOBJEX_PARAM_BLOCK ParamBlock
|
|
|
|
)
|
|
|
|
{
|
|
|
|
DWORD ThreadId;
|
|
|
|
NTSTATUS Status;
|
|
|
|
WINOBJEX_PLUGIN_STATE State = PluginInitialization;
|
|
|
|
|
|
|
|
DbgPrint("StartPlugin called from thread 0x%lx\r\n", GetCurrentThreadId());
|
|
|
|
|
|
|
|
RtlCopyMemory(&g_ParamBlock, ParamBlock, sizeof(WINOBJEX_PARAM_BLOCK));
|
|
|
|
g_StopPlugin = FALSE;
|
|
|
|
g_hThread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)PluginThread, (PVOID)NULL, 0, &ThreadId);
|
|
|
|
if (g_hThread) {
|
|
|
|
Status = STATUS_SUCCESS;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
Status = STATUS_UNSUCCESSFUL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NT_SUCCESS(Status))
|
|
|
|
State = PluginRunning;
|
|
|
|
else
|
|
|
|
State = PluginError;
|
|
|
|
|
|
|
|
g_Plugin->StateChangeCallback(g_Plugin, State, NULL);
|
|
|
|
|
|
|
|
return Status;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* StopPlugin
|
|
|
|
*
|
|
|
|
* Purpose:
|
|
|
|
*
|
|
|
|
* Stop plugin execution.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void CALLBACK StopPlugin(
|
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
DbgPrint("StopPlugin called from thread 0x%lx\r\n", GetCurrentThreadId());
|
|
|
|
|
|
|
|
if (g_hThread) {
|
|
|
|
InterlockedExchange((PLONG)&g_StopPlugin, 1);
|
|
|
|
if (WaitForSingleObject(g_hThread, 1000) == WAIT_TIMEOUT) {
|
2020-05-31 07:39:46 +00:00
|
|
|
DbgPrint("Wait timeout, terminating plugin thread, g_hTread = %llx\r\n", g_hThread);
|
2019-08-27 06:02:24 +00:00
|
|
|
TerminateThread(g_hThread, 0);
|
|
|
|
}
|
|
|
|
else {
|
2020-05-31 07:39:46 +00:00
|
|
|
DbgPrint("Wait success, plugin thread stoped, g_Thread = %llx\r\n", g_hThread);
|
2019-08-27 06:02:24 +00:00
|
|
|
}
|
|
|
|
CloseHandle(g_hThread);
|
|
|
|
g_hThread = NULL;
|
|
|
|
g_Plugin->StateChangeCallback(g_Plugin, PluginStopped, NULL);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* PluginInit
|
|
|
|
*
|
|
|
|
* Purpose:
|
|
|
|
*
|
|
|
|
* Initialize plugin information for WinObjEx64.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
BOOLEAN CALLBACK PluginInit(
|
|
|
|
_Out_ PWINOBJEX_PLUGIN PluginData
|
|
|
|
)
|
|
|
|
{
|
|
|
|
__try {
|
|
|
|
//
|
|
|
|
// Set plugin name to be displayed in WinObjEx64 UI.
|
|
|
|
//
|
|
|
|
StringCbCopy(PluginData->Description, sizeof(PluginData->Description), TEXT("ExamplePlugin"));
|
|
|
|
|
|
|
|
//
|
|
|
|
// Setup start/stop plugin callbacks.
|
|
|
|
//
|
|
|
|
PluginData->StartPlugin = (pfnStartPlugin)&StartPlugin;
|
|
|
|
PluginData->StopPlugin = (pfnStopPlugin)&StopPlugin;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Setup permissions.
|
|
|
|
//
|
|
|
|
PluginData->NeedAdmin = FALSE;
|
|
|
|
PluginData->SupportWine = TRUE;
|
|
|
|
PluginData->NeedDriver = FALSE;
|
|
|
|
|
|
|
|
PluginData->MajorVersion = 1;
|
|
|
|
PluginData->MinorVersion = 0;
|
|
|
|
g_Plugin = PluginData;
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
__except (EXCEPTION_EXECUTE_HANDLER) {
|
|
|
|
DbgPrint("PluginInit exception thrown %lx\r\n", GetExceptionCode());
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* DllMain
|
|
|
|
*
|
|
|
|
* Purpose:
|
|
|
|
*
|
|
|
|
* Dummy dll entrypoint.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
BOOL WINAPI DllMain(
|
|
|
|
_In_ HINSTANCE hinstDLL,
|
|
|
|
_In_ DWORD fdwReason,
|
|
|
|
_In_ LPVOID lpvReserved
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UNREFERENCED_PARAMETER(lpvReserved);
|
|
|
|
|
|
|
|
if (fdwReason == DLL_PROCESS_ATTACH) {
|
|
|
|
DisableThreadLibraryCalls(hinstDLL);
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
}
|