app2-api/modules/multimedia/multimedia.model.js

68 lines
1.8 KiB
JavaScript
Raw Normal View History

2019-06-26 11:28:17 +00:00
'use strict';
module.exports = function (sequelize, DataTypes) {
2019-07-05 07:06:29 +00:00
const Multimedia = sequelize.define('Multimedia', {
2019-06-26 11:28:17 +00:00
id: {
type: DataTypes.UUID,
defaultValue: DataTypes.UUIDV4,
primaryKey: true,
},
2019-07-05 07:06:29 +00:00
multimediafileId: {
type: DataTypes.UUID,
allowNull: false,
},
2019-06-26 11:28:17 +00:00
entityId: {
type: DataTypes.UUID,
allowNull: false,
},
entityName: {
type: DataTypes.STRING,
allowNull: false,
},
type: {
type: DataTypes.STRING,
allowNull: false,
},
2019-07-12 11:19:15 +00:00
/*entity: {
2019-06-26 11:28:17 +00:00
type: DataTypes.VIRTUAL,
get: function() {
const name = this.get('entityName');
const id = this.get('entityId');
let modelName = '';
switch (name) {
case 'post':
modelName = 'Post';
break;
2019-07-09 17:39:52 +00:00
2019-06-26 11:28:17 +00:00
case 'speaker':
modelName = 'Speaker'
break;
case 'event':
modelName = 'Event';
break;
default:
break;
}
2019-07-12 11:19:15 +00:00
return sequelize.models[modelName].findByPk(id).then(function(result) { return result });
2019-06-26 11:28:17 +00:00
}
2019-07-12 11:19:15 +00:00
}*/
2019-06-26 11:28:17 +00:00
}, {
indexes: [{
unique: false,
fields: ['entityId']
}],
tableName: 'multimedias',
freezeTableName: true,
timestamps: true,
});
2019-07-05 07:06:29 +00:00
Multimedia.associate = function (models) {
Multimedia.MultimediaFile = Multimedia.belongsTo(models.MultimediaFile, { foreignKey: 'multimediafileId' });
};
2019-06-26 11:28:17 +00:00
2019-07-05 07:06:29 +00:00
return Multimedia;
2019-06-26 11:28:17 +00:00
};