/nodegpm

Unified management for global Node.js packages

Primary LanguageTypeScriptMIT LicenseMIT

NodeGPM

Unified management for global Node.js packages

🚧 Project is under development 🚧

npm-badge


What does NodeGPM do?

NodeGPM (Node Global Package Manager) is designed to simplify the management of global Node.js packages across different package managers like npm, yarn, pnpm, and bun. It provides a set of utility functions to perform tasks such as installing, removing, detecting globally installed packages, detecting available package managers, most used one, and more soon.

It uses command line tools for each package manager (npm, yarn, pnpm, and bun) to perform the tasks to make development easier, faster and more reliable.

Note: Bun doesn't offer needed commands to search for globally installed packages, so it's not supported yet.



Installation

npm install nodegpm

yarn add nodegpm

pnpm add nodegpm

bun add nodegpm

Usage

Here are the vailable functions:

Detecting Global Package Managers

To detect which global package managers are installed, you can use the detectPackageManagers function:

const globalPackageManagers = await detectPackageManagers();
console.log('Installed global package managers:', globalPackageManagers);

Detecting Most Used Global Package Manager

To detect the most used global package manager, you can use the mostUsedGPM function:

const mostUsedPM = await mostUsedGPM();
console.log('Most used global package manager:', mostUsedPM);

Detecting Globally Installed Package(s)

To detect if a package is installed globally, you can use the isGloballyInstalled function:

const nuxi = await isInstalledGlobally('nuxi');
console.log('Is nuxi installed globally?', nuxi);

Installing Packages Globally

You can use the installGlobally function to install packages globally using a specific package manager:

const pm = 'npm'; // Package manager (npm, yarn, pnpm, bun), default is most-used
const packages = ['prettier', 'eslint'];
await installGlobally(packages, pm);

Removing Packages Globally

To remove globally installed packages, you can use the removeGlobally function:

const packagesToRemove = ['prettier', 'eslint'];
await removeGlobally(packagesToRemove);

Acknowledgement

NodeGPM is inspired by nypm by unjs team. 💚


Contributing

Thanks for your interest 💚
If you have any idea, feel free to open a discussion first and let's talk about it!


License

MIT License © 2023.