2024-06-06 12:30:46 +00:00
|
|
|
'use strict';
|
|
|
|
const {
|
|
|
|
Model
|
|
|
|
} = require('sequelize');
|
|
|
|
|
|
|
|
module.exports = (sequelize, DataTypes) => {
|
|
|
|
class article extends Model {
|
|
|
|
static associate(models) {
|
2024-06-06 17:41:23 +00:00
|
|
|
article.belongsTo(models.user, {
|
|
|
|
foreignKey: 'submittedBy',
|
2024-06-06 12:30:46 +00:00
|
|
|
onDelete: 'SET NULL',
|
|
|
|
onUpdate: 'CASCADE',
|
|
|
|
as: 'submitter',
|
|
|
|
})
|
2024-06-06 17:41:23 +00:00
|
|
|
article.belongsTo(models.user, {
|
2024-06-06 12:30:46 +00:00
|
|
|
as: 'reviewer',
|
2024-06-06 17:41:23 +00:00
|
|
|
foreignKey: 'reviewedBy',
|
2024-06-06 12:30:46 +00:00
|
|
|
onDelete: 'SET NULL',
|
|
|
|
onUpdate: 'CASCADE',
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
article.init({
|
|
|
|
title: DataTypes.STRING,
|
|
|
|
content: DataTypes.STRING,
|
|
|
|
submittedBy: DataTypes.STRING,
|
|
|
|
reviewedBy: DataTypes.STRING
|
|
|
|
}, {
|
|
|
|
sequelize,
|
|
|
|
modelName: 'article',
|
2024-06-06 17:41:23 +00:00
|
|
|
tableName: 'articles',
|
2024-06-06 12:30:46 +00:00
|
|
|
});
|
|
|
|
return article;
|
|
|
|
};
|