Codementor Events

Creating Public & Private Node Modules

Published Apr 09, 2015Last updated Feb 18, 2017
Creating Public & Private Node Modules

Why Modules are important

Creating modules are important, especially when you want your code to be reusable. Node provides an architecture where you can write and reuse your code in the form of modules, through npm registry. The packages can be published publicly or privately according to your needs. Private modules also make you able to distribute your code to intended users, your team mates or private to yourself, accessible from anywhere.

Writing a Public Module

First create a folder MyModule anywhere. Then set the path to MyModule in cmd. Then you only need to create two files to create your first sample package.

  • package.json
  • index.js

now this can be the simplest module we can create, with just two files.

Creating package.json file

You do not need to explicitly create a package.json file. To create it, write in command prompt.

$npm init

This should ask you following questions:

name: (MyModule) 
version: (1.0.0)           
description:                        
entry point: (index.js)     
test command:                 
git repository:                      
keywords:                                     
author:            
license: (ISC) 

Now you don't even need to answer these, few important questions are: version, description, entry point(which can be changed, by default it is index.js file) and author.

Answer those and skip the rest by pressing enter. This will create a package.json file for your module.

Optionally, you can directly create a package.json file, following the next steps:

  • Create a text file, rename it to package.json
  • Add the following code in it:
{
  "name": "MyModule",
  "version": "1.0.0",
  "description": "My First Module",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "naeem shaikh",
  "license": "MIT"
}

Now we have created the package.json file, we will create the index.js file, which is the entry point of our module.

The index.js File

Now this is our entry point to the module. We will create a simple to array to object converter. For ex:

we will convert this

['john','martin','scott']

to

{
"0": "john",
"1": "martin",
"2": "scott"
}

write following code in your index.js file.

exports.to_Object=function (arr) {
  var obj = {};
  for (var i = 0; i < arr.length; ++i)
    obj[i] = arr[i];
  return obj;
}

Done! we have created a module which exports a function to_Object, which will take an array as a parameter, and return converted object.

Publishing the Module

As we have completed the module, we can now publish it to npm registry. To publish your module, you must have a user on the npm registry. If you don't have one, create it with following command:

 npm adduser

This will ask you the username, password to set and your email address. once done, you can login to npm using the following command:

npm login

This will store your credentials on client, and you would be now able to publish you module to npm registry.

Now the magic step, use this command

 npm publish

This publish your package. To see if your package is actually puslished on npm or not? You can go to following url from your browser:

http://npmjs.com/package/<Package-Name>

Where?

Package-Name is the package name you just created and published.

Updating Your Package

You will need to update your package at some point with some additional feature. If you do, you can the change the version of your module, by using following command:

npm version <update-type>

Where?

update-type is one of the semantic versioning release types, patch, minor, or major. This command will change the version number in package.json.

Note that this will also add a tag with this release number to your git repository if you have one.

Additionally, you can also change the version number directly in your package.json file.

After updating the version number, you can npm publish again. You can then see the package updated at the same url: http://npmjs.com/package/<Package-Name>

Now, create a node project and change the current directory in _cmd _to your project. You can now install your module directly using

npm install Package-Name

using your own module in you node project is similar to how you use other modules such as express

var MyModule= require('MyModule');

Now you get access to your module, and the method defined in it as,

MyModule.to_Object(parameterArray)

write a simple node program, which will use our module.

var MyModule= require('MyModule');

var arr=['john','martin','scott'];
var result=MyModule.to_Object(arr)
console.log(result)

This is what you get in your console.

{
"0": "john",
"1": "martin",
"2": "scott"
}

Creating Private Modules

When you don't want to publish your module to anyone else except few, you can create a private module.

Publishing the private module is similar to publishing the public module, as discussed above, with just one difference, you publish them in your namespace or your team's namespace (with whom you wish to share your module), just by giving them a name in package.json:

{
  "name": "@myuser/MyModule"
}

Publish them with npm publish , just like any other package, and you install them by namespace:

npm install @myuser/MyModule

Once installed, use them by requiring them by namespace, just like any package:

var MyModule= require('@myuser/MyModule');

Conclusion

Creating private or public modules is especially helpful to make you code reusable, distributive and make your code modular, so it's much more readable.

Discover and read more posts from Naeem
get started
post comments1Reply
Paul Green
7 years ago

Thanks really useful, clear and conciseā€¦