Browser Console test: lodash
Lodash was recently identified as having a security flaw up through the current release version.
I wanted to see what version was currently running on a webapp,
- reproduce a tell-tale script to confirm the vulnerability
- rebuild the app with the fixed version
- confirm the vulnerability was fixed.
To get the current version I put _.VERSION in the console with the site loaded. I added this as a live expression (click the eyeball next to the console filter) so I could keep tabs on the version as I accessed different parts of the app and rebuilt it using the fixed version.
data:image/s3,"s3://crabby-images/633a7/633a7fd5773ed0118446209b5f35b4197d808896" alt=""
Then I entered the telltale script in the console:
_.zipObjectDeep(['a.b.__proto__.c'],[123])
which was provided on HackerOne by lodash author jdalton.
With the vulnerability, console(c) prints
"123"
data:image/s3,"s3://crabby-images/46060/460607db1c33399e39389f7e18e650402c008a80" alt=""
After rebuilding with the fix version of lodash, the same script prints
undefined.
data:image/s3,"s3://crabby-images/9bd65/9bd656fb1375f44610f614d1a371986070269c6e" alt=""
I noticed after pasting the images that it is important to include the VERSION value in the screenshot if you intend to document patching this kind of issue efficiently.
data:image/s3,"s3://crabby-images/3088e/3088e56ae11ea48a7ea8a8c7ad5efb99ee72b790" alt=""