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.
@carsy/eslint-config
Advanced tools
My own eslint configurations, based from https://github.com/satazor/eslint-config
$ npm install --save-dev @carsy/eslint-config
Additional dependencies that need to be installed per addon:
react addon: $ npm install --save-dev eslint-plugin-react@^3.13.0
This config was tested with eslint@^4.3.0
and the specific version ranges for plugins. Use other versions at your own risk. I will try to keep this project up to date with the changes of eslint
and the plugins used here.
First you need to choose the base configuration to use:
es5
- The configuration to be used in ECMAScript 5 based projectses6
- The configuration to be used in ECMAScript 6 based projectsThen enhance it with one or more addons:
browser
- If you are going to develop code for the browser (having in mind IE >= 9)node
- If you are going to develop code for NodeJSnode-v4-es6
- If you are going to develop code for NodeJS >= 4 with the es6
base configurationes6-modules
- If you are going to use ES6 import & export (must be used with the es6
base configuration)react
- If you are going to use React and JSX (requires eslint-plugin-react
)Finally, simply create a .eslintrc.json
file with the chosen base configuration and addons. Feel free to override rules you won't agree with. You can look at some examples bellow.
Alternatively, you can make your own configuration by using the set of rules individually. If you're interested in doing that, you can check es5.js
to see how it is done.
Cutting edge ES6 with modules in the browser, using react:
{
"root": true,
"extends": [
"@carsy/eslint-config/es6",
"@carsy/eslint-config/addons/es6-modules",
"@carsy/eslint-config/addons/browser",
"@carsy/eslint-config/addons/react"
]
}
Cutting edge ES6 with modules in NodeJS (requires babel or similar):
{
"root": true,
"extends": [
"@carsy/eslint-config/es6",
"@carsy/eslint-config/addons/es6-modules",
"@carsy/eslint-config/addons/node"
]
}
Use ES6 in NodeJS without any transpiler:
{
"root": true,
"extends": [
"@carsy/eslint-config/es6",
"@carsy/eslint-config/addons/node"
]
}
.. and if you are programming against NodeJS v4 please use:
{
"root": true,
"extends": [
"@carsy/eslint-config/es6",
"@carsy/eslint-config/addons/node"
"@carsy/eslint-config/addons/node-v4-es6"
]
}
Good old ES5 in NodeJS:
{
"root": true,
"extends": [
"@carsy/eslint-config/es5",
"@carsy/eslint-config/addons/node"
]
}
Note that by setting root
to true, we ensure that no ancestor configuration is used which also improves eslint
performance because no more file lookups need to be done.
If your file exports a single class, your filename should be exactly the name of the class. For other cases, the name of the file should be the same as the default exports (prefer camelCase).
FAQs
My own eslint configurations
The npm package @carsy/eslint-config receives a total of 11 weekly downloads. As such, @carsy/eslint-config popularity was classified as not popular.
We found that @carsy/eslint-config 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.
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.