Services - Critical - Arbitrary Code Execution - SA-CONTRIB-2017-003

Date: 
Mar 8th, 2017
Security risk: 
Critical
Vulnerability: 
Arbitrary PHP code execution

This module provides a standardized solution for building API's so that external clients can communicate with Backdrop.

The module accepts user submitted data in PHP's serialization format ("Content-Type: application/vnd.php.serialized") which can lead to arbitrary remote code execution.

This vulnerability is mitigated by the fact that an attacker must know your Service Endpoint's path, and your Service Endpoint must have "application/vnd.php.serialized" enabled as a request parser.

Advisory ID: 
BACKDROP-SA-CONTRIB-2017-003
Versions affected: 
  • Services 1.x versions prior to 1.x-3.0.1-beta

Backdrop core is not affected. If you do not use the contributed Services module, there is nothing you need to do. 

Metatag - Moderately Critical - Information disclosure - SA-CONTRIB-2017-002

Date: 
Mar 8th, 2017
Security risk: 
Moderately Critical
Vulnerability: 
Information Disclosure

This module enables you to add a variety of meta tags to a site for helping with a site's search engine results and to customize how content is shared on social networks.

The module doesn't sufficiently protect against data being cached that might contain information related to a specific user.

This vulnerability is mitigated by the fact that a site must have a page with sensitive data in the page title that varies per logged in user.

Advisory ID: 
BACKDROP-SA-CONTRIB-2017-002
Versions affected: 
  • Metatag 0.x and 1.x versions prior to 1.21.0

Backdrop core is not affected. If you do not use the contributed Metatag module, there is nothing you need to do.

Better Exposed Filters - Less Critical - Cross Site Scripting - SA-CONTRIB-2017-001

Date: 
Mar 4th, 2017
Security risk: 
Less Critical
Vulnerability: 
Cross Site Scripting

The Better Exposed Filters module gives site builders more choices for rendering Views' exposed form elements.

The module does not sufficiently sanitize taxonomy term descriptions when the "Include the term description" option is selected.

This vulnerability is mitigated by the fact that an attacker must have a role with the permission "administer taxonomy".

Advisory ID: 
BACKDROP-SA-CONTRIB-2017-001
Versions affected: 

Backdrop core is not affected. If you do not use the contributed Better Exposed filters module, there is nothing you need to do. 

Backdrop core - Multiple Vulnerabilities - SA-CORE-2016-003

Date: 
Nov 15th, 2016
Vulnerabilities: 
  • Open Redirect
  • Denial of Service
  • Multiple vulnerabilities

Inconsistent name for term access query

Backdrop provides a mechanism to alter database SELECT queries before they are executed. Contributed and custom modules may use this mechanism to restrict access to certain entities by implementing hook_query_alter() or hook_query_TAG_alter() in order to add additional conditions. Queries can be distinguished by means of query tags. As the documentation on EntityFieldQuery::addTag() suggests, access-tags on entity queries normally follow the form ENTITY_TYPE_access (e.g. node_access). However, the taxonomy module's access query tag predated this system and used term_access as the query tag instead of taxonomy_term_access.

As a result, before this security release modules wishing to restrict access to taxonomy terms may have implemented an unsupported tag, or needed to look for both tags (term_access and taxonomy_term_access) in order to be compatible with queries generated both by Backdrop core as well as those generated by contributed modules like Reference. Otherwise information on taxonomy terms might be disclosed to unprivileged users.

Cancel links on entity and confirmation forms allow external URLs to be injected

Under some conditions this would allow the cancel links in some forms to redirect to an external site.

Denial of service via transliterate mechanism

A specially crafted URL can cause a denial of service via the transliterate mechanism.

Advisory ID: 
BACKDROP-SA-CORE-2016-003
Versions affected: 
  • Backdrop Core 1.5.x versions prior to 1.5.2

Backdrop core - Multiple vulnerabilities - SA-CORE-2015-003

Date: 
May 6th, 2016
Vulnerabilities: 
  • Information Disclosure
  • Open Redirect
  • Multiple vulnerabilities

Open redirect (Field UI module)

The Field UI module uses a "destinations" query string parameter in URLs to redirect users to new destinations after completing an action on a few administration pages. Under certain circumstances, malicious users can use this parameter to construct a URL that will trick users into being redirected to a 3rd party website, thereby exposing the users to potential social engineering attacks. This vulnerability is mitigated by the fact that only sites with the Field UI module enabled are affected.

Information disclosure (Render cache system)

On sites utilizing Backdrop's render cache system to cache content on the site by user role, private content viewed by user 1 may be included in the cache and exposed to non-privileged users. This vulnerability is mitigated by the fact that render caching is not used in Backdrop core itself (it requires custom code to enable) and that it only affects sites that have user 1 browsing the live site. Exposure is also limited if an administrative role has been assigned to the user 1 account (which is done, for example, by the Standard install profile that ships with Backdrop core).

Advisory ID: 
BACKDROP-SA-CORE-2015-003
Versions affected: 
  • Backdrop Core versions prior to 1.1.2

Backdrop core - Access Bypass - SA-CORE-2016-002

Date: 
Apr 20th, 2016
Vulnerability: 
Access bypass

Backdrop CMS doesn't sufficiently check permissions to access editor dialogs or check the access to upload images within those editor dialogs. This may allow anonymous users to upload temporary images to the server. These files are temporary and will be automatically deleted by the server after 6 hours, mitigating the possibility of the server becoming filled with temporary files.

This release also includes an informational fix to a security-related warning on the status report. Backdrop CMS was not correctly checking if the "update free access" setting was disabled when reporting site status to administrators. This does not indicate a vulnerability; the status report is now fixed to show the warning if needed.

