66 lines
1.3 KiB
JavaScript
66 lines
1.3 KiB
JavaScript
const { Model, DataTypes } = require('sequelize');
|
|
|
|
class Article extends Model {
|
|
|
|
}
|
|
|
|
Article.structure = {
|
|
id: {
|
|
type: DataTypes.BIGINT(11),
|
|
primaryKey: true,
|
|
autoIncrement: true,
|
|
allowNull: false
|
|
},
|
|
title: {
|
|
type: DataTypes.TEXT,
|
|
allowNull: false
|
|
},
|
|
shortText: {
|
|
type: DataTypes.TEXT,
|
|
allowNull: false
|
|
},
|
|
body: {
|
|
type: DataTypes.TEXT,
|
|
allowNull: false
|
|
},
|
|
submitted: {
|
|
type: DataTypes.BIGINT,
|
|
allowNull: false
|
|
},
|
|
edited: {
|
|
type: DataTypes.BIGINT,
|
|
allowNull: false
|
|
},
|
|
submitter: {
|
|
type: DataTypes.BIGINT,
|
|
allowNull: false
|
|
},
|
|
gpgsign: {
|
|
type: DataTypes.TEXT,
|
|
allowNull: true
|
|
},
|
|
hidden: {
|
|
type: DataTypes.BOOLEAN,
|
|
allowNull: false,
|
|
defaultValue: false
|
|
}
|
|
};
|
|
|
|
/**
|
|
* @param {import('sequelize').Sequelize} sequelize
|
|
* @param {import('sequelize').DataTypes} DataTypes
|
|
* @returns Article
|
|
*/
|
|
let init = (sequelize, DataTypes) => {
|
|
let article = Article.init(Article.structure, {
|
|
sequelize,
|
|
modelName: 'Article',
|
|
tableName: 'articles'
|
|
})
|
|
article.class = Article;
|
|
|
|
return article;
|
|
}
|
|
|
|
init.class = Article;
|
|
module.exports = init; |