Research
Security News
Kill Switch Hidden in npm Packages Typosquatting Chalk and Chokidar
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
fis3-hook-lego
Advanced tools
fis3 版本的 lego
包管理的模块查找,http://lego.imweb.io/ 。
如下目录结构:
.
├── index.html
├── lego_modules
│ ├── dialog
│ │ └── 0.1.0
│ │ ├── custom.js
│ │ └── package.json
│ ├── slider
│ │ └── 0.1.0
│ │ └── index.js
│ ├── tab
│ │ └── 0.1.0
│ │ └── tab.js
│ └── test_module
│ └── 0.1.0
│ └── index.js
├── map.json
├── modules
│ ├── common
│ │ ├── common.js
│ │ └── header
│ │ ├── db.header.js
│ │ └── header.js
│ ├── common.js
│ ├── index
│ │ └── header
│ │ ├── db.header.js
│ │ └── header.js
│ └── test_module.js
└── pages
└── index
├── main.css
└── main.js
现在 main.js
内容:
var dialog = require('dialog');
var slider = require('slider');
var tab = require('tab'); // lego_modules 中的快速引用
var version = require('versions@0.1.0'); // 指定版本
var common = require('common');
var testModule = require('test_module');
var header = require('index/header'); // modules 中也可以省去 `modules`
var index = require('index'); // 查找modules/index.js ; modules/index/index.js
npm i fis3-hook-lego -g
在 fis-conf.js
中:
fis.hook('lego');
fis.match(/^\/modules\/(.+)\.js$/, {
isMod: true,
id: '$1'
})
.match(/^\/modules\/((?:[^\/]+\/)*)([^\/]+)\/\2\.(js)$/i, {
//isMod: true,
id: '$1$2'
})
.match(/^\/lego_modules\/(.+)\.js$/i, {
isMod: true,
id: '$1'
});
由于有多版本的场景,lego会修改文件id,比如require('zepto'), 产出后是 require('zepto/1.1.6/zepto')
,
其他插件的配置中需要zepto时,比如 ignore: ['zepto'],查找会有问题,解决方案:
ignore: ['zepto/1.1.6/zepto'],指定具体的版本
在处理逻辑之前,调用 fis.get('idMaps'), 将zepto的id进行转化(ps:idMaps中记录了lego对文件id的修改,key值是修改前的id,value是修改后的id)
FAQs
lego 包管理模块查找
The npm package fis3-hook-lego receives a total of 2 weekly downloads. As such, fis3-hook-lego popularity was classified as not popular.
We found that fis3-hook-lego demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 5 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 found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.