DB: Add models and migration for badges

This commit is contained in:
2023-02-27 01:56:44 +01:00
parent 1a5e7c1b62
commit 06575d280f
4 changed files with 69 additions and 0 deletions

View File

@@ -0,0 +1,41 @@
'use strict';
/** @type {import('sequelize-cli').Migration} */
module.exports = {
async up(queryInterface, Sequelize) {
await queryInterface.createTable('Badges', {
id: {
allowNull: false,
autoIncrement: true,
primaryKey: true,
type: Sequelize.INTEGER
},
name: {
type: Sequelize.STRING
},
description: {
type: Sequelize.STRING
},
image: {
type: Sequelize.STRING,
allowNull: true
},
createdAt: {
allowNull: false,
type: Sequelize.DATE,
defaultValue: Sequelize.literal('CURRENT_TIMESTAMP')
},
updatedAt: {
allowNull: false,
type: Sequelize.DATE,
defaultValue: Sequelize.literal('CURRENT_TIMESTAMP')
}
});
},
async down(queryInterface, Sequelize) {
await queryInterface.sequelize.query('ALTER TABLE BadgeCharacter DROP FOREIGN KEY BadgeCharacter_ibfk_1;');
await queryInterface.sequelize.query('ALTER TABLE BadgeCharacter DROP FOREIGN KEY BadgeCharacter_ibfk_2;');
await queryInterface.sequelize.query('ALTER TABLE BadgeUser DROP FOREIGN KEY BadgeUser_ibfk_1;');
await queryInterface.sequelize.query('ALTER TABLE BadgeUser DROP FOREIGN KEY BadgeUser_ibfk_2;');
await queryInterface.dropTable('Badges');
}
};

24
models/badge.js Normal file
View File

@@ -0,0 +1,24 @@
'use strict';
const {
Model
} = require('sequelize');
module.exports = (sequelize, DataTypes) => {
class Badge extends Model {
static associate(models) {
// A badge can belong to many cards
Badge.belongsToMany(models.Character, { through: 'BadgeCharacter' });
// A badge can belong to many users
Badge.belongsToMany(models.User, { through: 'BadgeUser' });
}
}
Badge.init({
name: DataTypes.STRING,
description: DataTypes.STRING,
image: DataTypes.STRING
}, {
sequelize,
modelName: 'Badge',
});
return Badge;
};

View File

@@ -11,6 +11,8 @@ module.exports = (sequelize, DataTypes) => {
*/
static associate(models) {
Character.belongsTo(models.Group, { foreignKey: 'groupId', });
// A character can belong to many badges
Character.belongsToMany(models.Badge, { through: 'BadgeCharacter' });
}
}
Character.init({

View File

@@ -17,6 +17,8 @@ module.exports = (sequelize, DataTypes) => {
User.hasMany(models.Card);
User.hasMany(models.CurrencyHistory);
User.hasOne(models.Profile);
// A user can have many badges
User.belongsToMany(models.Badge, { through: 'BadgeUser' });
}
async addExperience(amount, source='unknown') {
console.log(`Adding ${amount} experience to user ${this.id}`);