mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-25 07:48:56 -04:00 
			
		
		
		
	Add: migrations for authors, series, and podcast episodes
This commit is contained in:
		
							parent
							
								
									d80752cc9d
								
							
						
					
					
						commit
						1fa80e31d1
					
				
							
								
								
									
										78
									
								
								server/migrations/v2.15.2-index-creation.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								server/migrations/v2.15.2-index-creation.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | |||||||
|  | /** | ||||||
|  |  * @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 `PodcastEpisode` 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') | ||||||
|  |   await queryInterface.addIndex('BookAuthor', ['authorId'], { | ||||||
|  |     name: 'bookAuthor_authorId' | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   // Create index for bookSeries
 | ||||||
|  |   logger.info('[2.15.2 migration] Creating index for bookSeries') | ||||||
|  |   await queryInterface.addIndex('BookSeries', ['seriesId'], { | ||||||
|  |     name: 'bookSeries_seriesId' | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   // Delete existing podcastEpisode index
 | ||||||
|  |   logger.info('[2.15.2 migration] Deleting existing podcastEpisode index') | ||||||
|  |   await queryInterface.removeIndex('PodcastEpisode', 'podcast_episode_created_at') | ||||||
|  | 
 | ||||||
|  |   // Create index for podcastEpisode and createdAt
 | ||||||
|  |   logger.info('[2.15.2 migration] Creating index for podcastEpisode and createdAt') | ||||||
|  |   await queryInterface.addIndex('PodcastEpisode', ['createdAt', 'podcastId'], { | ||||||
|  |     name: 'podcastEpisode_createdAt_podcastId' | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   // 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 `PodcastEpisode` 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('BookAuthor', '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('PodcastEpisode', 'podcastEpisode_createdAt_podcastId') | ||||||
|  | 
 | ||||||
|  |   // Create index for podcastEpisode and createdAt
 | ||||||
|  |   logger.info('[2.15.2 migration] Creating index for podcastEpisode createdAt') | ||||||
|  |   await queryInterface.addIndex('PodcastEpisode', ['createdAt'], { | ||||||
|  |     name: 'podcast_episode_created_at' | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   // Finished migration
 | ||||||
|  |   logger.info('[2.15.2 migration] DOWNGRADE END: 2.15.2-index-creation') | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | module.exports = { up, down } | ||||||
| @ -54,7 +54,13 @@ class BookAuthor extends Model { | |||||||
|         sequelize, |         sequelize, | ||||||
|         modelName: 'bookAuthor', |         modelName: 'bookAuthor', | ||||||
|         timestamps: true, |         timestamps: true, | ||||||
|         updatedAt: false |         updatedAt: false, | ||||||
|  |         indexes: [ | ||||||
|  |           { | ||||||
|  |             name: 'bookAuthor_authorId', | ||||||
|  |             fields: ['authorId'] | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|       } |       } | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -43,7 +43,13 @@ class BookSeries extends Model { | |||||||
|         sequelize, |         sequelize, | ||||||
|         modelName: 'bookSeries', |         modelName: 'bookSeries', | ||||||
|         timestamps: true, |         timestamps: true, | ||||||
|         updatedAt: false |         updatedAt: false, | ||||||
|  |         indexes: [ | ||||||
|  |           { | ||||||
|  |             name: 'bookSeries_seriesId', | ||||||
|  |             fields: ['seriesId'] | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|       } |       } | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -157,7 +157,7 @@ class PodcastEpisode extends Model { | |||||||
|         modelName: 'podcastEpisode', |         modelName: 'podcastEpisode', | ||||||
|         indexes: [ |         indexes: [ | ||||||
|           { |           { | ||||||
|             fields: ['createdAt'] |             fields: ['createdAt', 'podcastId'] | ||||||
|           } |           } | ||||||
|         ] |         ] | ||||||
|       } |       } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user