Skip to content

Commit

Permalink
Merge branch 'master' into netlify-functions-example
Browse files Browse the repository at this point in the history
  • Loading branch information
vkarpov15 committed Jul 20, 2022
2 parents 2e6b064 + 92cb6fb commit eced2c7
Show file tree
Hide file tree
Showing 13 changed files with 115 additions and 30 deletions.
15 changes: 15 additions & 0 deletions CHANGELOG.md
@@ -1,3 +1,18 @@
6.4.5 / 2022-07-18
==================
* fix(model+timestamps): set timestamps on subdocuments in insertMany() #12060
* fix: correct isAtlas check #12110 [skrtheboss](https://github.com/skrtheboss)
* fix(types): fix various issues with auto typed schemas #12042 [mohammad0-0ahmad](https://github.com/mohammad0-0ahmad)
* fix(types): allow any value for AddFields #12096
* fix(types): allow arbitrary expressions for ConcatArrays #12058
* fix(types): make $addToSet fields mutable to allow programatically constructing $addToSet #12091
* fix(types): add $let as a possible expression to $addFields #12087 [AbdelrahmanHafez](https://github.com/AbdelrahmanHafez)
* fix(types): fix $switch expression type #12088 [AbdelrahmanHafez](https://github.com/AbdelrahmanHafez)
* fix(types): correct options type for syncIndexes() #12101 [lpizzinidev](https://github.com/lpizzinidev)
* fix(types): avoid treating | undefined types as any in `Require_id` to better support `_id: String` with auto-typed schemas #12070
* docs: fix up various jsdoc issues #12086 [hasezoey](https://github.com/hasezoey)
* docs: add sanitizeFilter to mongoose.set() options #12112 [pathei-kosmos](https://github.com/pathei-kosmos)

