
Research
Two Malicious Rust Crates Impersonate Popular Logger to Steal Wallet Keys
Socket uncovers malicious Rust crates impersonating fast_log to steal Solana and Ethereum wallet keys from source code.
eslint-plugin-maintainable
Advanced tools
This plugin focused on keeping the code clean, maintainable, and readable for humans. Because coders read existing code most of the times, cumbersome code will slow you down and lead to bugs.
This is achieved via rules like complexity
, sonarjs/cognitive-complexity
, max-params
, max-nested-callbacks
etc.
Also, line length is limited to 80 characters, so it's convinient to split and edit code side by side.
Also includes setup to format code with prettier
via eslint, so no hassle to set up those two.
Feel free to ask questions or propose improvements to "issues"
:star: if you like the the project :)
Need eslint 8+ and prettier 3+
npm i -D eslint@8 eslint-plugin-maintainable@latest prettier@latest
maintainable
to the plugins section of your .eslintrc
configuration file. You can omit the eslint-plugin-
prefix
{
"extends": [
"plugin:maintainable/recommended",
"plugin:maintainable/react",
"...your others configs"
],
"plugins": [
"maintainable"
"...your others plugins"
]
}
By default plugin intended to be used with Typescript, but can tune it for pure JS, just change parser to default "espree" or "@babel/eslint-parser".
"parser": "espree",
.editorconfig
, IDEs and prettier will format code according to itroot = true
[*]
end_of_line = lf
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true
indent_style = space
indent_size = 2
quote_type = single
max_line_length = 80
package.json
eslint-plugin-compat
will tell you if you use api that not supported by browsers
"browserslist": [
"last 5 Chrome versions",
"last 5 ChromeAndroid versions",
"last 5 Firefox versions",
"last 5 FirefoxAndroid versions",
"Firefox ESR",
"last 3 Safari major versions",
"last 2 iOS major versions"
],
husky
and lint-staged
Install deps
npm i -D husky lint-staged
npx husky install
More details at lint-staged repo
Edit(or create) file pre-commit
in .husky
directory with this content:
#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"
npx lint-staged
And update package.json
"lint-staged": {
"*.{js,jsx,ts,tsx}": [
"eslint --fix",
],
"*.{html,css,less,ejs,json}": [
"prettier --write",
]
},
Name | Description | |
---|---|---|
✅ | base | Basic rules and prettier formatter |
✅ | recommended | Basic + more rules for Node and Browser |
✅ | react | Basic + React specific rules |
You can take a look at configs definitions
FAQs
Eslint config to keep code clean and in maintainable state
We found that eslint-plugin-maintainable 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
Socket uncovers malicious Rust crates impersonating fast_log to steal Solana and Ethereum wallet keys from source code.
Research
A malicious package uses a QR code as steganography in an innovative technique.
Research
/Security News
Socket identified 80 fake candidates targeting engineering roles, including suspected North Korean operators, exposing the new reality of hiring as a security function.