2017-06-21 23:33:03 -07:00
|
|
|
module.exports = (sequelize, { STRING, BOOLEAN, INTEGER }) => {
|
2017-06-17 22:51:30 +02:00
|
|
|
const File = sequelize.define(
|
|
|
|
'File',
|
|
|
|
{
|
|
|
|
name: {
|
|
|
|
type : STRING,
|
|
|
|
allowNull: false,
|
|
|
|
},
|
2017-06-19 15:25:14 -07:00
|
|
|
claimId: {
|
2017-06-17 22:51:30 +02:00
|
|
|
type : STRING,
|
|
|
|
allowNull: false,
|
|
|
|
},
|
2017-07-03 18:27:35 -07:00
|
|
|
address: {
|
|
|
|
type : STRING,
|
|
|
|
allowNull: false,
|
|
|
|
},
|
2017-06-17 22:51:30 +02:00
|
|
|
outpoint: {
|
|
|
|
type : STRING,
|
|
|
|
allowNull: false,
|
|
|
|
},
|
2017-06-21 23:33:03 -07:00
|
|
|
height: {
|
|
|
|
type : INTEGER,
|
|
|
|
allowNull: false,
|
|
|
|
default : 0,
|
|
|
|
},
|
2017-06-19 15:25:14 -07:00
|
|
|
fileName: {
|
2017-06-17 22:51:30 +02:00
|
|
|
type : STRING,
|
|
|
|
allowNull: false,
|
|
|
|
},
|
2017-06-19 15:25:14 -07:00
|
|
|
filePath: {
|
2017-06-17 22:51:30 +02:00
|
|
|
type : STRING,
|
|
|
|
allowNull: false,
|
|
|
|
},
|
2017-06-19 15:25:14 -07:00
|
|
|
fileType: {
|
2017-06-17 22:51:30 +02:00
|
|
|
type: STRING,
|
|
|
|
},
|
|
|
|
nsfw: {
|
|
|
|
type : BOOLEAN,
|
|
|
|
allowNull : false,
|
|
|
|
defaultValue: false,
|
|
|
|
},
|
2017-07-26 16:24:50 -07:00
|
|
|
trendingEligible: {
|
|
|
|
type : BOOLEAN,
|
|
|
|
allowNull : false,
|
|
|
|
defaultValue: true,
|
|
|
|
},
|
2017-06-17 22:51:30 +02:00
|
|
|
},
|
|
|
|
{
|
|
|
|
freezeTableName: true,
|
|
|
|
}
|
2017-06-19 18:37:35 +02:00
|
|
|
);
|
2017-07-12 15:30:31 -07:00
|
|
|
|
|
|
|
File.associate = db => {
|
|
|
|
File.hasMany(db.Request);
|
2017-09-15 14:41:47 -07:00
|
|
|
File.hasOne(db.Claim);
|
2017-07-12 15:30:31 -07:00
|
|
|
};
|
|
|
|
|
2017-10-31 17:19:26 -07:00
|
|
|
File.getRecentClaims = function () {
|
|
|
|
return this.findAll({
|
|
|
|
where: { nsfw: false, trendingEligible: true },
|
|
|
|
order: [['createdAt', 'DESC']],
|
|
|
|
limit: 25,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2017-06-19 18:37:35 +02:00
|
|
|
return File;
|
|
|
|
};
|