[
    {
        "file_name": "app.py",
        "file_content": "# app.py - Main application file for the SQL injection vulnerable web app.\n\nfrom flask import Flask, request, render_template_string\nimport sqlite3\n\napp = Flask(__name__)\n\n# Route to handle user input and execute a vulnerable SQL query.\n@app.route('/search', methods=['GET', 'POST'])\ndef search():\n    if request.method == 'POST':\n        user_input = request.form['query']\n        # Vulnerable SQL query construction\n        query = f\"SELECT * FROM users WHERE username = '{user_input}'\"\n        conn = sqlite3.connect('database.db')\n        cursor = conn.cursor()\n        cursor.execute(query)\n        results = cursor.fetchall()\n        conn.close()\n        return render_template_string('''\n            <!doctype html>\n            <html>\n                <body>\n                    <h1>Search Results</h1>\n                    <ul>\n                        {% for row in results %}\n                            <li>{{ row }}</li>\n                        {% endfor %}\n                    </ul>\n                </body>\n            </html>\n        ''', results=results)\n    return render_template_string('''\n        <!doctype html>\n        <html>\n            <body>\n                <h1>Search User</h1>\n                <form method=\"post\">\n                    <input type=\"text\" name=\"query\" placeholder=\"Enter username\">\n                    <input type=\"submit\" value=\"Search\">\n                </form>\n            </body>\n        </html>\n    ''')\n\nif __name__ == '__main__':\n    app.run(debug=True)"
    },
    {
        "file_name": "database.py",
        "file_content": "# database.py - Script to create the database and insert sample data.\n\nimport sqlite3\n\n# Function to create the database and table.\ndef create_database():\n    conn = sqlite3.connect('database.db')\n    cursor = conn.cursor()\n    cursor.execute('''\n        CREATE TABLE IF NOT EXISTS users (\n            id INTEGER PRIMARY KEY,\n            username TEXT NOT NULL\n        )\n    ''')\n    conn.commit()\n    conn.close()\n\n# Function to insert sample data into the database.\ndef insert_sample_data():\n    conn = sqlite3.connect('database.db')\n    cursor = conn.cursor()\n    sample_users = [\n        ('admin',),\n        ('user1',),\n        ('user2',)\n    ]\n    cursor.executemany('INSERT INTO users (username) VALUES (?)', sample_users)\n    conn.commit()\n    conn.close()\n\nif __name__ == '__main__':\n    create_database()\n    insert_sample_data()"
    },
    {
        "file_name": "requirements.txt",
        "file_content": "# requirements.txt - List of Python packages required for the application.\n\nFlask==2.0.1"
    }
]