ChatGPT解决这个技术问题 Extra ChatGPT

How to install an npm package from GitHub directly

Trying to install modules from GitHub results in this error:

ENOENT error on package.json.

Easily reproduced using express:

npm install https://github.com/visionmedia/express throws error.

npm install express works.

Why can't I install from GitHub?

Here is the console output:

npm http GET https://github.com/visionmedia/express.git
npm http 200 https://github.com/visionmedia/express.git
npm ERR! not a package /home/guym/tmp/npm-32312/1373176518024-0.6586997057311237/tmp.tgz
npm ERR! Error: ENOENT, open '/home/guym/tmp/npm-32312/1373176518024-0.6586997057311237/package/package.json'
npm ERR! If you need help, you may report this log at:
npm ERR!     <http://github.com/isaacs/npm/issues>
npm ERR! or email it to:
npm ERR!     <npm-@googlegroups.com>

npm ERR! System Linux 3.8.0-23-generic
npm ERR! command "/usr/bin/node" "/usr/bin/npm" "install" "https://github.com/visionmedia/express.git"
npm ERR! cwd /home/guym/dev_env/projects_GIT/proj/somename
npm ERR! node -v v0.10.10
npm ERR! npm -v 1.2.25
npm ERR! path /home/guym/tmp/npm-32312/1373176518024-0.6586997057311237/package/package.json
npm ERR! code ENOENT
npm ERR! errno 34
npm ERR!
npm ERR! Additional logging details can be found in:
npm ERR!     /home/guym/dev_env/projects_GIT/proj/somename/npm-debug.log
npm ERR! not ok code 0
Can anyone give the package.json devDependencies format?
@Adam you can add "express": "github:visionmedia/express" to the "dependencies" section of package.json file, then run: npm install (as mentioned below)
@danny, that doesn't work for me. i wonder if there was a dist folder in that express repo to enable it.

S
Smart Manoj

Because https://github.com/visionmedia/express is the URL of a web page and not an npm module. Use this flavor: git+{url}.git

git+https://github.com/visionmedia/express.git

or this flavor if you need SSH:

git+ssh://git@github.com/visionmedia/express.git

You can also use git+https://github.com/visionmedia/express.git to use https rather than ssh.
Note that repository you want to install must be a npm module, it must contain a package.json file or else you will get this error: Error: ENOENT, open 'tmp.tgz-unpack/package.json'.
what if I want a specific branch
Only solution I think of for now is to specify a commit with .../express.git#commit
Worth saying that you might need to escape the # to use a specific branch from the shell, i.e.: npm install git+https://github.com/user/repo.git\#branch
J
Jeremy Caney

To install from GitHub, you can also do

npm install visionmedia/express

Or

npm install visionmedia/express#branch

There is also support for installing directly from a Gist, Bitbucket, GitLab, and a number of other specialized formats. Look at the npm install documentation for them all.


What, without specifying URL? How does npm know which flavor hosting service you're using?
@Jake Rayson: it's possible since version 1.1.65 and works for github.com only.
Didn't work for me on Windows - it just tried to install from a subfolder of my current directory.
Note this doesn't work on global installs (i.e. npm i repo/pkg -g) as of npm 1.4.28
Note that you need a package.json file in there.
P
Peter Mortensen

If Git is not installed, we can try:

npm install --save https://github.com/Amitesh/gulp-rev-all/tarball/master

You can also use tag names in place of master. Probably safer to do it that way.
Yes. It will be more safer. Thank you to bring this in focus.
Nice for when you are working with branches, you should modify your answer to include a general format answer, i didn't notice the /tarball/ at first
This is the only answer which worked for me when installing a dependency from within a Docker container.
This is also perfect for not requiring the entire repo to be downloaded. Thanks!
P
Peter Mortensen

As of September 2016, installing from vanilla HTTPS GitHub URLs now works:

npm install https://github.com/fergiemcdowall/search-index.git

You can't do this for all modules because you are reading from a source control system, which may well contain invalid/uncompiled/buggy code. So to be clear (although it should go without saying): given that the code in the repository is in an npm-usable state, you can now quite happily install directly from GitHub.

In October 2019, we are now living through "peak TypeScript/React/Babel", and therefore JavaScript compilation has become quite common. If you need to take compilation into account, look into prepare. That said, NPM modules do not need to be compiled, and it is wise to assume that compilation is not the default, especially for older node modules (and possibly also for very new, bleeding-edge "ESNext"-y ones).