Advisory ID: 
BACKDROP-SA-CORE-2016-002
Versions affected: 
  • Backdrop Core 1.x.x versions prior to 1.3.5

Backdrop core - Multiple Vulnerabilities - SA-CORE-2016-001

Date: 
Feb 23rd, 2016
Vulnerabilities: 
  • Access bypass
  • Open Redirect
  • Denial of Service

File upload access bypass and denial of service (File module - Moderately Critical)

A vulnerability exists in the File module that allows a malicious user to view, delete or substitute a link to a file that the victim has uploaded to a form while the form has not yet been submitted and processed. If an attacker carries out this attack continuously, all file uploads to a site could be blocked by deleting all temporary files before they can be saved.

This vulnerability is mitigated by the fact that the attacker must have permission to create content or comment and upload files as part of that process.

Open redirect via path manipulation (Base system - Moderately Critical)

The current path can be populated with an external URL. This can lead to Open Redirect vulnerabilities.

This vulnerability is mitigated by the fact that it would only occur in combination with custom code, or in certain cases if a user submits a form shown on a 404 page with a specially crafted URL.

Advisory ID: 
BACKDROP-SA-CORE-2016-001
Versions affected: 
  • Backdrop Core 1.x versions prior to 1.3.3

Backdrop core - Multiple Vulnerabilities - SA-CORE-2015-004

Date: 
Aug 19th, 2015
Vulnerabilities: 
  • Cross Site Scripting
  • Cross Site Request Forgery
  • SQL Injection
  • Information Disclosure
  • Multiple vulnerabilities

XSS injection in AJAX Framework

A vulnerability was found that allows a malicious user to perform an XSS attack by invoking Backdrop.ajax() on a whitelisted HTML element. This vulnerability is mitigated on sites that do not allow untrusted users to enter HTML.

XSS injection in Autocomplete

A cross-site scripting vulnerability was found in the autocomplete functionality of forms. The requested URL is not sufficiently sanitized. This vulnerability is mitigated by the fact that the malicious user must be allowed to upload files to the site.

SQL Injection

A vulnerability was found in the SQL comment filtering system which could allow a user with elevated permissions to inject malicious code in SQL comments. This vulnerability is mitigated by only be accessible to users with "administer views" permissions.

Value callbacks in Form API might run with untrusted input

A vulnerability was discovered in Backdrop's Form API that could allow file upload value callbacks to run with untrusted input, due to the order form token not being checked early enough. This vulnerability can be mitigated by not allowing untrusted users to upload files.

Information Disclosure of Node Titles in Menu Links

For a site that has removed the "access content" permission from anonymous users, the titles of nodes that are added to the main menu or another menu are still visible to anonymous users. This vulnerability is mitigated by the fact the site administrators must have added one or more nodes to a menu that is visible to anonymous users, and the site must not be using a node access module that would filter the nodes out from content listings for anonymous users.

Advisory ID: 
BACKDROP-SA-CORE-2015-004
Versions affected: 
  • Backdrop Core 1.x.x versions prior to 1.1.3

Backdrop core - Multiple vulnerabilities - SA-CORE-2015-002

Date: 
Mar 18th, 2015
Vulnerability: 
Multiple vulnerabilities

Access bypass (Password reset URLs)

Password reset URLs can be forged under certain circumstances, allowing an attacker to gain access to another user's account without knowing the account's password. This vulnerability is mitigated by it only being exploitable on sites where accounts have been imported or programmatically edited in a way that results in the password hash in the database being the same for multiple user accounts. Sites that have empty password hashes and empty user login entries in the database are especially prone to this vulnerability.

Open redirect (Several vectors including the "destination" URL parameter)

Backdrop core and contributed modules frequently use a "destination" query string parameter in URLs to redirect users to a new destination after completing an action on the current page. Under certain circumstances, malicious users can use this parameter to construct a URL that will trick users into being redirected to a 3rd party website, thereby exposing the users to potential social engineering attacks. In addition, several URL-related API functions can be tricked into passing through external URLs when not intending to, potentially leading to additional open redirect vulnerabilities. This vulnerability is mitigated by the fact that many common uses of the "destination" parameter are not susceptible to the attack. However, all confirmation forms built using Form API are vulnerable via the Cancel action that appears at the bottom of the form.

Advisory ID: 
BACKDROP-SA-CORE-2015-002
Versions affected: 
  • Backdrop Core 1.0.x versions prior to 1.0.5

Backdrop core - Multiple vulnerabilities - SA-CORE-2015-001

Date: 
Feb 11th, 2015
Vulnerability: 
Multiple vulnerabilities

Layout access bypass

The core Layout module incorrectly stores contextual information in a cache that may result in cached contexts being served in the wrong situations. This may result in blocks or layouts that are limited to a specific user role or permission being shown to non-privileged accounts. This vulnerability is mitigated by the fact that an administrator must have configured a layout or block must use contextual access control. By default, all blocks and layouts have no access restrictions.

Views open redirect vulnerability

The core Views UI module does not sanitize user provided URLs when processing the page to break the lock on Views being edited, thereby exposing a phishing attack vector. This vulnerability is mitigated by the fact that the Views UI submodule must be enabled.

Views access bypass vulnerability

The core Views module does not protect the default Views configurations sufficiently, thereby exposing possibly protected information to unprivileged users. This vulnerability is mitigated by the fact that it only affects sites that have not granted the common "access content" or "access comments" permission to untrusted users. Furthermore, these default views configurations are disabled by default and must be enabled by an administrator.

Advisory ID: 
BACKDROP-SA-CORE-2015-001
Versions affected: 
  • Backdrop Core 1.x versions prior to 1.0.2

Pages