Update dependency highlight.js to v10 [SECURITY] #2
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
^9.8.0
->^10.0.0
GitHub Vulnerability Alerts
CVE-2020-26237
Impact
Affected versions of this package are vulnerable to Prototype Pollution. A malicious HTML code block can be crafted that will result in prototype pollution of the base object's prototype during highlighting. If you allow users to insert custom HTML code blocks into your page/app via parsing Markdown code blocks (or similar) and do not filter the language names the user can provide you may be vulnerable.
The pollution should just be harmless data but this can cause problems for applications not expecting these properties to exist and can result in strange behavior or application crashes, i.e. a potential DOS vector.
If your website or application does not render user provided data it should be unaffected.
Patches
Versions 9.18.2 and 10.1.2 and newer include fixes for this vulnerability. If you are using version 7 or 8 you are encouraged to upgrade to a newer release.
Workarounds
Patch your library
Manually patch your library to create null objects for both
languages
andaliases
:Filter out bad data from end users
Filter the language names that users are allowed to inject into your HTML to guarantee they are valid.
References
For more information
If you have any questions or comments about this advisory:
GHSA-7wwv-vh3v-89cq
Impact: Potential ReDOS vulnerabilities (exponential and polynomial RegEx backtracking)
oswasp:
If are you are using Highlight.js to highlight user-provided data you are possibly vulnerable. On the client-side (in a browser or Electron environment) risks could include lengthy freezes or crashes... On the server-side infinite freezes could occur... effectively preventing users from accessing your app or service (ie, Denial of Service).
This is an issue with grammars shipped with the parser (and potentially 3rd party grammars also), not the parser itself. If you are using Highlight.js with any of the following grammars you are vulnerable. If you are using
highlightAuto
to detect the language (and have any of these grammars registered) you are vulnerable.All versions prior to 10.4.1 are vulnerable, including version 9.18.5.
Grammars with exponential backtracking issues:
And of course any aliases of those languages have the same issue. ie:
hpp
is no safer thancpp
.Grammars with polynomial backtracking issues:
And again: any aliases of those languages have the same issue. ie:
ruby
andrb
share the same ruby issues.Patches
Workarounds / Mitigations
References
For more information
If you have any questions or comments about this advisory:
Release Notes
highlightjs/highlight.js
v10.4.1
Compare Source
Security
Very grateful to Michael Schmidt for all the help.
v10.4.0
Compare Source
A largish release with many improvements and fixes from quite a few different contributors. Enjoy!
Deprecations:
requireLanguage
is deprecated.getLanguage
(with custom error handling) or built-time dependencies.Parser:
beginKeywords
support (#2813) Josh GoebelclassNameAliases
for more complex grammars Josh GoebelclassNameAliases
for more complex grammars Josh GoebelNew Languages:
node-repl
for Node.js REPL sessions (#2792) Marat NagayevLanguage Improvements:
~
(#2859) Guillaume Grossetie\
(#2861) Guillaume Grossetie\[Gamma]
#
Marcus Ortizsome
keyword Marcus Ortiz@main
attribute Marcus OrtizDev Improvements:
New themes:
v10.3.2
Compare Source
Tiny tiny release, just to fix the website incorrectly not listing Javascript
in the list of languages you could choose for a custom build. NPM and CDN
build should not have been affected so 10.3.1 is effectively the same as
10.3.2 for those builds.
If you made a custom build from the website with 10.3 or 10.3.1 you may
want to check and make sure it includes Javascript, and if not, build it again.
v10.3.1
Compare Source
Prior version let some look-behind regex sneak in, which does not work
yet on Safari. This release removes those incompatible regexes.
Fix:
v10.3.0
Compare Source
Language Improvements:
enum (struct|class)
andunion
(#2752) [Josh Goebel][]{}
inside template literals SUBST expression (#2748) [Josh Goebel][]constructor
is now highlighted as a function title (not keyword) (#2727) [Josh Goebel][]#
for private class fields (#2701) Chris Krycho(*)
from being detected as a multi-line comment [Josh Goebel][]objective-c++
andobj-c++
aliases for Objective-C [Josh Goebel][]record
(#2685) [Josh Goebel][]title
(#2683) [Josh Goebel][]final
) in class declaration (#2696) [Josh Goebel][]match
keyword and addphp8
as an alias (#2733) Ayesh KarunaratneDeprecations:
useBR
option deprecated and will be removed in v11.0. (#2559) [Josh Goebel][]v10.2.1
Compare Source
Parser Engine:
v10.2.0
Compare Source
Parser Engine:
New themes:
Deprecations:
fixMarkup
is now deprecated and will be removed in v11.0. (#2534) Josh GoebelBig picture:
Language Improvements:
init
andrecord
keywords for C# 9.0 (#2660) Youssef Victorarguments
keyword and fixenumeration
keyword (#2619) Andrew JankegetLanguage
(#2636) nightenum
, which will identify as aclass
now (#2643) ezksdv10.1.2
Compare Source
Fixes:
getLanguage
(#2636) nightv10.1.1
Compare Source
Fixes:
index.d.ts is not a module
error (#2603) Josh Goebelv10.1.0
Compare Source
New themes:
Parser Engine:
keywords.$pattern
key to grammar definitions (#2519) Josh GoebelregisterAliases
method (#2540) [Taufik Nurrohman][]on:begin
callback for modes (#2261) Josh Goebelon:end
callback for modes (#2261) Josh GoebelEND_SAME_AS_BEGIN
mode to replaceendSameAsBegin
parser attribute (#2261) Josh GoebelfixMarkup
would rarely destroy markup whenuseBR
was enabled (#2532) Josh GoebelDeprecations:
htmlbars
grammar is now deprecated. Usehandlebars
instead. (#2344) Nils KnappmeierhighlightBlock
result.re
deprecated. Useresult.relevance
instead. (#2552) Josh Goebelresult.second_best.re
=>result.second_best.relevance
(#2552)lexemes
is now deprecated in favor ofkeywords.$pattern
key (#2519) Josh GoebelendSameAsBegin
is now deprecated. (#2261) Josh GoebelLanguage Improvements:
readonly
keyword (#2562) Martin (Lhoerion)OPTIMIZE:
andHACK:
to the labels highlighted inside comments Josh Goebelpair
,make_pair
,priority_queue
as built-ins (#2538) Hankun Linpriority_queue
pair
as cpp containers (#2541) Hankun Linset
keyword conflicting with setTimeout, etc. (#2514) Vania Kucher=>
function with nested()
in params now works (#2502) Josh Goebel=>
function with nested()
in params now works (#2502) Josh Goebel@objcMembers
was being partially highlighted (#2543) Nick Randalllate
andrequired
keywords, theNever
built-in type, and nullable built-in types (#2550) Sam Rawlinsv10.0.3
Compare Source
v10.0.2
Compare Source
Brower build:
Parser Engine Changes:
v10.0.1
Compare Source
Parser Engine Changes:
v10.0.0
Compare Source
New languages:
python-repl
for Python REPL sessionsNew themes:
Parser Engine Changes:
beginKeywords
to ignore . matches (#2434) Josh Goebelbefore:highlight
plugin API callback (#2395) Josh Goebelafter:highlight
plugin API callback (#2395) Josh Goebelname
attribute now (#2400) Josh GoebelnoHighlightRe
andlanguagePrefixRe
configurable (#2374) Josh GoebelLanguage Improvements:
compactMap
to keywords as built_in (#2478) Omid Golparvarfunc
keyword (#2468) Adnan Yaqoobdefn-
properly (#2438) Josh Goebel@identifier
style identifiers (#2414) Josh Goebeldeny
andallow
keywords Josh Goebel<?=
syntax to meta Taufik Nurrohmanrpc
when followed by a block (#) Josh Goebelwhere
keyword as class constraint (#2378) Josh Goebeltext
andtxt
as alias (#2360) Taufik NurrohmanDeveloper Tools:
v9.18.1
Compare Source
Grammar Improvements:
v9.18.0
Compare Source
New languages:
New themes:
Core Changes:
Language Improvements:
block
andendblock
keywords (#2343) Philipp EngelA::typeName func(...)
) (#2332) Josh GoebelA::functionName
) (#2332) Josh Goebelint8_t
, etc.) as function types (#2332) Josh GoebelDeveloper Tools:
v9.17.1
Compare Source
Fixes:
v9.17.0
Compare Source
New languages:
New themes:
Core Improvements:
createElementNS
tocreateElement
(#2314) Josh Goebelself
mode at the top-level of a language (#2294) Josh GoebelLanguage Improvements:
if
getting confused as an f-string (#2200) Josh Goebel and Carl Baxtercalc(2px+3px)
(#2241)v9.16.2
Compare Source
New languages:
none.
New styles:
none.
Improvements:
v9.16.1
Compare Source
New languages:
none.
New styles:
Improvements:
!~
method definition (#2222)@dynamicMemberLookup
and@propertyWrapper
(#2202)endWithParent
insidestarts
now always works (#2201)vbscript
as potential script tag subLanguagefuture
built-in (#1610)v9.15.10
Compare Source
New languages:
none.
New styles:
none.
Improvements:
script
tags (#1690)v9.15.9
Compare Source
Improvements:
v9.15.8
Compare Source
New languages:
none.
New styles:
none.
Improvements:
v9.15.7
Compare Source
New languages:
none.
New styles:
none.
Improvements:
v9.15.6
Compare Source
New languages:
none.
New styles:
none.
Improvements:
v9.15.5
Compare Source
New languages:
none.
New styles:
none.
Improvements:
🔥 Hot fix: updated build tool.
v9.15.2
Compare Source
New languages:
none.
New styles:
none.
Improvements:
🔥 Hot fix that was preventing highlight.js from installing.
v9.15.1
Compare Source
New languages:
none.
New styles:
none.
Improvements:
script
tags (#1690)v9.14.2
Compare Source
New languages:
none.
New styles:
none.
Improvements:
v9.14.1
Compare Source
New languages:
none.
New styles:
none.
Improvements:
v9.13.1
Compare Source
Improvements:
autoDetection
to accept language aliases.[Antoine Bois
Configuration
📅 Schedule: "" (UTC).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR has been generated by WhiteSource Renovate. View repository job log here.