6.4.4 / 2022-07-08
==================
* fix(types): allow using an object to configure timestamps #12061 [lantw44](https://github.com/lantw44)
Expand Down
4 changes: 2 additions & 2 deletions docs/migrating_to_6.md
Expand Up @@ -194,8 +194,8 @@ mongoose.isValidObjectId(new User({ name: 'test' })); // true
// character hex strings.
mongoose.isObjectIdOrHexString(new mongoose.Types.ObjectId()); // true
mongoose.isObjectIdOrHexString('62261a65d66c6be0a63c051f'); // true
mongoose.isValidObjectId('0123456789ab'); // false
mongoose.isValidObjectId(6); // false
mongoose.isObjectIdOrHexString('0123456789ab'); // false
mongoose.isObjectIdOrHexString(6); // false
```

<h3 id="schema-defined-document-key-order"><a href="#schema-defined-document-key-order">Schema Defined Document Key Order</a></h3>
Expand Down
2 changes: 1 addition & 1 deletion lib/document.js
Expand Up @@ -1149,8 +1149,8 @@ Document.prototype.$set = function $set(path, val, type, options) {
}

if (utils.isNonBuiltinObject(valForKey) && pathtype === 'nested') {
$applyDefaultsToNested(path[key], prefix + key, this);
this.$set(prefix + key, path[key], constructing, Object.assign({}, options, { _skipMarkModified: true }));
$applyDefaultsToNested(this.$get(prefix + key), prefix + key, this);
continue;
} else if (strict) {
// Don't overwrite defaults with undefined keys (gh-3981) (gh-9039)
Expand Down
10 changes: 8 additions & 2 deletions lib/query.js
Expand Up @@ -4019,7 +4019,9 @@ Query.prototype._findAndModify = function(type, callback) {
*/

function _completeOneLean(schema, doc, path, res, opts, callback) {
if (opts.lean && opts.lean.transform) {
if (opts.lean && typeof opts.lean.transform === 'function') {
opts.lean.transform(doc);

for (let i = 0; i < schema.childSchemas.length; i++) {
const childPath = path ? path + '.' + schema.childSchemas[i].model.path : schema.childSchemas[i].model.path;
const _schema = schema.childSchemas[i].schema;
Expand Down Expand Up @@ -4053,7 +4055,11 @@ function _completeOneLean(schema, doc, path, res, opts, callback) {
*/

function _completeManyLean(schema, docs, path, opts, callback) {
if (opts.lean && opts.lean.transform) {
if (opts.lean && typeof opts.lean.transform === 'function') {
for (const doc of docs) {
opts.lean.transform(doc);
}

for (let i = 0; i < schema.childSchemas.length; i++) {
const childPath = path ? path + '.' + schema.childSchemas[i].model.path : schema.childSchemas[i].model.path;
const _schema = schema.childSchemas[i].schema;
Expand Down
7 changes: 7 additions & 0 deletions lib/schema.js
Expand Up @@ -554,6 +554,10 @@ Schema.prototype.add = function add(obj, prefix) {
const keys = Object.keys(obj);
const typeKey = this.options.typeKey;
for (const key of keys) {
if (utils.specialProperties.has(key)) {
continue;
}

const fullPath = prefix + key;
const val = obj[key];

Expand Down Expand Up @@ -854,6 +858,9 @@ Schema.prototype.path = function(path, obj) {
let fullPath = '';

for (const sub of subpaths) {
if (utils.specialProperties.has(sub)) {
throw new Error('Cannot set special property `' + sub + '` on a schema');
}
fullPath = fullPath += (fullPath.length > 0 ? '.' : '') + sub;
if (!branch[sub]) {
this.nested[fullPath] = true;
Expand Down
4 changes: 2 additions & 2 deletions package.json
@@ -1,7 +1,7 @@
{
"name": "mongoose",
"description": "Mongoose MongoDB ODM",
"version": "6.4.4",
"version": "6.4.5",
"author": "Guillermo Rauch <guillermo@learnboost.com>",
"keywords": [
"mongodb",
Expand All @@ -21,7 +21,7 @@
"dependencies": {
"bson": "^4.6.2",
"kareem": "2.4.1",
"mongodb": "4.8.0",
"mongodb": "4.7.0",
"mpath": "0.9.0",
"mquery": "4.0.3",
"ms": "2.1.3",
Expand Down
8 changes: 5 additions & 3 deletions test/document.test.js
Expand Up @@ -8831,7 +8831,7 @@ describe('document', function() {
assert.ok(!user.updatedAt);
});

it('Sets default when passing undefined as value for a key in a nested subdoc (gh-9039)', async function() {
it('Sets default when passing undefined as value for a key in a nested subdoc (gh-12102) (gh-9039)', async function() {
const Test = db.model('Test', {
nested: {
prop: {
Expand All @@ -8841,9 +8841,11 @@ describe('document', function() {
}
});


const doc = await Test.create({ nested: { prop: undefined } });
const obj = { nested: { prop: undefined } };
const doc = await Test.create(obj);
assert.equal(doc.nested.prop, 'some default value');

assert.deepStrictEqual(obj, { nested: { prop: undefined } });
});

it('allows accessing $locals when initializing (gh-9098)', function() {
Expand Down
38 changes: 22 additions & 16 deletions test/query.test.js
Expand Up @@ -4006,22 +4006,28 @@ describe('Query', function() {
});
const Test = db.model('gh10423', testSchema);
await Test.create({ name: 'foo', foo: [{ sub: 'Test' }, { sub: 'Testerson' }], otherName: { nickName: 'Bar' } });
const result = await Test.find().lean({ transform: (doc) => {
delete doc._id;
return doc;
} });
assert(result[0]._id);
assert.equal(result[0].otherName._id, undefined);
assert.equal(result[0].foo[0]._id, undefined);
assert.equal(result[0].foo[1]._id, undefined);
const single = await Test.findOne().lean({ transform: (doc) => {
delete doc._id;
return doc;
} });
assert(single._id);
assert.equal(single.otherName._id, undefined);
assert.equal(single.foo[0]._id, undefined);
assert.equal(single.foo[0]._id, undefined);

const result = await Test.find().lean({
transform: (doc) => {
delete doc._id;
return doc;
}
});
assert.strictEqual(result[0]._id, undefined);
assert.strictEqual(result[0].otherName._id, undefined);
assert.strictEqual(result[0].foo[0]._id, undefined);
assert.strictEqual(result[0].foo[1]._id, undefined);

const single = await Test.findOne().lean({
transform: (doc) => {
delete doc._id;
return doc;
}
});
assert.strictEqual(single._id, undefined);
assert.strictEqual(single.otherName._id, undefined);
assert.strictEqual(single.foo[0]._id, undefined);
assert.strictEqual(single.foo[0]._id, undefined);
});

it('skips applying default projections over slice projections (gh-11940)', async function() {
Expand Down
23 changes: 23 additions & 0 deletions test/schema.test.js
Expand Up @@ -924,6 +924,19 @@ describe('schema', function() {

assert.equal(called, true);
});

it('options param (gh-12077)', function() {
const Tobi = new Schema();
let called = false;

Tobi.plugin(function(schema, opts) {
assert.equal(schema, Tobi);
assert.deepStrictEqual(opts, { answer: 42 });
called = true;
}, { answer: 42 });

assert.equal(called, true);
});
});

describe('options', function() {
Expand Down Expand Up @@ -2792,4 +2805,14 @@ describe('schema', function() {
});
}, /Cannot use schema-level projections.*subdocument_mapping.not_selected/);
});

it('disallows setting special properties with `add()` or constructor (gh-12085)', async function() {
const maliciousPayload = '{"__proto__.toString": "Number"}';

assert.throws(() => {
mongoose.Schema(JSON.parse(maliciousPayload));
}, /__proto__/);

assert.ok({}.toString());
});
});
8 changes: 8 additions & 0 deletions test/types/PipelineStage.test.ts
Expand Up @@ -415,3 +415,11 @@ const stages4: PipelineStage[] = [
}
}
];

(function gh12096() {
const data: PipelineStage.AddFields = {
$addFields: {
name: { $meta: 'Bill' }
}
};
})();
14 changes: 14 additions & 0 deletions test/types/queries.test.ts
Expand Up @@ -325,5 +325,19 @@ function gh11964() {
/* ... */
}
}
}

function gh12091() {
interface IUser{
friendsNames: string[];
}
const userSchema = new Schema<IUser>({
friendsNames: [String]
});

const update: UpdateQuery<IUser> = { $addToSet: { friendsNames: 'John Doe' } };
if (!update?.$addToSet) {
return;
}
update.$addToSet.friendsNames = 'Jane Doe';
}
2 changes: 1 addition & 1 deletion types/expressions.d.ts
Expand Up @@ -2449,7 +2449,7 @@ declare module 'mongoose' {
FunctionExpression |
ObjectIdExpression |
ConditionalExpressionOperator |
Expression.Let;
any;

export type ObjectIdExpression =
TypeExpressionOperatorReturningObjectId;
Expand Down
10 changes: 7 additions & 3 deletions types/index.d.ts
Expand Up @@ -437,6 +437,10 @@ declare module 'mongoose' {

export type SortOrder = -1 | 1 | 'asc' | 'ascending' | 'desc' | 'descending';

type Mutable<T> = {
-readonly [K in keyof T]: T[K];
};

type _UpdateQuery<TSchema> = {
/** @see https://docs.mongodb.com/manual/reference/operator/update-field/ */
$currentDate?: AnyKeys<TSchema> & AnyObject;
Expand All @@ -450,10 +454,10 @@ declare module 'mongoose' {
$unset?: AnyKeys<TSchema> & AnyObject;

/** @see https://docs.mongodb.com/manual/reference/operator/update-array/ */
$addToSet?: mongodb.SetFields<TSchema>;
$addToSet?: Mutable<mongodb.SetFields<TSchema>>;
$pop?: AnyKeys<TSchema> & AnyObject;
$pull?: mongodb.PullOperator<TSchema>;
$push?: mongodb.PushOperator<TSchema>;
$pull?: Mutable<mongodb.PullOperator<TSchema>>;
$push?: Mutable<mongodb.PushOperator<TSchema>>;
$pullAll?: mongodb.PullAllOperator<TSchema>;

/** @see https://docs.mongodb.com/manual/reference/operator/update-bitwise/ */
Expand Down

0 comments on commit eced2c7

Please sign in to comment.