The following vulnerability was detected in Zoho CRM Lead Magnet Version 1.7.2.4
Issue: Stored Cross-Site Scripting.
Steps to Reproduce:
1. Log in to the WordPress application.
Note: A virtual host (wptest.com) was used to test the application locally.
2. Install the Zoho CRM Lead Magnet Plugin.
data:image/s3,"s3://crabby-images/bbaf7/bbaf7a4bb037708c9c0dbdd6e481ac1b281e6f5d" alt=""
Figure 01: Zoho CRM Lead Magnet Version 1.7.2.4
3. Configure the Client ID and Secret Key.
4. Click the ‘Create New Form’ button, fill the values, and then click the ‘Next’ button.
data:image/s3,"s3://crabby-images/235a0/235a05296f24da725f3525a70f1e77007fe1bf45" alt=""
Figure 02: New form in Zoho CRM Plugin
5. Encode the payload <img src=x onerror=alert(document.cookie)> with a hexadecimal HTML encoder.
data:image/s3,"s3://crabby-images/764ca/764caa92dfb0ca7b819ee6b06e30c51aa8d2d39c" alt=""
Figure 03: Encoding the Payload
6. Enter the encoded payload in the ‘Form Name’ field (formvalue parameter) to update the form. Then, click the arrow button near the ‘Create a New Form’ heading to go back to the previous page.
data:image/s3,"s3://crabby-images/c551c/c551c21ee4bc4c569b4f064f620decb7de60d819" alt=""
Figure 04: Entering Encoded Xss Payload In The ‘form Name’ Field
7. Click on the pencil icon to edit the created form.
data:image/s3,"s3://crabby-images/dd5ba/dd5bac709704f504cf371771099a6327b9965cfc" alt=""
Figure 05: Click on the Pencil Icon to Edit the Form
8. Change any form value, such as ‘Company’ or the ‘Last Name’.
data:image/s3,"s3://crabby-images/540f8/540f817933507c48a46270106831183e61ed8256" alt=""
Figure 06: Modifying Form Fields
data:image/s3,"s3://crabby-images/4c979/4c979d19b3712fcd3c56d79f6d5963ce23ea1810" alt=""
Figure 07: Injected XSS Payload Executed Displaying An Alert Box With Contents of the User’s Cookies
9. The XSS payload is also executed when the user tries to delete the form.
data:image/s3,"s3://crabby-images/199ea/199ea9a1d78f4d806afe65e6701ecd42cad8735e" alt=""
Figure 08: XSS Payload Executed When the User Tries To Delete the Form