Cross Site Scripting (XSS) vulnerability ?
-
Got this notification today. Update needed?
WordPress Secondary Title plugin <= 2.0.9.1 – Cross Site Scripting (XSS) vulnerability
-
Thanks for bringing this to my attention. Where did you receive this information, and can you provide further details?
My warning was from WP Toolkit (Plesk server)
Hi all,
As there’s only very little information on how the vulnerability was detected, I have to go through every file. But this will be fixed ASAP!
Thanks so much for your patience.
Hi all,
I’m working on it as we speak. However, those companies aren’t really revealing ANY data whatsoever that could at least help reproduce the attack. Until then, I have to keep digging.
Small gain: The vulnerability is not very high.
If you’d like to help, I could find a copy of your “Health Manager” diagnosis text report helpful.
Hi @blackboxz and others,
To be honest, I am considering giving it up. Being a plugin developer for WordPress in 2023 is different than how it was when I made Secondary Title a couple of years ago. The community has changed as well; instead of feedback, I only hear demands as if I had a legal responsibility to keep the plugin up to date until I die. You can see an example in @show-up-strong’s post.
In addition to that, I’m unable even to offer the help I want to give the users of my plugin because it violates WP.org’s forum rules. My comments regularly get moderated and only become visible once mods have checked them. I was also threatened that my account would be deleted. This has left a bitter taste and pushed me even further away from the WP community.
The security issue is another thing. Unfortunately, I’ve never been informed by the auditor and to this day have zero information on what exactly has to be fixed. There’s only one way to eliminate any possible XSS scenarios, which is escaping sequences for user input (title format or the secondary title itself), which would render the entire “Title format” feature of the plugin useless.
That’s why I’m asking myself: is this all still worth it?
Hey @thaikolja, I just wanted to say I appreciate supporting the plugin up to this point. I wanted to attempt to provide some assistance with solving the issue where I can, but you would probably have the most insight into things.
The only details on the vulnerability I could find was from the WordFence article where it mentions:
“with contributor-level access and above, to inject arbitrary web scripts in pages that will execute whenever a user accesses an injected page”
https://www.wordfence.com/threat-intel/vulnerabilities/wordpress-plugins/secondary-title/secondary-title-2091-authenticated-contributor-stored-cross-site-scriptingI pulled the code down from Github and have been looking into it. As far as I’ve been able to determine, there is nothing that sanitizes or filters user input into the
_secondary_title
meta field. This might be intentional to allow for user input to include raw html for formatting purposes, but it does also allow for user input to include something like<script>alert(‘XSS’)</script>
or<iframe src="https://www.ads-software.com/"/>
which is the concern for XSS.The
secondary_title_auto_show()
function is what renders the subtitle in, what I assume, most cases. Inside that function, the code essentially just appends the raw (html decoded) subtitle into the new title string and is returned as the unfiltered output to the frontend.Both the unfiltered input and the unfiltered output is where the XSS concern appears to be present. That and the fact that a contributor has the capability to inject whatever they want (despite not being able to publish) is probably not ideal.
I think there are two possible solutions to this. But I’m unsure on the original intent for what you want a user to be able to do. The plugin settings page is only accessible to users with manage_options perms so it could be an option to simply restrict any styling/html input to the settings page.
Regarding actual filtering of the input/output the
_secondary_title
meta, the first option would be to filter the user input. Thesecondary_title_edit_post()
function does useesc_attr()
on the user input to encode html entities but there is no additional input filtering or validation that prevents users from injecting whatever else they want into the DB. All it does is encode the input. A basic option could be to usestrip_tags()
which would prevent html tags specifically but the effectiveness of that option for XSS is limited by itself. A combination ofstrip_tags()
andesc_html()
can clean up input to an extent.The second option would be to capture and filter the output using similar methods and ensure the
_secondary_title
meta is not returned as decoded html that could contain XSS routes. Keeping the the data encoded, stripping tags, or implementing some other data filtering on the output should also resolve the issue with XSS.Hope this helps!
Hi @kdowns,
Thanks for taking the time and giving your advice.
Unfortunately, most users do use HTML within the secondary title. Stripping tags would therefore render the plugin more or less useless. The only thing I can think of is to decouple the formatting part to the settings page, as you’ve pointed out. Any specific advise on this?
I reached out to Kolja directly in email and WordPress slack but have not yet heard back. I made a pretty basic fork of the plugin at https://github.com/kylendowns/secondary-title/tree/antixss which implements an antixss package to protect (only) the html output. It still could use some refinement (which I’m messing with on the side) so I might not recommend this as an official solution, but it might be a decent option in the meantime if wanting to implement some form of XSS protection while continuing to use the plugin.
Hi @all,
I will implement a fix for the XSS vulnerability soon. Since there’s no real way around it, I’ll restrict the usage of HTML to the settings page only.
Thanks for all your suggestions.
@thaikolja Thank you!
Hello thaikolja, do we get notified through www.ads-software.com of an update?
All updates will go through the default WP update page.
Ok, would it be available soon maybe?
As we speak ?? Wanna be a beta tester?
- The topic ‘Cross Site Scripting (XSS) vulnerability ?’ is closed to new replies.