Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

object-merge

Package Overview
Dependencies
Maintainers
1
Versions
12
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

object-merge - npm Package Compare versions

Comparing version 2.2.3 to 2.3.0

63

browser/object-merge_web.js

@@ -153,29 +153,50 @@ (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);throw new Error("Cannot find module '"+o+"'")}var f=n[o]={exports:{}};t[o][0].call(f.exports,function(e){var n=t[o][1][e];return s(n?n:e)},f,f.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){

}
function main(shadows) {
var out = getOutputObject(shadows);
function shadowHandler(val, prop, shadow) {
// this is the queue of visited objects / properties.
var visited = [];
function objectMergeRecursor(shadows) {
// if any of the current objects to process exist in the queue
// then throw an error.
shadows.forEach(function (item) {
if (item instanceof Object && visited.indexOf(item) > -1) {
throw new Error('Circular reference error');
}
});
// if none of the current objects were in the queue then add references
// to the queue.
visited = visited.concat(shadows);
function main(shadows) {
var out = getOutputObject(shadows);
/*jslint unparam:true */
if (out[prop]) {
out[prop] = objectMerge(out[prop], shadow[prop]);
} else {
out[prop] = objectMerge(shadow[prop]);
function shadowHandler(val, prop, shadow) {
if (out[prop]) {
out[prop] = objectMergeRecursor([
out[prop],
shadow[prop]
]);
} else {
out[prop] = objectMergeRecursor([shadow[prop]]);
}
}
/*jslint unparam:false */
function shadowMerger(shadow) {
objectForeach(shadow, shadowHandler);
}
// short circuits case where output would be a primitive value
// anyway.
if (out instanceof Object) {
// only merges trailing objects since primitives would wipe out
// previous objects, as in merging {a:'a'}, 'a', and {b:'b'}
// would result in {b:'b'} so the first two arguments
// can be ignored completely.
var relevantShadows = getShadowObjects(shadows);
relevantShadows.forEach(shadowMerger);
}
return out;
}
function shadowMerger(shadow) {
objectForeach(shadow, shadowHandler);
}
// short circuits case where output would be a primitive value anyway.
if (out instanceof Object) {
// only merges trailing objects since primitives would wipe out previous
// objects, as in merging {a:'a'}, 'a', and {b:'b'} would result in
// {b:'b'} so the first two arguments can be ignored completely.
var relevantShadows = getShadowObjects(shadows);
relevantShadows.forEach(shadowMerger);
}
return out;
return main(shadows);
}
return main(shadows);
return objectMergeRecursor(shadows);
}
module.exports = objectMerge;
},{"clone-function":2,"object-foreach":3}]},{},[1])
//@ sourceMappingURL=data:application/json;base64,{"version":3,"file":"generated.js","sources":["C:/Users/kastor/Documents/GitHub/object-merge/dev/browserMain.js","C:/Users/kastor/Documents/GitHub/object-merge/node_modules/clone-function/src/clone-function.js","C:/Users/kastor/Documents/GitHub/object-merge/node_modules/object-foreach/src/object-foreach.js","C:/Users/kastor/Documents/GitHub/object-merge/src/object-merge.js"],"names":[],"mappings":";AAAA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourcesContent":["objectMerge = require('../src/object-merge.js');\r\n","/*\r\nLicense gpl-3.0 http://www.gnu.org/licenses/gpl-3.0-standalone.html\r\n*/\r\n/*jslint\r\n    evil: true,\r\n    node: true\r\n*/\r\n'use strict';\r\n/**\r\n * Clones non native JavaScript functions, or references native functions.\r\n * @author <a href=\"mailto:matthewkastor@gmail.com\">Matthew Kastor</a>\r\n * @param {Function} func The function to clone.\r\n * @returns {Function} Returns a clone of the non native function, or a\r\n *  reference to the native function.\r\n */\r\nfunction cloneFunction(func) {\r\n    var out, str;\r\n    try {\r\n        str = func.toString();\r\n        if (/\\[native code\\]/.test(str)) {\r\n            out = func;\r\n        } else {\r\n            out = eval('(function(){return ' + str + '}());');\r\n        }\r\n    } catch (e) {\r\n        throw new Error(e.message + '\\r\\n\\r\\n' + str);\r\n    }\r\n    return out;\r\n}\r\nmodule.exports = cloneFunction;","/**\r\n * Executes a function on each of an objects own enumerable properties. The\r\n *  callback function will receive three arguments: the value of the current\r\n *  property, the name of the property, and the object being processed. This is\r\n *  roughly equivalent to the signature for callbacks to\r\n *  Array.prototype.forEach.\r\n * @param {Object} obj The object to act on.\r\n * @param {Function} callback The function to execute.\r\n * @returns {Object} Returns the given object.\r\n */\r\nfunction objectForeach(obj, callback) {\r\n    \"use strict\";\r\n    Object.keys(obj).forEach(function (prop) {\r\n        callback(obj[prop], prop, obj);\r\n    });\r\n    return obj;\r\n};\r\nmodule.exports = objectForeach;","/*\r\nLicense gpl-3.0 http://www.gnu.org/licenses/gpl-3.0-standalone.html\r\n*/\r\n/*jslint\r\n    white: true,\r\n    vars: true,\r\n    node: true\r\n*/\r\n/**\r\n * Merges JavaScript objects recursively without altering the objects merged.\r\n * @author <a href=\"mailto:matthewkastor@gmail.com\">Matthew Kastor</a>\r\n * @param {Object} shadows [[shadows]...] One or more objects to merge. Each\r\n *  argument given will be treated as an object to merge. Each object overwrites\r\n *  the previous objects descendant properties if the property name matches. If\r\n *  objects properties are objects they will be merged recursively as well.\r\n * @returns {Object} Returns a single merged object composed from clones of the\r\n *  input objects.\r\n * @example\r\n *  var objectMerge = require('object-merge');\r\n *  var x = {\r\n *      a : 'a',\r\n *      b : 'b',\r\n *      c : {\r\n *          d : 'd',\r\n *          e : 'e',\r\n *          f : {\r\n *              g : 'g'\r\n *          }\r\n *      }\r\n *  };\r\n *  var y = {\r\n *      a : '`a',\r\n *      b : '`b',\r\n *      c : {\r\n *          d : '`d'\r\n *      }\r\n *  };\r\n *  var z = {\r\n *      a : {\r\n *          b : '``b'\r\n *      },\r\n *      fun : function foo () {\r\n *          return 'foo';\r\n *      },\r\n *      aps : Array.prototype.slice\r\n *  };\r\n *  var out = objectMerge(x, y, z);\r\n *  // out.a will be {\r\n *  //         b : '``b'\r\n *  //     }\r\n *  // out.b will be '`b'\r\n *  // out.c will be {\r\n *  //         d : '`d',\r\n *  //         e : 'e',\r\n *  //         f : {\r\n *  //             g : 'g'\r\n *  //         }\r\n *  //     }\r\n *  // out.fun will be a clone of z.fun\r\n *  // out.aps will be equal to z.aps\r\n */\r\nfunction objectMerge(shadows) {\r\n    'use strict';\r\n    var objectForeach = require('object-foreach');\r\n    var cloneFunction = require('clone-function');\r\n    shadows = Array.prototype.slice.call(arguments, 0);\r\n    // gets the sequential trailing objects from array.\r\n    function getShadowObjects(shadows) {\r\n        var out = shadows.reduce(function (collector, shadow) {\r\n                if (shadow instanceof Object) {\r\n                    collector.push(shadow);\r\n                } else {\r\n                    collector = [];\r\n                }\r\n                return collector;\r\n            }, []);\r\n        return out;\r\n    }\r\n    // gets either a new object of the proper type or the last primitive value\r\n    function getOutputObject(shadows) {\r\n        var out;\r\n        var lastShadow = shadows[shadows.length - 1];\r\n        if (lastShadow instanceof Array) {\r\n            out = [];\r\n        } else if (lastShadow instanceof Function) {\r\n            try {\r\n                out = cloneFunction(lastShadow);\r\n            } catch (e) {\r\n                throw new Error(e.message);\r\n            }\r\n        } else if (lastShadow instanceof Object) {\r\n            out = {};\r\n        } else {\r\n            // lastShadow is a primitive value;\r\n            out = lastShadow;\r\n        }\r\n        return out;\r\n    }\r\n    function main(shadows) {\r\n        var out = getOutputObject(shadows);\r\n        function shadowHandler(val, prop, shadow) {\r\n            /*jslint unparam:true */\r\n            if (out[prop]) {\r\n                out[prop] = objectMerge(out[prop], shadow[prop]);\r\n            } else {\r\n                out[prop] = objectMerge(shadow[prop]);\r\n            }\r\n        }\r\n        function shadowMerger(shadow) {\r\n            objectForeach(shadow, shadowHandler);\r\n        }\r\n        // short circuits case where output would be a primitive value anyway.\r\n        if (out instanceof Object) {\r\n            // only merges trailing objects since primitives would wipe out previous\r\n            // objects, as in merging {a:'a'}, 'a', and {b:'b'} would result in\r\n            // {b:'b'} so the first two arguments can be ignored completely.\r\n            var relevantShadows = getShadowObjects(shadows);\r\n            relevantShadows.forEach(shadowMerger);\r\n        }\r\n        return out;\r\n    }\r\n    return main(shadows);\r\n}\r\nmodule.exports = objectMerge;"]}
//@ sourceMappingURL=data:application/json;base64,{"version":3,"file":"generated.js","sources":["C:/Users/kastor/Documents/GitHub/object-merge/dev/browserMain.js","C:/Users/kastor/Documents/GitHub/object-merge/node_modules/clone-function/src/clone-function.js","C:/Users/kastor/Documents/GitHub/object-merge/node_modules/object-foreach/src/object-foreach.js","C:/Users/kastor/Documents/GitHub/object-merge/src/object-merge.js"],"names":[],"mappings":";AAAA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourcesContent":["objectMerge = require('../src/object-merge.js');\r\n","/*\r\nLicense gpl-3.0 http://www.gnu.org/licenses/gpl-3.0-standalone.html\r\n*/\r\n/*jslint\r\n    evil: true,\r\n    node: true\r\n*/\r\n'use strict';\r\n/**\r\n * Clones non native JavaScript functions, or references native functions.\r\n * @author <a href=\"mailto:matthewkastor@gmail.com\">Matthew Kastor</a>\r\n * @param {Function} func The function to clone.\r\n * @returns {Function} Returns a clone of the non native function, or a\r\n *  reference to the native function.\r\n */\r\nfunction cloneFunction(func) {\r\n    var out, str;\r\n    try {\r\n        str = func.toString();\r\n        if (/\\[native code\\]/.test(str)) {\r\n            out = func;\r\n        } else {\r\n            out = eval('(function(){return ' + str + '}());');\r\n        }\r\n    } catch (e) {\r\n        throw new Error(e.message + '\\r\\n\\r\\n' + str);\r\n    }\r\n    return out;\r\n}\r\nmodule.exports = cloneFunction;","/**\r\n * Executes a function on each of an objects own enumerable properties. The\r\n *  callback function will receive three arguments: the value of the current\r\n *  property, the name of the property, and the object being processed. This is\r\n *  roughly equivalent to the signature for callbacks to\r\n *  Array.prototype.forEach.\r\n * @param {Object} obj The object to act on.\r\n * @param {Function} callback The function to execute.\r\n * @returns {Object} Returns the given object.\r\n */\r\nfunction objectForeach(obj, callback) {\r\n    \"use strict\";\r\n    Object.keys(obj).forEach(function (prop) {\r\n        callback(obj[prop], prop, obj);\r\n    });\r\n    return obj;\r\n};\r\nmodule.exports = objectForeach;","/*\r\nLicense gpl-3.0 http://www.gnu.org/licenses/gpl-3.0-standalone.html\r\n*/\r\n/*jslint\r\n    white: true,\r\n    vars: true,\r\n    node: true\r\n*/\r\n/**\r\n * Merges JavaScript objects recursively without altering the objects merged.\r\n * @author <a href=\"mailto:matthewkastor@gmail.com\">Matthew Kastor</a>\r\n * @param {Object} shadows [[shadows]...] One or more objects to merge. Each\r\n *  argument given will be treated as an object to merge. Each object overwrites\r\n *  the previous objects descendant properties if the property name matches. If\r\n *  objects properties are objects they will be merged recursively as well.\r\n * @returns {Object} Returns a single merged object composed from clones of the\r\n *  input objects.\r\n * @example\r\n *  var objectMerge = require('object-merge');\r\n *  var x = {\r\n *      a : 'a',\r\n *      b : 'b',\r\n *      c : {\r\n *          d : 'd',\r\n *          e : 'e',\r\n *          f : {\r\n *              g : 'g'\r\n *          }\r\n *      }\r\n *  };\r\n *  var y = {\r\n *      a : '`a',\r\n *      b : '`b',\r\n *      c : {\r\n *          d : '`d'\r\n *      }\r\n *  };\r\n *  var z = {\r\n *      a : {\r\n *          b : '``b'\r\n *      },\r\n *      fun : function foo () {\r\n *          return 'foo';\r\n *      },\r\n *      aps : Array.prototype.slice\r\n *  };\r\n *  var out = objectMerge(x, y, z);\r\n *  // out.a will be {\r\n *  //         b : '``b'\r\n *  //     }\r\n *  // out.b will be '`b'\r\n *  // out.c will be {\r\n *  //         d : '`d',\r\n *  //         e : 'e',\r\n *  //         f : {\r\n *  //             g : 'g'\r\n *  //         }\r\n *  //     }\r\n *  // out.fun will be a clone of z.fun\r\n *  // out.aps will be equal to z.aps\r\n */\r\nfunction objectMerge(shadows) {\r\n    'use strict';\r\n    var objectForeach = require('object-foreach');\r\n    var cloneFunction = require('clone-function');\r\n    shadows = Array.prototype.slice.call(arguments, 0);\r\n    // gets the sequential trailing objects from array.\r\n    function getShadowObjects(shadows) {\r\n        var out = shadows.reduce(function (collector, shadow) {\r\n                if (shadow instanceof Object) {\r\n                    collector.push(shadow);\r\n                } else {\r\n                    collector = [];\r\n                }\r\n                return collector;\r\n            }, []);\r\n        return out;\r\n    }\r\n    // gets either a new object of the proper type or the last primitive value\r\n    function getOutputObject(shadows) {\r\n        var out;\r\n        var lastShadow = shadows[shadows.length - 1];\r\n        if (lastShadow instanceof Array) {\r\n            out = [];\r\n        } else if (lastShadow instanceof Function) {\r\n            try {\r\n                out = cloneFunction(lastShadow);\r\n            } catch (e) {\r\n                throw new Error(e.message);\r\n            }\r\n        } else if (lastShadow instanceof Object) {\r\n            out = {};\r\n        } else {\r\n            // lastShadow is a primitive value;\r\n            out = lastShadow;\r\n        }\r\n        return out;\r\n    }\r\n    // this is the queue of visited objects / properties.\r\n    var visited = [];\r\n    function objectMergeRecursor(shadows) {\r\n        // if any of the current objects to process exist in the queue\r\n        // then throw an error.\r\n        shadows.forEach(function (item) {\r\n            if (item instanceof Object && visited.indexOf(item) > -1) {\r\n                throw new Error('Circular reference error');\r\n            }\r\n        });\r\n        // if none of the current objects were in the queue then add references\r\n        // to the queue.\r\n        visited = visited.concat(shadows);\r\n        function main(shadows) {\r\n            var out = getOutputObject(shadows);\r\n            /*jslint unparam:true */\r\n            function shadowHandler(val, prop, shadow) {\r\n                if (out[prop]) {\r\n                    out[prop] = objectMergeRecursor([\r\n                        out[prop],\r\n                        shadow[prop]\r\n                    ]);\r\n                } else {\r\n                    out[prop] = objectMergeRecursor([shadow[prop]]);\r\n                }\r\n            }\r\n            /*jslint unparam:false */\r\n            function shadowMerger(shadow) {\r\n                objectForeach(shadow, shadowHandler);\r\n            }\r\n            // short circuits case where output would be a primitive value\r\n            // anyway.\r\n            if (out instanceof Object) {\r\n                // only merges trailing objects since primitives would wipe out\r\n                // previous objects, as in merging {a:'a'}, 'a', and {b:'b'}\r\n                // would result in {b:'b'} so the first two arguments\r\n                // can be ignored completely.\r\n                var relevantShadows = getShadowObjects(shadows);\r\n                relevantShadows.forEach(shadowMerger);\r\n            }\r\n            return out;\r\n        }\r\n        return main(shadows);\r\n    }\r\n    return objectMergeRecursor(shadows);\r\n}\r\nmodule.exports = objectMerge;"]}

