Server side cross-site scripting In wwbn/avideo

Description

WWBN AVideo: Stored XSS via unescaped Gallery category description

Summary

AVideo stores category descriptions from user input and later renders category_description as raw HTML in the Gallery view. A user who can create or edit categories can store JavaScript in a category description, which executes when another user views the affected Gallery/category page.

This is a stored XSS in the category description field, separate from previously fixed XSS issues in video titles or comments.

Details

Source:

objects/categoryAddNew.json.php

$objCat->setDescription($_POST['description']);

Storage setter:

objects/category.php

public function setDescription($description)
{...

Sink:

plugin/Gallery/view/mainAreaCategory.php

  <div id="categoryDescription<?php echo $duid; ?>" style="display: none;"><?php echo $videos[0]['category_description']; ?></div>

The value is rendered without htmlspecialchars(), htmlentities(), HTMLPurifier, or equivalent output encoding.

PoC

Prerequisites:

    AVideo current master / v29.0

    User account with permission to create or edit categories

    Gallery plugin/view enabled

    At least one video assigned to the affected category

Steps:

    Log in as a user who can create or edit categories.

    Create or edit a category.

    Set the category description to:

  <img src=x onerror=alert(document.domain)>

    Save the category.

    Assign at least one video to that category.

    Open the Gallery/category page that renders the category section.

    The payload is inserted into the page as raw HTML and JavaScript executes.

Impact

An attacker with category edit permission can execute JavaScript in the browser of users or administrators who view the affected Gallery/category page. This can be used to perform actions as the victim, steal same-origin data accessible to JavaScript, or abuse administrative UI actions if an administrator views the malicious category.

Recommended fix

    Sanitize category descriptions on input with the same HTML policy used for video descriptions, or store plain text only.

    Encode on output:

echo htmlspecialchars($videos[0]['category_description'], ENT_QUOTES, 'UTF-8');

    If limited HTML is intended, run the description through HTMLPurifier before storage or before render.

    Add regression tests for category description rendering in Gallery views.

Mitigation

Update Impact

Minimal update. May introduce new vulnerabilities or breaking changes.

Ecosystem
Package
Affected version
FLAT-7G7OW – Vulnerability | Fluid Attacks Database