GHSA-h6gj-6jjq-h8g9

Suggest an improvement
Source
https://github.com/advisories/GHSA-h6gj-6jjq-h8g9
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2022/07/GHSA-h6gj-6jjq-h8g9/GHSA-h6gj-6jjq-h8g9.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-h6gj-6jjq-h8g9
Aliases
Published
2022-07-18T17:07:36Z
Modified
2024-10-28T18:33:36.265771Z
Severity
  • 6.1 (Medium) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N CVSS Calculator
Summary
jQuery UI vulnerable to XSS when refreshing a checkboxradio with an HTML-like initial text label
Details

Impact

Initializing a checkboxradio widget on an input enclosed within a label makes that parent label contents considered as the input label. If you call .checkboxradio( "refresh" ) on such a widget and the initial HTML contained encoded HTML entities, they will erroneously get decoded. This can lead to potentially executing JavaScript code.

For example, starting with the following initial secure HTML:

<label>
    <input id="test-input">
    &lt;img src=x onerror="alert(1)"&gt;
</label>

and calling:

$( "#test-input" ).checkboxradio();
$( "#test-input" ).checkboxradio( "refresh" );

will turn the initial HTML into:

<label>
    <!-- some jQuery UI elements -->
    <input id="test-input">
    <img src=x onerror="alert(1)">
</label>

and the alert will get executed.

Patches

The bug has been patched in jQuery UI 1.13.2.

Workarounds

To remediate the issue, if you can change the initial HTML, you can wrap all the non-input contents of the label in a span:

<label>
    <input id="test-input">
    <span>&lt;img src=x onerror="alert(1)"&gt;</span>
</label>

References

https://blog.jqueryui.com/2022/07/jquery-ui-1-13-2-released/

For more information

If you have any questions or comments about this advisory, search for a relevant issue in the jQuery UI repo. If you don't find an answer, open a new issue.

References

Affected packages

npm / jquery-ui

Package

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.13.2

Maven / org.webjars.npm:jquery-ui

Package

Name
org.webjars.npm:jquery-ui
View open source insights on deps.dev
Purl
pkg:maven/org.webjars.npm/jquery-ui

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.13.2

Affected versions

1.*

1.10.4
1.10.5
1.12.0-rc.2
1.12.0
1.12.1
1.13.0-rc.2
1.13.0-rc.3
1.13.0
1.13.1

RubyGems / jquery-ui-rails

Package

Name
jquery-ui-rails
Purl
pkg:gem/jquery-ui-rails

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
7.0.0

Affected versions

0.*

0.0.1
0.0.2
0.1.0
0.2.0
0.2.1
0.2.2
0.3.0
0.4.0
0.4.1
0.5.0

1.*

1.0.0
1.1.0
1.1.1

2.*

2.0.0
2.0.1
2.0.2

3.*

3.0.0
3.0.1

4.*

4.0.0
4.0.1
4.0.2
4.0.3
4.0.4
4.0.5
4.1.0
4.1.1
4.1.2
4.2.0
4.2.1

5.*

5.0.0
5.0.1
5.0.2
5.0.3
5.0.4
5.0.5

6.*

6.0.0
6.0.1

7.*

7.0.0

NuGet / jQuery.UI.Combined

Package

Name
jQuery.UI.Combined
View open source insights on deps.dev
Purl
pkg:nuget/jQuery.UI.Combined

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.13.2

Affected versions

1.*

1.8.9
1.8.10
1.8.11
1.8.12
1.8.13
1.8.14
1.8.15
1.8.16
1.8.17
1.8.18
1.8.19
1.8.20
1.8.20.1
1.8.21
1.8.22
1.8.23
1.8.24
1.9.0-RC1
1.9.0
1.9.1
1.9.2
1.10.0
1.10.1
1.10.2
1.10.3
1.10.4
1.11.0
1.11.1
1.11.2
1.11.3
1.11.4
1.12.0
1.12.1
1.13.0
1.13.1