@@ -149,2 +149,87 @@ /*

});
it('throws an error on circular references to functions', function () {
var x = {
'a' : function () {return null},
};
x.b = x.a;
function thrower () {
return objectMerge(x);
}
expect(thrower).toThrow();
});
it('throws an error on circular references to arrays', function () {
var x = {
'a' : [],
};
x.b = x.a;
function thrower () {
return objectMerge(x);
}
expect(thrower).toThrow();
});
it('throws an error on circular references to objects', function () {
var x = {
'a' : {}
};
x.b = x.a;
function thrower () {
return objectMerge(x);
}
expect(thrower).toThrow();
});
it('throws an error on circular references to nested objects', function () {
var x = {
'a' : {}
};
x.b = {};
x.b.c = x.a;
function thrower () {
return objectMerge(x);
}
expect(thrower).toThrow();
});
it('throws an error on circular references to string objects', function () {
var x = {
'a' : new String(),
};
x.b = x.a;
function thrower () {
return objectMerge(x);
}
expect(thrower).toThrow();
});
it('throws an error on circular references to number objects', function () {
var x = {
'a' : new Number(),
};
x.b = x.a;
function thrower () {
return objectMerge(x);
}
expect(thrower).toThrow();
});
it('does not throw an error on circular references to scalar string',
function () {
var x = {
'a' : 'x',
};
x.b = x.a;
function thrower () {
return objectMerge(x);
}
expect(thrower).not.toThrow();
}
);
it('does not throw an error on circular references to scalar number',
function () {
var x = {
'a' : 5,
};
x.b = x.a;
function thrower () {
return objectMerge(x);
}
expect(thrower).not.toThrow();
}
);
});
{
"name": "object-merge",
"version": "2.2.3",
"version": "2.3.0",
"description": "Merges JavaScript objects recursively without altering the objects merged.",

@@ -5,0 +5,0 @@ "main": "./src/object-merge.js",

@@ -99,27 +99,48 @@ /*

}
function main(shadows) {
var out = getOutputObject(shadows);
function shadowHandler(val, prop, shadow) {
// this is the queue of visited objects / properties.
var visited = [];
function objectMergeRecursor(shadows) {
// if any of the current objects to process exist in the queue
// then throw an error.
shadows.forEach(function (item) {
if (item instanceof Object && visited.indexOf(item) > -1) {
throw new Error('Circular reference error');
}
});
// if none of the current objects were in the queue then add references
// to the queue.
visited = visited.concat(shadows);
function main(shadows) {
var out = getOutputObject(shadows);
/*jslint unparam:true */
if (out[prop]) {
out[prop] = objectMerge(out[prop], shadow[prop]);
} else {
out[prop] = objectMerge(shadow[prop]);
function shadowHandler(val, prop, shadow) {
if (out[prop]) {
out[prop] = objectMergeRecursor([
out[prop],
shadow[prop]
]);
} else {
out[prop] = objectMergeRecursor([shadow[prop]]);
}
}
/*jslint unparam:false */
function shadowMerger(shadow) {
objectForeach(shadow, shadowHandler);
}
// short circuits case where output would be a primitive value
// anyway.
if (out instanceof Object) {
// only merges trailing objects since primitives would wipe out
// previous objects, as in merging {a:'a'}, 'a', and {b:'b'}
// would result in {b:'b'} so the first two arguments
// can be ignored completely.
var relevantShadows = getShadowObjects(shadows);
relevantShadows.forEach(shadowMerger);
}
return out;
}
function shadowMerger(shadow) {
objectForeach(shadow, shadowHandler);
}
// short circuits case where output would be a primitive value anyway.
if (out instanceof Object) {
// only merges trailing objects since primitives would wipe out previous
// objects, as in merging {a:'a'}, 'a', and {b:'b'} would result in
// {b:'b'} so the first two arguments can be ignored completely.
var relevantShadows = getShadowObjects(shadows);
relevantShadows.forEach(shadowMerger);
}
return out;
return main(shadows);
}
return main(shadows);
return objectMergeRecursor(shadows);
}
module.exports = objectMerge;

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc