Skip to content

Commit

Permalink
fix: Make ARIA polyfill more robust
Browse files Browse the repository at this point in the history
All the attributes listed in the polyfill already begin with "aria".
However, to add extra protection against the possibility of XSS
attacks through one of the polyfill's internal methods, this enforces
"aria-" at the beginning of the snake-case attribute name, even if
somehow "aria" were missing from the input JavaScript attribute name.

This change is based on the outcome of an internal security review.

Change-Id: Iec8a9cbd5f88fdf4b87da3e5cd058c4ffb69c3ff
  • Loading branch information
joeyparrish committed Jul 20, 2021
1 parent 3270248 commit b185b3c
Showing 1 changed file with 7 additions and 1 deletion.
8 changes: 7 additions & 1 deletion lib/polyfill/aria.js
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,13 @@ shaka.polyfill.Aria = class {
* @private
*/
static addARIAMixinAttribute_(name) {
const snakeCaseName = name.toLowerCase().replace('aria', 'aria-');
const baseName = name.toLowerCase().replace(/^aria/, '');
// NOTE: All the attributes listed in the method above begin with "aria".
// However, to add extra protection against the possibility of XSS attacks
// through this method, this enforces "aria-" at the beginning of the
// snake-case name, even if somehow "aria" were missing from the input.
const snakeCaseName = `aria-${baseName}`;

/* eslint-disable no-restricted-syntax */
Object.defineProperty(Element.prototype, name, {
get() {
Expand Down

0 comments on commit b185b3c

Please sign in to comment.