const mongoose = require('mongoose'); //pour vérifier la validité d'une adresse mail const { isEmail } = require('validator'); const bcrypt = require('bcrypt'); const NotifSchema = new mongoose.Schema({ typeNotif: { type: String, required: true }, id_user: { type: String, required: true }, id_post1: { type: String, required: true }, id_post2: { type: String, required: true } }); const PictureSchema = new mongoose.Schema({ data: { type: String, required: true, }, contentType: { type: String, required: true, } }); //trim pour supprimer les espaces const userSchema = new mongoose.Schema( { pseudo: { type: String, required: true, minLength: 3, maxLength: 55, unique: true, trim: true }, email: { type: String, required: true, validate: [isEmail], lowercase: true, unique: true, trim: true }, password: { type: String, required: true, max: 1024, minlength: 6 }, picture: { type: PictureSchema, default: { data: "", contentType: "image/png" } }, bio :{ type: String, max: 1024, }, followers: { type: [String] }, following: { type: [String] }, likes: { type: [String] }, notif: [NotifSchema] }, { timestamps: true, } ); //timestamps pour savoir quand l'utilisateur c'est connecté // play function before save into display: 'block', userSchema.pre("save", async function(next) { const salt = await bcrypt.genSalt(); this.password = await bcrypt.hash(this.password, salt); next(); }); userSchema.statics.login = async function({email, password}) { const user = await this.findOne( {email} ); if (user) { const auth = await bcrypt.compare(password, user.password); if (auth) { return user; } throw Error('incorrect password'); } throw Error('incorrect email') }; const UserModel = mongoose.model("user", userSchema); module.exports = UserModel;