install-pnpm-package
v0.5.2
Published
Install node packages with pnpm, npm or yarn
Downloads
6
Maintainers
Readme
install-pnpm-package
Install packages into npm
, pnpm
or yarn
projects.
Does not require any package manager to be installed, as it uses
@pnpm/core
or
@npmcli/arborist directly. This way it also does
not spawn a new process.
Usage
import { installPackage, removePackage } from "install-pnpm-package"
// Install a node package
await installPackage("lodash")
// Remove a node package
await removePackage("lodash")
// Install multiple packages
await installPackage(["lodash", "underscore", "ramda"])
// Install a package into a project in /projects/my-project
await installPackage("lodash", { directory: "/projects/my-project" })
// Install a package as devDependencies
await installPackage("lodash", { type: "dev" })
// Install a package as peerDependencies (and devDependencies)
await installPackage("lodash", { type: "peer" })
// Install a package as optionalDependencies
await installPackage("lodash", { type: "optional" })
// Install a package using the yarn.lock lockfile
await installPackage("lodash", { packageManager: "yarn" })
// Install a package using the package-lock.json lockfile
await installPackage("lodash", { packageManager: "npm" })
// Remove multiple packages
await removePackage(["lodash", "underscore", "ramda"])
// Remove a package from a project in /projects/my-project
await removePackage("lodash", { directory: "/projects/my-project" })
// Remove a package from dependencies, devDependencies, optionalDependencies and peerDependencies
await removePackage("lodash")
// Remove a package only from dependencies
await removePackage("lodash", { type: "normal" })
// Remove a package only from devDependencies
await removePackage("lodash", { type: "dev" })
// You can basically combine all operations above, e.g. remove multiple modules from devDependencies from a package in /projects/my-project
await removePackage(["lodash", "underscore"], { directory: "/projects/my-project", type: "dev" })
If you already know which lockfile format you want to use, you can also use the installPackageNpm
,
installPackagePnpm
or installPackageYarn
functions.
How does installPackage know which lockfile to generate
We parse the lockfiles inside the target directory and generate lockfiles for the same format afterwards.
In future we could also look into the node_modules structure or the packageManager key in package.json, but that is not implemented yet.
Background
I want to install packages without spawning a new process for the package manager.
Initially I tried to use @yarnpkg/core
and
@yarnpkg/plugin-essentials
, but they couple
the UI and some of the functionality. Yarn uses a mix of an object oriented and a functional style, in which it took me
quite a while to realize where the properties for this
got defined. The
function that gets called on yarn add ...
also does some prompts to the user and outputs information. There is
project.install
(defined here), which
probably does what I want, but I did not investigate that further for now.
Instead I looked for an alternative package manager with an easier API. The other modern node package manager is
pnpm, so I started there. I skimmed through the pnpm git repo and found the
mutateModules
function in
@pnpm/core
. While it is a bit tricky to use, it was still a lot easier than anything I did with yarn. Basically I had
to pass an object with information about the current manifest of the project and what dependencies should be changed as
the first argument, and a StoreController
and the lockfile as the second argument. Finding out how to optain the
manifest and the StoreController
took a bit, but I learned, that pnpm already has some convenient functions to create
those from basic information
(createOrConnectStoreController
from @pnpm/store-connection-manager
and
readProjectManifest
from @pnpm/read-project-manifest).
You also need to sepecify lockfileDir
in the second parameter of mutateModules
. If you don't pnpm will look for a
lockfile in a directory above yours and use that.
Related projects
- npm-install-package: Install packages from javascript. Spawns a npm process.
- install-package: Install packages from javascript. Spawns a npm process. Has a great name.
- yarn-programmatic: Use basic yarn functions from javascript. Spawns yarn.
- pnpm-install: Does basically the same thing as this package. Uses a different pnpm API, maybe produces output, I haven't tested it yet. The npm package has no keywords, description or linked gitrepo, so I did not find this until after creating this package.
- yarn-install: Install packages from javascript. Spawns a yarn or npm process.
- @npmcli/arborist: The library npm uses to manage
node_modules
trees. Easy to use for a few specific tasks, quite a pain for anything unusual. - @pnpm/core: The core API of pnpm. Quite powerful, but somewhat hard to use
- @yarn/core: The core API of yarn 2. Lowlevel functionality for package management.