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-rewrite-module-path
Advanced tools
Rewrite module resolving path
case 1: Rewrite a specific module subpath to node_modules
- import foo from "@monorepo/shared/modules/foo"
+ import foo from "@monorepo/shared/node_modules/foo"
via
// .babelrc.json
{
"plugins": ["babel-plugin-rewrite-module-path", {
"rewriteMapper": {
"^@monorepo/shared/modules/": "@monorepo/shared/node_modules/"
}
}]
}
case 2: Rewrite a cjs importing to esm importing
- import inversify from "inversify/lib/inversify"
+ import inversify from "inversify/es/inversify"
via
// .babelrc.json
{
"plugins": ["babel-plugin-rewrite-module-path", {
"rewriteMapper": {
"^inversify/lib/": "inversify/es/"
}
}]
}
case 3: Rewrite a lodash importing to lodash fp importing(for typescript user don't forget to config the paths compiler options of tsconfig.json to adjust intelligence)
- import flatMap from "lodash/flatMap"
+ import flatMap from "lodash/fp/flatMap"
via
// .babelrc.json
{
"plugins": ["babel-plugin-rewrite-module-path", {
"rewriteMapper": {
"^lodash/": "lodash/fp/"
}
}]
}
Take the advantage of rewriting to shorten the importing path. / Config the importing path to a preferred/reader-friendly one.
Rewrite module subpath for hacking the resolving mechanism. e.g. in some bundling situation.
It could be an alternative approach to declaring exports
filed to tell the node modules resolver how to resolve a node_modules
package.
// package.json
{
"exports": {
"modules/*": "./node_modules/*"
}
}
For Javascript user, you could use a custom folder name as replacement to
node_modules
, it's common for implementing a monorepo project. e.g.
// '../../modules/..' will be rewritten to '../../node_modules/..'
import singletonModule from '@monorepo/shared/modules/inversify'
For Typescript user, you need additional works to support intelligence through module path rewriting, see typescript paths for more details. e.g.
// tsconfig.json
{
"compilerOptions": {
"baseUrl": ".",
"paths": {
// we already have type-safe node_modules aliasing, still need a runtime rewriting for development and production building.
"@monorepo/shared/modules/*": ["./packages/shared/node_modules/*", "./packages/shared/node_modules/@types/*"]
}
}
}
Supports these module importing usages:
Import Declaration
Export All Declaration
Export Named Declaration
Dynamic Importing
require
require.context
import.meta.glob
import.meta.globEager
.rewrite
import foo from '@monorepo/shared/modules/foo'
import * as foo from '@monorepo/shared/modules/foo'
import '@monorepo/shared/modules/foo'
export * from '@monorepo/shared/modules/foo'
export { bar } from '@monorepo/shared/modules/foo'
export { default as foo } from '@monorepo/shared/modules/foo'
const foo = await import('@monorepo/shared/modules/foo')
const { bar } = await import('@monorepo/shared/modules/foo')
import('@monorepo/shared/modules/foo')
const foo = require('@monorepo/shared/modules/foo')
const foo = import.meta.glob('@monorepo/shared/modules/foo')
const foo = import.meta.globEager('@monorepo/shared/modules/foo')
const foo = require.context('@monorepo/shared/modules/foo')
to
import foo from '@monorepo/shared/node_modules/foo'
import * as foo from '@monorepo/shared/node_modules/foo'
import '@monorepo/shared/node_modules/foo'
export * from '@monorepo/shared/node_modules/foo'
export { bar } from '@monorepo/shared/node_modules/foo'
export { default as foo } from '@monorepo/shared/node_modules/foo'
const foo = await import('@monorepo/shared/node_modules/foo')
const { bar } = await import('@monorepo/shared/node_modules/foo')
import('@monorepo/shared/node_modules/foo')
const foo = require('@monorepo/shared/node_modules/foo')
const foo = import.meta.glob('@monorepo/shared/node_modules/foo')
const foo = import.meta.globEager('@monorepo/shared/node_modules/foo')
const foo = require.context('@monorepo/shared/node_modules/foo')
npm install babel-plugin-rewrite-module-path
// .babelrc.json
{
"plugins": ["babel-plugin-rewrite-module-path", {
"rewriteMapper": {
"/modules/", "/node_modules/"
}
}]
}
The Plugin Options Signature:
export type RewriteNodeModulesOptions = {
rewriteMapper: Record<string, string>,
transform?: {
importDeclaration?: boolean,
exportDeclaration?: boolean,
dynamicImport?: boolean,
importGlob?: boolean,
importGlobEager?: boolean,
require?: boolean,
requireContext?: boolean,
}
}
The Default Options:
export const defaultRewriteNodeModulesOptions = {
transform: {
importDeclaration: true,
exportDeclaration: true,
dynamicImport: true,
importGlob: true,
importGlobEager: true,
require: true,
requireContext: true,
}
}
FAQs
Rewrite module resolving path
The npm package babel-plugin-rewrite-module-path receives a total of 78 weekly downloads. As such, babel-plugin-rewrite-module-path popularity was classified as not popular.
We found that babel-plugin-rewrite-module-path 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.