Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@pedroslopez/moduleraid
Advanced tools
NOTE This package was modified from pixeldesu's original moduleRaid for compatibility with webpack v5 used in WhatsApp Web. No support will be given outside of anything strictly necessary to extract modules in WhatsApp Web.
moduleRaid is a utility to get modules and module constructors from webpackJsonp
functions embedded on websites by Webpack. It also provides functions to search through returned modules.
You can get moduleRaid over npm
$ npm install moduleraid
Or if you directly want to use it in the browser
<script src="https://unpkg.com/moduleraid@4.0.1/moduleraid.js"></script>
<!-- minified -->
<script src="https://unpkg.com/moduleraid@4.0.1/moduleraid.min.js"></script>
Alternatively, just copy the script from moduleraid.js
and run it in a devtool console
on the site of your choosing.
Using moduleRaid
as a module, simply require and execute it somewhere where it will end up as a public facing script on a page that also
includes a Webpack build!
const moduleRaid = require('moduleraid')
window.mR = moduleRaid()
If you a running the script from the console or loading it over a service like unpkg, no further need for preparations!
moduleraid
objectOnce moduleRaid
is run or included on a page that includes a Webpack build (usually noted by a webpackJsonp
function), it
will return a object, containing:
modules
: An object containing all modules we could get from Webpackconstructors
: An array containing all module constructor functionsget(id)
: Get the module from the specified id
findModule(query)
: Return the module that has query
as a key in its exportsfindFunction(query)
: Return functions that include query
(query
can be either a string or a function)If you run the code in devtools or load it as external script from unpkg/etc. the moduleRaid
object can be found in window.mR
by default.
Note: If moduleRaid had to get modules through iteration, constructors
will be empty and so findFunction
will not work.
If you call moduleRaid with an optional argument true
, you will enable debug output. Debug output will show errors that are normally supressed.
In the version that is minified and you can't just add another argument easily, simply run window.mRdebug = true
before adding the script and you should
be fine!
There already was a script basically doing the same as moduleRaid
some months earlier, called webcrack
(made by no-boot-device), which was rendered obsolute due to structural changes in how you can access Webpack modules from the outside.
This library is an effort to bring back the ability to inspect all available modules, for debugging or userscript purposes.
As noted above, Webpack exposes a function webpackJsonp
containing all the code that has been bundled with Webpack. The function takes three
parameters, all of them being an array. The first two don't seem to really matter, the last one is interesting, it seems to directly return
a module given an index.
So, in a brute-forcy manner we simply run a while
over webpackJsonp([], [], [i])
until we get an exception from Webpack (trying to run call
on undefined
), and now we have all modules (or most of them)!
moduleRaid is licensed under the MIT License
FAQs
Get modules from webpack v5
We found that @pedroslopez/moduleraid demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.