As we mentioned in the previous post, “Easy Switching Between Public and Private npm Registries”, the topic of running a private registry server is quite broad. Once you’re running your private registry server and know how to switch between different registries when installing packages, it’s time to look at the process of package publishing.
Consider the following two scenarios…
Keeping private modules private
Some of your modules are open source, thus you want to publish them to the public npmjs.org registry at some point. Others are private and must be published to your private registry. The process should prevent you from publishing a private module to the public repository. A possible solution preventing such errors is to publish public modules to the private registry first and promote them to the public registry later.
Setting up a staging npm registry
You want to set up a staging registry for pre-release versions of your modules, to allow other people to test them simply using npm install. This becomes very useful when you are changing a set of dependent modules and want to ensure the correct pre-release versions of all dependencies. Later, when the pre-release version passes all tests, you want to promote it from the staging registry to the main one.
To implement such process with the current tools, one has to:
- Record a commit or tag ID for each pre-release version being published.
- To promote a version, retrieve the appropriate commit/tag ID and check out the source code from the repository.
- Once you’ve obtained the right version of the source, publish the package to a different registry using npm publish. Caveat: you must first configure the npm client to use the right registry URL, authentication credentials, and other related options.
slc to the rescue
Today we are happy to announce a new addition to our slc toolbox:
$ slc registry promote
Assuming you have already configured the source and the target registry using
slc registry add, you can promote any package with a single command. For example:
$ slc registry promote --from team --to staging [email protected]
1. Update your slc tool
$ slc update
or install it from the public npmjs.org registry
$ npm install -g strong-cli
2. Add a new configuration for your private registry
$ slc registry add private
3. Switch your npm client to use the private registry
$ slc registry use private
The steps 1–3 are the initial setup. You have do them only once.
4. Publish a package to the private registry
$ npm publish
5. Promote a package version to the public registry
$ slc registry promote --from private --to default [email protected]
- Learn more in the documentation: Using multiple package registries and slc registry command reference.
Ready to start monitoring event loops, manage Node clusters and chase down memory leaks? We’ve made it easy to get started with StrongOps either locally or on your favorite cloud, with a simple npm install.
- What’s in the upcoming Node v0.12 release? Big performance optimizations, read Ben Noordhuis’ blog to learn more.
- Ready to develop APIs in Node.js and get them connected to your data? Check out the Node.js LoopBack framework. We’ve made it easy to get started either locally or on your favorite cloud, with a simple npm install.
- Need training and certification for Node? Learn more about both the private and open options StrongLoop offers.