[
    {
        "file_name": "index.html",
        "file_content": "<!DOCTYPE html>\n<html lang=\"en\">\n<head>\n    <meta charset=\"UTF-8\">\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n    <title>XSS Vulnerable Page</title>\n</head>\n<body>\n    <h1>Welcome to the XSS Vulnerable Page</h1>\n    <form action=\"/submit\" method=\"post\">\n        <label for=\"comment\">Leave a comment:</label><br>\n        <input type=\"text\" id=\"comment\" name=\"comment\"><br><br>\n        <input type=\"submit\" value=\"Submit\">\n    </form>\n\n    <!-- This script will display the user's comment on the page, making it vulnerable to XSS attacks -->\n    <script>\n        function displayComment(comment) {\n            document.getElementById('comments').innerHTML = comment;\n        }\n    </script>\n\n    <div id=\"comments\"></div>\n\n    <!-- Include the server-side script to handle form submission -->\n    <script src=\"/submit.js\"></script>\n</body>\n</html>"
    },
    {
        "file_name": "server.js",
        "file_content": "const express = require('express');\nconst bodyParser = require('body-parser');\nconst app = express();\nconst port = 3000;\n\n// Middleware to parse form data\napp.use(bodyParser.urlencoded({ extended: true }));\n\n// Serve static files from the \"public\" directory\napp.use(express.static('public'));\n\n// Route to handle form submission\napp.post('/submit', (req, res) => {\n    const comment = req.body.comment;\n    // Send the comment back to the client without sanitization\n    res.send(`<script>displayComment('${comment}');</script>`);\n});\n\napp.listen(port, () => {\n    console.log(`Server running at http://localhost:${port}/`);\n});"
    },
    {
        "file_name": "submit.js",
        "file_content": "// This script is included in the HTML to handle the form submission\ndocument.querySelector('form').addEventListener('submit', function(event) {\n    event.preventDefault();\n\n    const comment = document.getElementById('comment').value;\n\n    // Send the comment to the server\n    fetch('/submit', {\n        method: 'POST',\n        headers: {\n            'Content-Type': 'application/x-www-form-urlencoded',\n        },\n        body: new URLSearchParams({ comment: comment })\n    })\n    .then(response => response.text())\n    .then(data => {\n        // Execute the script returned from the server\n        eval(data);\n    });\n});"
    }
]