Anatoly
Anatoly

Reputation: 5243

Define private registry in package.json

We have a private npm repository based on Sinopia

What should I define in package.json that some packages will be installed from Synopia rather then from global npm repository?

If I install it from command line I can run: npm install <package_name> --registry <http://<server:port>

P.S. tried to google and looked in official NPM documentation but have found nothing.

Upvotes: 28

Views: 42906

Answers (3)

Gabor Dicso
Gabor Dicso

Reputation: 33

In case anyone has the same question in 2024, you can use Verdaccio (a Sinopia fork maintained by Juan Picado among others, see his answer here). Himanshu sharma's answer works fine using Verdaccio as well. You don't have to provide your auth credentials in the .npmrc file in your project folder, you can authenticate with npm adduser --registry http://localhost:4873 and store the credentials in .npmrc in your home folder.

Upvotes: 0

Himanshu sharma
Himanshu sharma

Reputation: 7901

One of the method i know that is by .npmrc You can also use .npmrc also inside the project

set configuration like this

registry = http://10.197.142.28:8081/repository/npm-internal/
init.author.name = Himanshu sharma
init.author.email = [email protected]
init.author.url = http://blog.example.com
# an email is required to publish npm packages
[email protected]
always-auth=true
_auth=YWRtaW46YWRtaW4xMjM=

auth can be generate by username:password echo -n 'admin:admin123' | openssl base64

output YWRtaW46YWRtaW4xMjM=

Upvotes: 34

Juan Picado
Juan Picado

Reputation: 1996

The whole point of sinopia is a private registry and a proxy at the same time. You can use uplinks install all your packages from one registry entry point. Sinopia is able to route to any registry if the local storage is not able to resolve the dependency. By default, he points to npmjs .

So, if you set your configuration like

   # a list of other known repositories we can talk to
uplinks:
  npmjs:
    url: https://registry.npmjs.org/

packages:
  '@*/*':
    # scoped packages
    access: $all
    publish: $authenticated
    proxy: npmjs

  '**':
    # allow all users (including non-authenticated users) to read and
    # publish all packages
    #
    # you can specify usernames/groupnames (depending on your auth plugin)
    # and three keywords: "$all", "$anonymous", "$authenticated"
    access: $all

    # allow all known users to publish packages
    # (anyone can register by default, remember?)
    publish: $authenticated

    # if package is not available locally, proxy requests to 'npmjs' registry
    proxy: npmjs

You should be able to resolve all your dependencies independently of the source of each of them

btw: sinopia has no longer maintained.

Upvotes: 1

Related Questions