|  | 3 years ago | |
|---|---|---|
| .. | ||
| .github | 3 years ago | |
| .eslintrc.js | 3 years ago | |
| LICENSE | 3 years ago | |
| README.md | 3 years ago | |
| index.d.ts | 3 years ago | |
| index.js | 3 years ago | |
| package.json | 3 years ago | |
:information_desk_person: show a message to your users to upgrade Node instead of a stacktrace
It's common for new Node users to miss or not understand engines warning when installing a CLI. This package displays a beginner-friendly message if their Node version is below the one expected.
$ node -v
0.12
$ modern-cli
modern-cli requires at least version 6 of Node, please upgrade
If you like this project, you can support me on GitHub Sponsors
npm install please-upgrade-node
Add please-upgrade-node at the top of your CLI
#!/usr/bin/env node
const pkg = require('./package.json')
require('please-upgrade-node')(pkg) // <- Must run BEFORE requiring any other modules
// ...
Set in your package.json the required Node version
{
  "engines": {
    "node": ">=6"
  }
}
Important: >= is the only operator supported by please-upgrade-node (e.g. >=6, >=6.0, >=6.0.0).
You can set custom exitCode and message function if needed
pleaseUpgradeNode(pkg, {
  exitCode: 0, // Default: 1
  message: function(requiredVersion) {
    return 'Oops this program require Node ' +  requiredVersion
  }
})
Important: to keep message function compatible with older versions of Node, avoid using ES6 features like => or string interpolation.
Thanks to zeit/serve for the error message inspiration.
MIT - Typicode :cactus: - Patreon