mirror of
https://github.com/advplyr/audiobookshelf.git
synced 2025-01-03 00:06:46 +01:00
46 lines
1.1 KiB
JavaScript
46 lines
1.1 KiB
JavaScript
const { DataTypes, Model } = require('sequelize')
|
|
|
|
module.exports = (sequelize) => {
|
|
class CollectionBook extends Model {
|
|
static removeByIds(collectionId, bookId) {
|
|
return this.destroy({
|
|
where: {
|
|
bookId,
|
|
collectionId
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
CollectionBook.init({
|
|
id: {
|
|
type: DataTypes.UUID,
|
|
defaultValue: DataTypes.UUIDV4,
|
|
primaryKey: true
|
|
},
|
|
order: DataTypes.INTEGER
|
|
}, {
|
|
sequelize,
|
|
timestamps: true,
|
|
updatedAt: false,
|
|
modelName: 'collectionBook'
|
|
})
|
|
|
|
// Super Many-to-Many
|
|
// ref: https://sequelize.org/docs/v6/advanced-association-concepts/advanced-many-to-many/#the-best-of-both-worlds-the-super-many-to-many-relationship
|
|
const { book, collection } = sequelize.models
|
|
book.belongsToMany(collection, { through: CollectionBook })
|
|
collection.belongsToMany(book, { through: CollectionBook })
|
|
|
|
book.hasMany(CollectionBook, {
|
|
onDelete: 'CASCADE'
|
|
})
|
|
CollectionBook.belongsTo(book)
|
|
|
|
collection.hasMany(CollectionBook, {
|
|
onDelete: 'CASCADE'
|
|
})
|
|
CollectionBook.belongsTo(collection)
|
|
|
|
return CollectionBook
|
|
} |