PT-2026-46858 · Packagist · Wwbn Avideo
Published
2026-06-04
·
Updated
2026-06-04
CVSS v3.1
5.4
Medium
| Vector | AV:N/AC:L/PR:L/UI:R/S:C/C:L/I:L/A:N |
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)
{
$this->description = $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.
Fix
XSS
Found an issue in the description? Have something to add? Feel free to write us 👾
Weakness Enumeration
Related Identifiers
Affected Products
Wwbn Avideo