Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/adhamfarrag/nodegpm

Unified management for global Node.js packages
https://github.com/adhamfarrag/nodegpm

global-packages npm

Last synced: 3 months ago
JSON representation

Unified management for global Node.js packages

Awesome Lists containing this project

README

        


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

```sh
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:

```ts
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:

```ts
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:

```ts
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:

```ts
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:

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


### Acknowledgement

NodeGPM is inspired by [nypm](https://github.com/unjs/nypm) by [unjs](https://github.com/unjs) team. 💚


### Contributing

Thanks for your interest 💚

If you have any idea, feel free to [open a discussion](https://github.com/adhamfarrag/nodegpm/discussions/new?category=ideas) first and let's talk about it!


### License

[MIT](https://github.com/adhamfarrag/nodegpm/blob/main/LICENSE) License © 2023.