Storybook: Getting 404 Registry returned when trying to run `npm install`

Created on 1 Apr 2016  路  32Comments  路  Source: storybookjs/storybook

Edited by @ndelangen:

I can see quite a bit of traffic to this issue, so I hope by editing this first message I will save a lot of people some time.

This problem occurs for companies that must use private npm proxies, mostly old ones do not properly support npm organisations. Or they are configured to not support them. An example would be artifactory.

Notify your support team about it to get support. More and more open source will eventually (have to) migrate to organisations because the global registry is getting crowded and package names are being squated.

But understandable you want a solution now,
This solution will likely work for you:

create a .npmrc-file in the root of your project (or higher in the directory-tree) with:

@storybook:registry=https://registry.npmjs.org/

If you're on a version of storybook lower than 3 you should use: @kadira:registry=https://registry.npmjs.org/

If the .npmrc file already exists, you can just append to the bottom of the file.

Since storybook has some dependencies in other npm-organisations like @types, you will probably need to add those as well.

@types:registry=https://registry.npmjs.org/

Original message:

Simply cloned your repo and ran npm install and got the error:

npm ERR! 404 Registry returned 404 for GET on https://npm-proxy.fury.io/C__hqNZ_HngaWmEnB-ps/massdrop/@kadira%2fstorybook
npm ERR! 404
npm ERR! 404 '@kadira/storybook' is not in the npm registry.
compatibility with other tools question / support

Most helpful comment

Yea, I was using sinopia. Doing a npm set registry https://registry.npmjs.org/ solved the problem.

All 32 comments

Same

This is a scoped NPM package. I hope that's not available on mirrors yet or something.

Is it possible for you guys to use the official mirror. If not directly install from github.

@arunoda - Sorry, mind if you explain more of what you mean?

@tedlin182 it seems like you are using fury.io as the NPM mirror.
May be to support private modules.

They seems not support scoped NPM modules. Starting with @.

Just contact them and verify.
As a quick fix, use our github repo URL as the package version. Then it get the module via NPM.

Yea, I was using sinopia. Doing a npm set registry https://registry.npmjs.org/ solved the problem.

I hope we are good here. Hope there's nothing we can do for this.
I'll add this into the README, if someone got this error.

It's great to reopen this since a few people seems to have this issue. Keeping this in the issue list will help them to see this.

Setting the registry unfortunately hasn't fixed it for me. :(

$ npm set registry https://registry.npmjs.org/
$ npm i --save-dev @kadira/storybook
npm ERR! Darwin 15.0.0
npm ERR! argv "/usr/local/bin/node" "/usr/local/bin/npm" "i" "--save-dev" "@kadira/storybook"
npm ERR! node v5.10.0
npm ERR! npm  v3.8.3

npm ERR! Invalid name: "@kadira/storybook"

Also adding the github url in package.json leads to the same result.

"@kadira/storybook": "https://github.com/kadirahq/react-storybook.git#v1.1.0"

I suppose, I'm still somehow holding it wrong.

Has this issue been fixed? I'm having the same issue as @robin-drexler

@nrempel @robin-drexler

You you can get if from the github like this:

"@kadira/storybook": "https://github.com/kadirahq/react-storybook.git"

I had to publish the dist directory to github in order to enable this.

Thanks @arunoda

That didn't fix my problem but I was able to fix it by explicitly upgrading npm to version 3.8.6 by running npm update npm -g. Now I can install it correctly with npm i --save-dev @kadira/storybook.

The version of npm that did not work was 3.8.3.

I think it was a bug with npm itself.

cc: @robin-drexler

For folks that are on npm 2.x I ran into this issue and found that npm 2.15.1 will fail but after upgrading to 2.15.3 everything is working.

Would you consider to publish this as non scoped package?
With the scoped name I cannot use the amazing pnpm substitute of npm project that saves soo much space with creating symlinks instead of having a copy of storybook in each project.

I have 13 packages that use storybook. Each package copies over 500MB and 300.000+ files just because of the storybook. This is hell for the cloud backup and more. Thanks!

We choose scoped packages for a reason to avoid global name collision (ref: the left-pad story). So, we are unlikely to change that.

But, we do realize the pain.

Im having the Invalid name: "@kadira/storybook" issue.
Same error when I npm i --save-dev @kadira/storybook or just add it to package.json with "@kadira/storybook": "https://github.com/kadirahq/react-storybook.git".

I've tried with node 5.11.1 (npm 3.8.6) and 6.2.2 (npm 3.9.5).
The registry I use is https://registry.npmjs.org/.

On OS X.

I don't think it's a duplicate of this issue, but issues like https://github.com/kadirahq/react-storybook/issues/22 is referring to this one.

Any ideas?

Seems like something like this: https://github.com/npm/npm/issues/10344
This will tell me to move this package to something like react-storybook.

There's nothing we can do about this issue.

This is a problem for companies that must use private npm proxies, we can't just switch to using global. If there isn't a specific reason for using scopes would appreciate you publishing non-scoped.

Using github repo URL also seems broken with proxies due to the internal scoped dependencies you use:

npm ERR! 404 Registry returned 404 for GET on https://npm-proxy.fury.io/________/@kadira%2fstorybook-ui

Hey, most of the private repositories now supports scoped modules.

Try their docs.

Great, thank you. This helped:

The solution is to set a registry for modules of specific scope. You can add the following to your project's .npmrc file

@kadira:registry=https://registry.npmjs.org

Put your auth token into local .npmrc (the .npmrc file inside the repository folder), not into the global one.

//registry.npmjs.org/:_authToken=00000000-0000-0000-0000-000000000000

@gthomas-appfolio that did the trick for me thanks a lot <3

First Run:

npm cache clean

Next:

npm rebuild

Cheers!

You can override the registry for specific scopes, if that's the easiest workaround. For example:

npm config set @types:registry https://registry.npmjs.org/

That would tell npm to always get anything for the @types scope directly from the official server on the internet, bypassing Sinopia entirely. Obviously it won't be the right fix for everyone. npm would need internet access (via a proxy if necessary) and there won't be any centralised caching.

Also, name in pakage.json , should have scope:
"name": "@scope/name"
This help me resolve this issues.

hi
for me npm cache clean
and
npm rebuild
worked
thanks

Just run either of the below commands in terminal

  sudo sysctl -w kern.maxfiles=5242880
  sudo sysctl -w kern.maxfilesperproc=524288

Initially I tried with "npm set registry https://registry.npmjs.org" (without quotes) and it didnt work. Later I tried with npm set registry https://registry.npmjs.org/ and it worked. "/" MATTERS

Thank you @suhas777 I've updated the first post to match. 馃憦

@arunoda Thank you very much! You are right, I am use the official mirror.

Was this page helpful?
0 / 5 - 0 ratings

Related issues

dnlsandiego picture dnlsandiego  路  3Comments

purplecones picture purplecones  路  3Comments

ZigGreen picture ZigGreen  路  3Comments

xogeny picture xogeny  路  3Comments

oriSomething picture oriSomething  路  3Comments