Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
batchdelcache
Advanced tools
Delete module cache safely. This project is inspired by decache.
# use npm
npm install batchdelcache
# or use yarn
yarn global add batchdelcache
Node.js 10+
Deleting module cache is the precondition of 'hot reloading'. Typically, we delete the module cache by:
delete require.cache[require.resolve('xxx')]
However, this method can cause memory leakage. It clears the module cache in Module._cache
which is referenced by require.cache
, but it doesn't eliminate the reference in the array of xxx.parent.children
.
batchdelcache
provides a way to eliminate both kinds of reference:
batchdelcache('xxx')
In most cases, this is enough to clean up all references, with the following exception:
{
id: 'parentModule',
children: [{
id: 'childModuleA',
children: [{
id: 'targetModule'
}]
}, {
id: 'childModuleB',
children: [{
id: 'targetModule'
}]
}]
}
You will find targetModule
still in the children of childModuleA
after calling batchdelcache(targetModule)
in childModuleB
. In this condition, you can pass true
as the second argument to batchdelcache
: batchdelcache(targetModule, true)
. batchdelcache
will traverse the whole module tree to delete targetModule from children of every module.
When passing rootPath
as the third argument, batchdelcache
will take it as the starting point. It is a recommended way to save time traversing the module tree.
Delete cache of target module and clear reference in parent's children:
const batchdelcache = require('batchdelcache')
let five = require('./five')
five.num = 6
batchdelcache(['./five'])
five = require('./five')
console.log(five.num) // 5
Pass true
as the second argument to delete cache of target module from the whole module tree.
const batchdelcache = require('batchdelcache')
let five = require('./five')
let six = require('./six')
five.num = 6
six.sum = 7
batchdelcache(['./five', './six'], true)
five = require('./five')
six = require('./six')
console.log(five.num) // 5
console.log(six.num) // 6
When the second argument is true
, you can specify the rootPath
from which clear the reference of the target module.
This is a recommended way to make the delete operation faster:
const batchdelcache = require('batchdelcache')
let five = require('./five')
five.num = 6
batchdelcache('./five', true, '../../root')
five = require('./five')
console.log(five.num) // 5
Don't uese delete require.cache[xxx]
with batchdelcache
, cause batchdelcache
will check if a module is referenced by Module._cache
.
//parent.js
require('./a')
require('./b')
//a.js
require('./mod')
delete require.cache[require.resolve('./mod')]
//b.js
const batchdelcache = require('batchdelcahce')
batchdelcache('./mod', true) // delcache can not eliminate the reference of mod in children of a.js
FAQs
batch delete module cache in node safely
The npm package batchdelcache receives a total of 27 weekly downloads. As such, batchdelcache popularity was classified as not popular.
We found that batchdelcache demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers 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.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.