Lucene search

K
huntrHaxatronF115BDF5-C06B-4627-A6FA-BA6904A43BA3
HistoryOct 26, 2021 - 2:00 a.m.

in bookstackapp/bookstack

2021-10-2602:00:49
haxatron
www.huntr.dev
5
base64 image validation
bookstack
flawed security
xss attacks
image upload
security vulnerability
broken file extension
csp bypass
reflected xss
vulnerable trim function

EPSS

0.001

Percentile

30.6%

Description

The image extension validation service for Base64 image extraction in new Bookstack version is flawed as it uses the vulnerable trim function. This allows attackers to upload malicious files with broken extension, such as pngr, and browsers will interpret broken extension hosted on the server as HTML.

Payload 1

POST /api/pages
{
	"book_id": 1,
	"name": "My API Page",
	"html": "<img src="">",
	"tags": [
		{"name": "Category", "value": "Not Bad Content"},
		{"name": "Rating", "value": "Average"}
	]
}

See that the file is stored on the server, an attacker can send this file to others to perform reflected XSS. The CSP does not help because CSP is on application layer and hence not applied to static files.

Payload 2

POST /api/pages
{
	"book_id": 1,
	"name": "My API Page",
	"html": "<img src="">",
	"tags": [
		{"name": "Category", "value": "Not Bad Content"},
		{"name": "Rating", "value": "Average"}
	]
}

This creates a phishing page on the server, we can modify where the credentials are sent to if we want

Root Cause

There is a subtle difference between single-quoted strings (literals) and double-quoted strings. In double-quoted strings \r\n will be interpreted as carriage-return and newline, but in single-quoted literals the characters will be interpreted as-is. Bookstack uses the trim function with only single-quoted string, so attackers can bypass the file validation check.

in_array(trim($extension, '. \t\n\r\0\x0B'), static::$supportedExtensions);

So if the $extension = pngr, then the trim function will strip the ‘r’ character so that it becomes png and thus gets validated.

Impact

An attacker with page edit permissions can upload files to:

1: Host phishing pages and obtain password of admin users

2: Javascript execution (XSS) to get the cookie.

EPSS

0.001

Percentile

30.6%

Related for F115BDF5-C06B-4627-A6FA-BA6904A43BA3