let Sequelize = require('sequelize'); let db = syzoj.db; let User = syzoj.model('user'); let Article = syzoj.model('article'); let model = db.define('comment', { id: { type: Sequelize.INTEGER, primaryKey: true, autoIncrement: true }, content: { type: Sequelize.TEXT }, article_id: { type: Sequelize.INTEGER }, user_id: { type: Sequelize.INTEGER }, public_time: { type: Sequelize.INTEGER } }, { timestamps: false, tableName: 'comment', indexes: [ { fields: ['article_id'] }, { fields: ['user_id'] } ] }); let Model = require('./common'); class ArticleComment extends Model { static async create(val) { return ArticleComment.fromRecord(ArticleComment.model.build(Object.assign({ content: '', article_id: 0, user_id: 0, public_time: 0, }, val))); } async loadRelationships() { this.user = await User.fromID(this.user_id); this.article = await Article.fromID(this.article_id); } async isAllowedEditBy(user) { await this.loadRelationships(); return user && (user.is_admin || this.user_id === user.id || user.id === this.article.user_id); } getModel() { return model; } }; ArticleComment.model = model; module.exports = ArticleComment;