Skip to content

A package for detecting all duplicated property keys of a JSON string.

License

Notifications You must be signed in to change notification settings

Dazedi/find-duplicated-property-keys

 
 

Repository files navigation

find-duplicated-property-keys

npm version Build Status Coverage Status JavaScript Style Guide

A package for detecting all duplicated property keys of a JSON string. It can either be used as a standalone tool for validating JSON files or as a submodule for other Node.js projects.

Use as a Standlone Tool

If you like to use find-duplicated-property-keys as a standalone tool, you first have to install it by using the following command:

$ npm install find-duplicated-property-keys

To run this tool you simply need to execute it from the installation directory like this:

$ node_modules/.bin/find-duplicated-property-keys -s <path-to-json-file>

Of course, if you prefer a more comfortable way of running this tool, you can also install it globally by using this command:

$ npm install -g find-duplicated-property-keys

Then you can run find-duplicated-property-keys from any directory by using the following command:

$ find-duplicated-property-keys -s <path-to-json-file>

When running the tool from terminal, it will list all duplicated property keys or return a notification to indicate the JSON file does not contain any duplicated property keys.

Use as a Submodule

In case you need to include find-duplicated-property-keys into another project, you first have to add it to your Node.js application by executing the following command while being in the root directory of your project:

$ npm install find-duplicated-property-keys

To validate a JSON string you can run the module as described in the following example:

const findDuplicatedPropertyKeys = require('find-duplicated-property-keys');

const jsonString = '{"name": "Carl", "name": "Carla"}';

const result = findDuplicatedPropertyKeys(jsonString);

console.log(result.toString()); // <instance>.name

The returned result will be an array that contains all duplicated property keys. Each of these property keys is represented by an object which has the following attributes:

  • key: The key name of the duplicated property.
  • parent: The parent object of a property key.
  • occurrence: The number of property keys having the same key and parent object.

Moreover, these objects also contain the following functions for illustrating the actual path to the property key:

  • propertyPath(): Returns a list of property keys, which represents the path to the property key of the current object.
  • toString(): Prints the path to the property key. However, since all necessary raw data are also contained by the object, the result objects can also be represented in any other way if desired.

Note: When using find-duplicated-property-keys as a submodule, you always have to pass a JSON string instead of the file path to a JSON file.

About

A package for detecting all duplicated property keys of a JSON string.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%