mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-26 08:12:25 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			85 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| const { DataTypes, Model } = require('sequelize')
 | |
| 
 | |
| class BookAuthor extends Model {
 | |
|   constructor(values, options) {
 | |
|     super(values, options)
 | |
| 
 | |
|     /** @type {UUIDV4} */
 | |
|     this.id
 | |
|     /** @type {UUIDV4} */
 | |
|     this.bookId
 | |
|     /** @type {UUIDV4} */
 | |
|     this.authorId
 | |
|     /** @type {Date} */
 | |
|     this.createdAt
 | |
|   }
 | |
| 
 | |
|   static removeByIds(authorId = null, bookId = null) {
 | |
|     const where = {}
 | |
|     if (authorId) where.authorId = authorId
 | |
|     if (bookId) where.bookId = bookId
 | |
|     return this.destroy({
 | |
|       where
 | |
|     })
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Get number of books for author
 | |
|    *
 | |
|    * @param {string} authorId
 | |
|    * @returns {Promise<number>}
 | |
|    */
 | |
|   static getCountForAuthor(authorId) {
 | |
|     return this.count({
 | |
|       where: {
 | |
|         authorId
 | |
|       }
 | |
|     })
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Initialize model
 | |
|    * @param {import('../Database').sequelize} sequelize
 | |
|    */
 | |
|   static init(sequelize) {
 | |
|     super.init(
 | |
|       {
 | |
|         id: {
 | |
|           type: DataTypes.UUID,
 | |
|           defaultValue: DataTypes.UUIDV4,
 | |
|           primaryKey: true
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         sequelize,
 | |
|         modelName: 'bookAuthor',
 | |
|         timestamps: true,
 | |
|         updatedAt: false,
 | |
|         indexes: [
 | |
|           {
 | |
|             name: 'bookAuthor_authorId',
 | |
|             fields: ['authorId']
 | |
|           }
 | |
|         ]
 | |
|       }
 | |
|     )
 | |
| 
 | |
|     // 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, author } = sequelize.models
 | |
|     book.belongsToMany(author, { through: BookAuthor })
 | |
|     author.belongsToMany(book, { through: BookAuthor })
 | |
| 
 | |
|     book.hasMany(BookAuthor, {
 | |
|       onDelete: 'CASCADE'
 | |
|     })
 | |
|     BookAuthor.belongsTo(book)
 | |
| 
 | |
|     author.hasMany(BookAuthor, {
 | |
|       onDelete: 'CASCADE'
 | |
|     })
 | |
|     BookAuthor.belongsTo(author)
 | |
|   }
 | |
| }
 | |
| module.exports = BookAuthor
 |