Je souhaite utiliser la validation personnalisée mangouste pour valider si endDate est supérieur à startDate. Comment accéder à la valeur startDate? Lorsque vous utilisez this.startDate, cela ne fonctionne pas; Je suis indéfini.
var a = new Schema({
startDate: Date,
endDate: Date
});
var A = mongoose.model('A', a);
A.schema.path('endDate').validate(function (value) {
return diff(this.startDate, value) >= 0;
}, 'End Date must be greater than Start Date');
diff
est une fonction qui compare deux dates.
Vous pouvez essayer d'imbriquer vos horodatages dans un objet parent, puis valider le parent. Par exemple quelque chose comme:
//create a simple object defining your dates
var dateStampSchema = {
startDate: {type:Date},
endDate: {type:Date}
};
//validation function
function checkDates(value) {
return value.endDate < value.startDate;
}
//now pass in the dateStampSchema object as the type for a schema field
var schema = new Schema({
dateInfo: {type:dateStampSchema, validate:checkDates}
});
Vous pouvez le faire en utilisant Mongoose 'validate'
middleware pour que vous ayez accès à tous les champs:
ASchema.pre('validate', function(next) {
if (this.startDate > this.endDate) {
next(new Error('End Date must be greater than Start Date'));
} else {
next();
}
});
Notez que vous devez encapsuler votre message d'erreur de validation dans un objet JavaScript Error
lors de l'appel de next
pour signaler un échec de validation.
Une alternative à la réponse acceptée pour la question d'origine est:
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
// schema definition
var ASchema = new Schema({
startDate: {
type: Date,
required: true
},
endDate: {
type: Date,
required: true,
validate: [dateValidator, 'Start Date must be less than End Date']
}
});
// function that validate the startDate and endDate
function dateValidator(value) {
// `this` is the mongoose document
return this.startDate <= value;
}
Je voulais développer la réponse solide de @JohnnyHK (merci) en puisant dans this.invalidate:
Schema.pre('validate', function (next) {
if (this.startDate > this.endDate) {
this.invalidate('startDate', 'Start date must be less than end date.', this.startDate);
}
next();
});
Cela conserve toutes les erreurs de validation à l'intérieur d'une erreur mongoose.Error.ValidationError. Aide à garder les gestionnaires d'erreurs standardisés. J'espère que cela t'aides.
L'utilisation de "ceci" dans le validateur fonctionne pour moi - dans ce cas, lors de la vérification de l'unicité de l'adresse e-mail, j'ai besoin d'accéder à l'ID de l'objet actuel afin de pouvoir l'exclure du décompte:
var userSchema = new mongoose.Schema({
id: String,
name: { type: String, required: true},
email: {
type: String,
index: {
unique: true, dropDups: true
},
validate: [
{ validator: validator.isEmail, msg: 'invalid email address'},
{ validator: isEmailUnique, msg: 'Email already exists'}
]},
facebookId: String,
googleId: String,
admin: Boolean
});
function isEmailUnique(value, done) {
if (value) {
mongoose.models['users'].count({ _id: {'$ne': this._id }, email: value }, function (err, count) {
if (err) {
return done(err);
}
// If `count` is greater than zero, "invalidate"
done(!count);
});
}
}
Voici la solution que j'ai utilisée (merci à @shakinfree pour l'astuce):
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
// schema definition
var ASchema = new Schema({
dateSchema : {
type:{
startDate:{type:Date, required: true},
endDate:{type:Date, required: true}
},
required: true,
validate: [dateValidator, 'Start Date must be less than End Date']
}
});
// function that validate the startDate and endDate
function dateValidator (value) {
return value.startDate <= value.endDate;
}
module.exports = mongoose.model('A', ASchema);