mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-27 11:18:14 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			94 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/**
 | 
						|
 * @typedef MigrationContext
 | 
						|
 * @property {import('sequelize').QueryInterface} queryInterface - a suquelize QueryInterface object.
 | 
						|
 * @property {import('../Logger')} logger - a Logger object.
 | 
						|
 *
 | 
						|
 * @typedef MigrationOptions
 | 
						|
 * @property {MigrationContext} context - an object containing the migration context.
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 * This upward migration script adds indexes to speed up queries on the `BookAuthor`, `BookSeries`, and `podcastEpisodes` tables.
 | 
						|
 *
 | 
						|
 * @param {MigrationOptions} options - an object containing the migration context.
 | 
						|
 * @returns {Promise<void>} - A promise that resolves when the migration is complete.
 | 
						|
 */
 | 
						|
async function up({ context: { queryInterface, logger } }) {
 | 
						|
  // Upwards migration script
 | 
						|
  logger.info('[2.15.2 migration] UPGRADE BEGIN: 2.15.2-index-creation')
 | 
						|
 | 
						|
  // Create index for bookAuthors
 | 
						|
  logger.info('[2.15.2 migration] Creating index for bookAuthors')
 | 
						|
  const bookAuthorsIndexes = await queryInterface.showIndex('bookAuthors')
 | 
						|
  if (!bookAuthorsIndexes.some((index) => index.name === 'bookAuthor_authorId')) {
 | 
						|
    await queryInterface.addIndex('bookAuthors', ['authorId'], {
 | 
						|
      name: 'bookAuthor_authorId'
 | 
						|
    })
 | 
						|
  } else {
 | 
						|
    logger.info('[2.15.2 migration] Index bookAuthor_authorId already exists')
 | 
						|
  }
 | 
						|
 | 
						|
  // Create index for bookSeries
 | 
						|
  logger.info('[2.15.2 migration] Creating index for bookSeries')
 | 
						|
  const bookSeriesIndexes = await queryInterface.showIndex('bookSeries')
 | 
						|
  if (!bookSeriesIndexes.some((index) => index.name === 'bookSeries_seriesId')) {
 | 
						|
    await queryInterface.addIndex('bookSeries', ['seriesId'], {
 | 
						|
      name: 'bookSeries_seriesId'
 | 
						|
    })
 | 
						|
  } else {
 | 
						|
    logger.info('[2.15.2 migration] Index bookSeries_seriesId already exists')
 | 
						|
  }
 | 
						|
 | 
						|
  // Delete existing podcastEpisode index
 | 
						|
  logger.info('[2.15.2 migration] Deleting existing podcastEpisode index')
 | 
						|
  await queryInterface.removeIndex('podcastEpisodes', 'podcast_episodes_created_at')
 | 
						|
 | 
						|
  // Create index for podcastEpisode and createdAt
 | 
						|
  logger.info('[2.15.2 migration] Creating index for podcastEpisode and createdAt')
 | 
						|
  const podcastEpisodesIndexes = await queryInterface.showIndex('podcastEpisodes')
 | 
						|
  if (!podcastEpisodesIndexes.some((index) => index.name === 'podcastEpisode_createdAt_podcastId')) {
 | 
						|
    await queryInterface.addIndex('podcastEpisodes', ['createdAt', 'podcastId'], {
 | 
						|
      name: 'podcastEpisode_createdAt_podcastId'
 | 
						|
    })
 | 
						|
  } else {
 | 
						|
    logger.info('[2.15.2 migration] Index podcastEpisode_createdAt_podcastId already exists')
 | 
						|
  }
 | 
						|
 | 
						|
  // Completed migration
 | 
						|
  logger.info('[2.15.2 migration] UPGRADE END: 2.15.2-index-creation')
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * This downward migration script removes the newly created indexes and re-adds the old index on the `podcastEpisodes` table.
 | 
						|
 *
 | 
						|
 * @param {MigrationOptions} options - an object containing the migration context.
 | 
						|
 * @returns {Promise<void>} - A promise that resolves when the migration is complete.
 | 
						|
 */
 | 
						|
async function down({ context: { queryInterface, logger } }) {
 | 
						|
  // Downward migration script
 | 
						|
  logger.info('[2.15.2 migration] DOWNGRADE BEGIN: 2.15.2-index-creation')
 | 
						|
 | 
						|
  // Remove index for bookAuthors
 | 
						|
  logger.info('[2.15.2 migration] Removing index for bookAuthors')
 | 
						|
  await queryInterface.removeIndex('bookAuthors', 'bookAuthor_authorId')
 | 
						|
 | 
						|
  // Remove index for bookSeries
 | 
						|
  logger.info('[2.15.2 migration] Removing index for bookSeries')
 | 
						|
  await queryInterface.removeIndex('bookSeries', 'bookSeries_seriesId')
 | 
						|
 | 
						|
  // Delete existing podcastEpisode index
 | 
						|
  logger.info('[2.15.2 migration] Deleting existing podcastEpisode index')
 | 
						|
  await queryInterface.removeIndex('podcastEpisodes', 'podcastEpisode_createdAt_podcastId')
 | 
						|
 | 
						|
  // Create index for podcastEpisode and createdAt
 | 
						|
  logger.info('[2.15.2 migration] Creating original index for podcastEpisode createdAt')
 | 
						|
  await queryInterface.addIndex('podcastEpisodes', ['createdAt'], {
 | 
						|
    name: 'podcast_episodes_created_at'
 | 
						|
  })
 | 
						|
 | 
						|
  // Finished migration
 | 
						|
  logger.info('[2.15.2 migration] DOWNGRADE END: 2.15.2-index-creation')
 | 
						|
}
 | 
						|
 | 
						|
module.exports = { up, down }
 |