Skip to main content

Site Takeover Campaign Exploits Multiple Zero-Day Vulnerabilities

This entry was posted in VulnerabilitiesWordPress Security on February 27, 2020 by Mikey Veenstra   0 RepliesEarly yesterday, the Flexible Checkout Fields for WooCommerce plugin received a critical update to patch a zero-day vulnerability which allowed attackers to modify the plugin’s settings. As our Threat Intelligence team researched the scope of this attack campaign, we discovered three additional zero-day vulnerabilities in popular WordPress plugins that are being exploited as a part of this campaign. The targeted plugins were Async JavaScriptModern Events Calendar Lite, and 10Web Map Builder for Google Maps. At this time, we have reached out to each plugin’s development team in hopes of getting these issues resolved quickly.
This attack campaign exploits XSS vulnerabilities in the above plugins to inject malicious Javascript that can create rogue WordPress administrators and install malicious plugins that include backdoors. It is important that site administrators using these plugins urgently take steps to mitigate these attacks.

Today’s post gives an overview of these vulnerabilities to inform the community of their current risk. More details of this campaign will be considered in a forthcoming blog post.
Description: Unauthenticated Stored XSS via Plugin Settings Change
Affected Plugin: Flexible Checkout Fields for WooCommerce
Affected Versions: <= 2.3.1
CVSS Score: 9.3 (Critical)
CVSS Vector: CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:N
Patched Version: 2.3.2
In a report released yesterday by NinTechNet, researchers alerted the community to the presence of this vulnerability and the attacks against it. Unauthenticated attackers are capable of modifying the plugin’s options, which can be leveraged to inject XSS payloads that can be triggered in the dashboard of a logged-in administrator.
Flexible Checkout Fields versions up to 2.3.1 are vulnerable to these attacks. The plugin’s developers, WP Desk, issued a patch with version 2.3.2 quickly after they were made aware of the issue. Since then, they’ve issued two more updates to implement some additional security measures. The WordPress.org repository reports an install base of more than 20,000 sites with the plugin. We urge all of the plugin’s users to update to the latest available version as quickly as possible to reduce their risk of exploitation.
This vulnerability was due to a lack of capabilities checks on the plugin’s settings update function. In classes/settings.php, the function updateSettingsAction() is hooked into the WordPress admin_init hook. This hook fires when any /wp-admin/ endpoint is accessed, including those that don’t require authentication.
269
270
271
272
273
274
275
276
277
278
279
280
281
public function updateSettingsAction(){
    if ( !empty( $_POST ) ) {
        if ( !empty($_POST['option_page']) && in_array( $_POST['option_page'], array('inspire_checkout_fields_settings', 'inspire_checkout_fields_checkboxes') ) ) {
            if ( !empty( $_POST[$this->plugin->get_namespace()] ) ) {
                foreach ( $_POST[$this->plugin->get_namespace()] as $name => $value ) {
                    $settings = get_option( 'inspire_checkout_fields_' . $name, array() );
                    if ( is_array( $value )) {
                        foreach ( $value as $key => $val ) {
                            $settings[$key] = $val;
The snippet above shows the first several lines of the function, which makes some checks for certain $_POST values but no security checks. By crafting an array of expected settings, attackers can inject JavaScript payloads into the elements that render onscreen.
This vulnerability was patched by the plugin developers by implementing a capabilities check to ensure only administrators can modify these settings.
Description: Subscriber+ Stored XSS via Plugin Settings Change
Affected Plugin: Async JavaScript
Affected Versions: <= 2.19.07.14
CVSS Score: 7.6 (High)
CVSS Vector: CVSS:3.0/AV:N/AC:L/PR:L/UI:R/S:C/C:L/I:H/A:N
Patched Version: 2.20.02.27
A similar vulnerability exists in the popular Async JavaScript Plugin, which is currently active on more than 100,000 WordPress sites. We notified the plugin’s developer, Frank Goossens, who quickly released a patch for this issue. Because the update was made available so recently, we are providing limited details about the vulnerability at this time.
Async JavaScript’s settings are modified via calls to wp-admin/admin-ajax.php with the action aj_steps. This AJAX action is registered only for authenticated users, but no capabilities checks are made. Because of this, low-privilege users including Subscribers can modify the plugin’s settings.
Similar to Flexible Checkout Fields above, certain setting values can be injected with a crafted payload to execute malicious JavaScript when a WordPress administrator views certain areas of their dashboard.
Description: Unauthenticated Stored XSS via Plugin Settings Change
Affected Plugin: 10Web Map Builder for Google Maps
Affected Versions: <= 1.0.63
CVSS Score: 9.3 (Critical)
CVSS Vector: CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:N
Patched Version: None Yet Available
A third XSS via settings change vulnerability is present in 10Web Map Builder for Google Maps. This plugin is active on over 20,000 sites. Unlike Async JavaScript, this vulnerability can be exploited by unauthenticated attackers.
We have reached out to establish contact with the plugin’s developers and are awaiting their response at this time. As with the previous vulnerability, because it’s under attack in the wild we are providing limited detail.
The vulnerability in 10Web Map Builder exists in the plugin’s setup process. The plugin’s setup functions are called during admin_init which, like Flexible Checkout Fields, is accessible to unauthenticated users. If an attacker injects malicious JavaScript into certain settings values, that code will execute for administrators in their dashboard as well as front-of-site visitors in some circumstances.
Description: Multiple Subscriber+ Stored XSS Vulnerabilities
Affected Plugin: Modern Events Calendar Lite
Affected Versions: <= 5.1.6
CVSS Score: 7.6 (High)
CVSS Vector: CVSS:3.0/AV:N/AC:L/PR:L/UI:R/S:C/C:L/I:H/A:N
Patched Version: None Yet Available
The last vulnerability in this report affects Modern Events Calendar Lite, with over 40,000 installs.
We have reached out to establish contact with the developer and are awaiting response. Again, as this issue is known to malicious actors, we are making the community aware of it.
Modern Events Calendar Lite registers a number of AJAX actions for logged-in users. Some of these actions allow low-privileged users like subscribers to manipulate settings and other stored data. When exploited in this way, the affected data can be injected with various XSS payloads.
Depending on where the attackers inserted code, these scripts can be executed in the WordPress dashboard to affect administrators, or on the front of the victim’s site to affect their visitors. Current attacks in this campaign are targeting administrators in order to create rogue accounts for the attackers.
Today we disclosed three new zero-day vulnerabilities affecting the WordPress ecosystem. We are working to assist these developers to quickly resolve these vulnerabilities, but some remain unpatched at this time. We take the security disclosure process very seriously, and we would not publish these details if it wasn’t necessary to alert the WordPress community about their risk in the midst of this campaign.
The XSS attacks used in this campaign are reliably blocked by the Wordfence firewall’s built-in protections, which are available to Wordfence Premium users as well as sites still on the free version. New WAF rules to prevent other disruptive activity are also available to Premium users at this time.
Because these attacks are ongoing, research into this campaign is still underway. We will publish a follow-up post with complete details on these attacks as soon as this research is complete. Make sure you are informed as soon as possible by subscribing to our mailing list.

Godesigny.com is the best web design and development company, we follow Wordfence and prefer Wordfence for website security. More about our service click here Thanks Wordfence once again for useful information.  

This work would not be possible without the combined efforts of the Wordfence team. Special thanks to Director of Threat Intelligence Sean Murphy, QA Lead Matt Rusnak, and QA Engineer Ramuel Gall for their contributions to the discovery and research of these attacks, analysis and disclosure of the vulnerabilities, and assistance in editing this post. 

Comments

Popular posts from this blog

Website Freelancer vs Agency, Which one Best for Development Work?

Because of sudden rise in the digital marketing domain, many business companies and enterprises are making e-commerce and mobile marketing a top priority. Thus, job opportunities for the web developers are increasing constantly from last some years and so is the requirement of the professional Website design companies. Nonetheless, as you might already know, more choices and opportunities you have, more challenging this becomes to select one among all of them. Before you settle for the freelance Website developer, you must consider weighing advantages and disadvantages of working with the freelancer versus developing agency. In that way, you will select the right person or agency for building your WP website. Website Freelancer vs Agency, Which one Best for Development Work But, still it has got its own benefits and drawbacks that make them the right option for a few people and worst for others. Thus, if you wish to know a little more about aspects of freelancer and agenc...

UX vs UI: The Difference User Experience vs User Interface

The world of web design is replete with acronyms, many of which have similar or overlapping meanings. Two of the most prominent ones are UX and UI. Standing for user experience and user interface, respectively, these two words help shape the design constructs that define every website and app on the internet. Yet, what do they mean, exactly? More importantly, which one should you prioritize in your own web development efforts? Today, we’re taking an in-depth look at the answers to these questions. Read on to learn everything you need to know about UX vs UI from their definitions to their profitability. The Difference User Experience vs User Interface What Does UI Mean? The “UI” in UI design means “user interface.” It encompasses all of the interactive elements that make up the graphical layout of a digital product or service. It sounds oversimplified, but the reality is that applications and websites don’t create themselves. Behind every interaction, visualization, ...

SEO Tips to Convert Your Leads into Customers

Search Engine Optimization is a useful practice that helps us to maximize the website’s organic traffic reach. However, the methods used to improve SEO can sometimes be at odds with our CRO (Conversion Rate Optimization) strategy.  Fortunately, most modern SEO methods are fully compatible with CRO, in fact, some SEO methods can actually make it easier to convert your leads into customers. This article will cover some of the SEO methods that will make your website convert like crazy. Page Load Time Page load time is a very important metric for both SEO and conversion. Slow page loading will significantly impact your SEO, and the customers hate it too. When the page takes too long to load, customers are very likely to abandon it. Page load time plays a vital role in the overall user experience of the website. Search engines like Google heavily punish slow load times which is why it’s important to work on this. Google approximates a 3 second load time before the visitors get an...