diff --git a/server/src/models/User.ts b/server/src/models/User.ts index 82909785..8e944e2c 100644 --- a/server/src/models/User.ts +++ b/server/src/models/User.ts @@ -3,56 +3,56 @@ import bcrypt from 'bcrypt'; import sequelize from '../db/config'; interface UserAttributes { - id: number; - email: string; - password: string; + id: number; + email: string; + password: string; } // Optional fields for creating a new user -interface UserCreationAttributes extends Optional {} +interface UserCreationAttributes extends Optional { } class User extends Model implements UserAttributes { - public id!: number; - public email!: string; - public password!: string; + public id!: number; + public email!: string; + public password!: string; - public async isValidPassword(password: string): Promise { - return bcrypt.compare(password, this.password); - } + public async isValidPassword(password: string): Promise { + return bcrypt.compare(password, this.password); + } } User.init( - { - id: { - type: DataTypes.INTEGER.UNSIGNED, - autoIncrement: true, - primaryKey: true, + { + id: { + type: DataTypes.INTEGER.UNSIGNED, + autoIncrement: true, + primaryKey: true, + }, + email: { + type: DataTypes.STRING, + allowNull: false, + unique: true, + validate: { + isEmail: true, + }, + }, + password: { + type: DataTypes.STRING, + allowNull: false, + }, }, - email: { - type: DataTypes.STRING, - allowNull: false, - unique: true, - validate: { - isEmail: true, - }, - }, - password: { - type: DataTypes.STRING, - allowNull: false, - }, - }, - { - sequelize, - tableName: 'user', - hooks: { - beforeCreate: async (user: User) => { - if (user.password) { - const salt = await bcrypt.genSalt(10); - user.password = await bcrypt.hash(user.password, salt); - } - }, - }, - } + { + sequelize, + tableName: 'user', + hooks: { + beforeCreate: async (user: User) => { + if (user.password) { + const salt = await bcrypt.genSalt(10); + user.password = await bcrypt.hash(user.password, salt); + } + }, + }, + } ); export default User;