Skip to content

Commit

Permalink
Merge pull request #12 from ohad2712/fix/address-prototype-pollution-…
Browse files Browse the repository at this point in the history
…vulnerablity-in-merge-function

fix: Address prototype pollution vulnerability in merge function
  • Loading branch information
Swaagie authored Jan 30, 2022
2 parents 238137e + 045c1c7 commit 1a86a01
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 1 deletion.
2 changes: 1 addition & 1 deletion index.js
Original file line number Diff line number Diff line change
Expand Up @@ -282,7 +282,7 @@ function merge(target, additional) {
each(additional, function objectForEach(key, value) {
if (target[key] === undefined) {
result[key] = value;
} else {
} else if (has.call(target, key)) {
result[key] = merge(target[key], additional[key]);
}
});
Expand Down
8 changes: 8 additions & 0 deletions test.js
Original file line number Diff line number Diff line change
Expand Up @@ -181,4 +181,12 @@ describe('predefine', function () {
assume(calls).to.equal(1);
});
});

describe('.merge', function () {
it('avoids prototype polluting', function () {
predefine.merge({}, JSON.parse('{"__proto__": {"a": "b"}}'));

assume(({}).a).to.be.undefined();
});
});
});

0 comments on commit 1a86a01

Please sign in to comment.