You can't install any npm package you want from its GitHub source, unless the repo includes a dist folder, and most don't. The issue I linked to is an npm bug - the prebuild step is not run when installing from GitHub. As an example, try installing node-influx/node-influx.
Repos without dist folders CAN be installed from GitHub, for example: npm install https://github.com/fergiemcdowall/search-index-adder works perfectly.
Right, because you have the directly usabel source in /lib (as if you had a dist folder). My point is that just including the GitHub URL of a repo in package.jons isn't guaranteed to work for installing that repo. Modules written in TypeScript, for example, need push their transpiled code into the repo. They typically don't do this, but rather use a prepublish script to dump the .JS code into a dist folder, which gets uploaded to npmjs.com.
I know this is a bit late, but the trick is actually npm does not have a 1-to-1 mapping to Git repositories. Some projects build their source files before publishing rather than before committing, meaning they are NOT in the Git repo, but would be in the npm package - projects doing this will not work right from Git. Another example of how this can fail is macro repositories - Babel's GitHub project, for example, includes hundreds of individual npm packages in subfolders. They can be published individually because npm does not map directly to Git. npm publishes whatever is in your directory.
For anyone who stumbles upon this later... As of npm5, npm will run any prepare script for bare "installs", which includes git deps. Which means the above comments around compilation and dist folders is out of date. Any package that properly sets their compilation to run on prepare will work just fine as a git dep without committing any compiled assets into git.
P
Peter Mortensen

The methods are covered pretty well now in npm's install documentation as well as the numerous other answers here.

npm install git+ssh://git@github.com:<githubname>/<githubrepo.git[#<commit-ish>]
npm install git+ssh://git@github.com:<githubname>/<githubrepo.git>[#semver:^x.x]
npm install git+https://git@github.com/<githubname>/<githubrepo.git>
npm install git://github.com/<githubname>/<githubrepo.git>
npm install github:<githubname>/<githubrepo>[#<commit-ish>]

However, something notable that has changed recently is npm adding the prepare script to replace the prepublish script. This fixes a long-standing problem where modules installed via Git did not run the prepublish script and thus did not complete the build steps that occur when a module is published to the npm registry. See Run prepublish for Git URL packages #3055.

Of course, the module authors will need to update their package.json file to use the new prepare directive for this to start working.


Watch out for issues with .gitignore files! stackoverflow.com/questions/48287776/…
Note that the git:// protocol is no longer supported (it was when this answer was written)
z
zakelfassi

There's also npm install https://github.com/{USER}/{REPO}/tarball/{BRANCH} to use a different branch.


I ran into this issue...github.com/yarnpkg/yarn/issues/2738 I was able to change the registry to the github tarball registry and it worked.. Thanks!
This resolved some major performance issues for me. Using {USER}/{REPO}.git#{BRANCH} was very slow.
THIS ^^^^ is what I'd been looking for. My library relies on a build step and didn't have a prepare script. I was just trying to install a branch of the whole repo in a test repo, but since the built code wasn't checked into GitHub, all that got installed was package.json and the readme. This tarball approach using the full URL installed all the source files, which is what I needed.
@jdunning You do not need to check your compiled code into git to use the prepare method! You just need to watch out for issues from also including a .gitignore: stackoverflow.com/questions/48287776/…
P
Peter Mortensen

The current top answer by Peter Lyons is not relevant with recent NPM versions. For example, using the same command that was criticized in this answer is now fine.

npm install https://github.com/visionmedia/express

If you have continued problems it might be a problem with whatever package you were using.


It also redirects to github.com/expressjs/express automatically now when you use this command :)
i
ishandutta2007

The general form of the syntax is

<protocol>://[<user>[:<password>]@]<hostname>[:<port>][:][/]<path>[#<commit-ish> | #semver:<semver>]

which means for your case it will be

npm install git+ssh://git@github.com/visionmedia/express.git

From npmjs docs:

npm install : Installs the package from the hosted git provider, cloning it with git. For a full git remote url, only that URL will be attempted. ://[[:]@][:][:][/][# | #semver:] is one of git, git+ssh, git+http, git+https, or git+file. If # is provided, it will be used to clone exactly that commit. If the commit-ish has the format #semver:, can be any valid semver range or exact version, and npm will look for any tags or refs matching that range in the remote repository, much as it would for a registry dependency. If neither # or semver: is specified, then master is used. If the repository makes use of submodules, those submodules will be cloned as well. If the package being installed contains a prepare script, its dependencies and devDependencies will be installed, and the prepare script will be run, before the package is packaged and installed. The following git environment variables are recognized by npm and will be added to the environment when running git: GIT_ASKPASS GIT_EXEC_PATH GIT_PROXY_COMMAND GIT_SSH GIT_SSH_COMMAND GIT_SSL_CAINFO GIT_SSL_NO_VERIFY See the git man page for details. Examples: npm install git+ssh://git@github.com:npm/npm.git#v1.0.27 npm install git+ssh://git@github.com:npm/npm#semver:^5.0 npm install git+https://isaacs@github.com/npm/npm.git npm install git://github.com/npm/npm.git#v1.0.27 GIT_SSH_COMMAND='ssh -i ~/.ssh/custom_ident' npm install git+ssh://git@github.com:npm/npm.git npm install


P
Peter Mortensen

You can do:

npm install git://github.com/foo/bar.git

Or in package.json:

"dependencies": {
  "bar": "git://github.com/foo/bar.git"
}

O
Omar Omeiri

This works for me and it is less typing.

npm i github:<UserName>/<RepoName>

package.json

{
    "dependencies": {
        "name": "github:<UserName>/<RepoName>"
    }
}

This way is baller!
This works with yarn.
T
Tyler Liu

Install it directly:

npm install visionmedia/express

Alternatively, you can add "express": "github:visionmedia/express" to the "dependencies" section of package.json file, then run:

npm install

A
Alex Cory

You could also do

npm i alex-cory/fasthacks

or

npm i github:alex-cory/fasthacks

Basically:

npm i user_or_org/repo_name

P
Peter Mortensen

You can directly install a GitHub repository by the npm install command, like this:

npm install https://github.com/futurechallenger/npm_git_install.git --save

NOTE: In the repository which will be installed by npm command:

maybe you have to have a dist folder in you repository, according to Dan Dascalescu's comment. You definitely have to have a package.json in your repository! Which I forget add.


You do not need a dist folder or any build code in your repo. You just need to use a prepare script in package.json.
P
Peter Mortensen

Simple:

npm install *GithubUrl*.git --save

Example:

npm install https://github.com/visionmedia/express.git --save

Z
Zephyr

I tried npm install git+https://github.com/visionmedia/express but that took way too long and I wasn't sure that would work.

What did work for me was - yarn add git+https://github.com/visionmedia/express.


S
Siddharth Murugan

Below piece of code worked for me to install from github repository:

npm install git+ssh://<your_repository_ssh_clone_link>#<branch_name_if_any>

You can get ssh clone link as below:

https://i.stack.imgur.com/EZ2fU.png

So for above screenshot repository, you may need to import as below,

npm install git+ssh://git@github.com:Siddhu2/calculator-chatbot.git#master

where master is my branch and it is optional since I have only one branch.


s
sultanmyrza

Sometimes I need to install from a specific branch or commit. To make things simple I just use https://gitpkg.vercel.app/

https://i.stack.imgur.com/Gpuak.png


P
Peter Mortensen

If you get something like this:

npm ERR! enoent undefined ls-remote -h -t https://github.com/some_repo/repo.git

Make sure you update to the latest npm and that you have permissions as well.


T
Toxnyc

The only command that worked for me was npm i MY_PACKAGE_NAME:MY_REPOSITORY#BRANCH_NAME


J
Jeremy Caney

No need to do much; this helped me:

Yarn add <git_name>:<github_name>/<Repository_name>.git

Example:

yarn add git@github.com:myGitHub/dynamic-checkbox-input.git

And if you want to add some specific commit or branch name then add #.

Example:

yarn add git@github.com:myGitHub/dynamic-checkbox-input.git#master

Example:

yarn add git@github.com:myGitHub/dynamic-checkbox-input.git#c978U57

P
Peter Mortensen

Try this command:

 npm install github:[Organisation]/[Repository]#[master/BranchName] -g

This command worked for me:

 npm install github:BlessCSS/bless#3.x -g

The version is the tag / branch name or the package.json version ?
Why two commands? Should both be used (in that order). Or only one or the other? This is not clear. Can you elaborate? Please respond by editing (changing) your answer, not here in comments (without "Edit:", "Update:", or similar - the answer should appear as if it was written today).