2019-06-13 07:53:57 +00:00
|
|
|
module.exports = function (sequelize, DataTypes) {
|
|
|
|
|
const Entity = sequelize.define('Entity', {
|
|
|
|
|
id: {
|
|
|
|
|
type: DataTypes.UUID,
|
|
|
|
|
defaultValue: DataTypes.UUIDV4,
|
|
|
|
|
primaryKey: true,
|
|
|
|
|
},
|
|
|
|
|
name: {
|
|
|
|
|
type: DataTypes.STRING,
|
|
|
|
|
allowNull: false
|
|
|
|
|
},
|
2019-07-10 17:26:22 +00:00
|
|
|
state: {
|
|
|
|
|
type: DataTypes.STRING(45),
|
|
|
|
|
allowNull: false,
|
|
|
|
|
default: 'draft',
|
|
|
|
|
}
|
2019-06-13 07:53:57 +00:00
|
|
|
}, {
|
|
|
|
|
tableName: 'entities',
|
|
|
|
|
freezeTableName: true,
|
|
|
|
|
timestamps: true,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Entity.associate = function (models) {
|
|
|
|
|
Entity.EntityTypes = Entity.belongsToMany(models.EntityType, {
|
|
|
|
|
through: models.EntityEntitiesTypes,
|
|
|
|
|
foreignKey: 'entityId'
|
|
|
|
|
});
|
2019-07-05 07:06:29 +00:00
|
|
|
Entity.Users = Entity.hasMany(models.User, { foreignKey: 'entityId' });
|
|
|
|
|
Entity.EventsReservations = Entity.hasMany(models.EventReservation, { foreignKey: 'entityId' });
|
2019-06-13 07:53:57 +00:00
|
|
|
};
|
|
|
|
|
return Entity;
|
|
|
|
|
};
|