mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-11-04 03:17:00 -05: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
 |