Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
babel-plugin-shim-nodejs
Advanced tools
Transform server side code to use Node.js shims for the browser.
In
var console = require('console');
console.info('Hello from '+__filename);
Out
var __filename = 'index.js';
var console = require('liferay-node-console');
console.info('Hello from '+__filename);
npm install --save-dev babel-plugin-shim-nodejs
Add the following to your .babelrc
file:
Without options:
{
"plugins": ["shim-nodejs"]
}
With options:
{
"plugins": [
["shim-nodejs", {
"nodeShimsVersion": "1.5.0",
"globals": {
"process": "var process = {env: {NODE_ENV: 'production'}}};"
},
"modules": {
}
}]
]
}
This plugins transforms as much as possible Node.js server code to make it work in the browser by using shims.
It assumes that you have deployed frontend-js-node-shims OSGi bundle to your Portal (the bundle is shipped with standard installations by default).
Failure to deploy such bundle will result in Javascript errors due to missing modules.
The plugin supports rewriting of all Node.js v8 globals and builtin modules to make them use the shims. This does not necessarily mean that all server code will work, just that it will try to use the shims, but the shims may not be deployed or may be incomplete.
Consider, for example, that there's no way to fully shim Node.js's
child_process
module in a browser (in a standard way) so that all npm packages
using it may work correctly in the browser.
The usual way to shim globals is to look for their appearance as lone identifiers and prepend a variable declaration for the global on top of the module.
On the other hand, the usual way to shim modules is to rewrite the require()
calls to prepend the liferay-node-
prefix to the module name so that the
deployed shim is loaded instead of failing with a missing module exception.
Of course, if liferay-node-*
modules are required after transformation, the
transformed package's package.json
file must be patched to inject a dependency
to the liferay-node-*
packages. This is also automatically done by the plugin.
This plugin has several configuration options that can be tweaked to support more globals and/or modules:
1.0.0
, it specifies the version to
use when patching package.json
files.liferay-node
(see modules.js for a more detailed description).FAQs
A Babel plugin to shim Node.js global objects and modules.
We found that babel-plugin-shim-nodejs 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
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.