diff --git a/dist/Shield.js b/dist/Shield.js index 4fdb6bc..992d710 100644 --- a/dist/Shield.js +++ b/dist/Shield.js @@ -6,7 +6,7 @@ class Shield { static traverse(obj, opts) { let error; for (const k in obj) { - if (opts.mongo && Utils_1.default.isString(k) && k.indexOf('$') === 0) { + if (opts.mongo && Utils_1.default.isString(k) && k.indexOf('$') === 0 && k.length > 1) { error = new ShieldError_1.default('Mongo $ injection found', 'mongo_error', obj); break; } diff --git a/src/Shield.ts b/src/Shield.ts index 61c91bf..04d7068 100644 --- a/src/Shield.ts +++ b/src/Shield.ts @@ -10,7 +10,7 @@ export class Shield { private static traverse(obj: any, opts: ShieldOptions): ShieldError | undefined { let error; for (const k in obj) { - if (opts.mongo && Utils.isString(k) && k.indexOf('$') === 0) { + if (opts.mongo && Utils.isString(k) && k.indexOf('$') === 0 && k.length > 1) { error = new ShieldError('Mongo $ injection found', 'mongo_error', obj); break; } diff --git a/test/Shield.test.ts b/test/Shield.test.ts index 29ffbde..98ac156 100644 --- a/test/Shield.test.ts +++ b/test/Shield.test.ts @@ -130,6 +130,17 @@ describe('Shield', () => { }); }); + it('should not block "$" attribute', (done) => { + const payload = { + $: { + id: 1, + }, + }; + shield.evaluate(payload, { + mongo: true, + }, done); + }); + it('should not block __proto__ object', (done) => { const payload = JSON.parse('{ "__proto__": { "admin": true } }'); shield.evaluate(payload, {