mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-27 11:18:14 +01:00 
			
		
		
		
	* Adds share download endpoint * Adds Downloadable toggle to share modal --------- Co-authored-by: advplyr <advplyr@protonmail.com>
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * @typedef MigrationContext
 | |
|  * @property {import('sequelize').QueryInterface} queryInterface - a Sequelize QueryInterface object.
 | |
|  * @property {import('../Logger')} logger - a Logger object.
 | |
|  *
 | |
|  * @typedef MigrationOptions
 | |
|  * @property {MigrationContext} context - an object containing the migration context.
 | |
|  */
 | |
| 
 | |
| const migrationVersion = '2.17.6'
 | |
| const migrationName = `${migrationVersion}-share-add-isdownloadable`
 | |
| const loggerPrefix = `[${migrationVersion} migration]`
 | |
| 
 | |
| /**
 | |
|  * This migration script adds the isDownloadable column to the mediaItemShares table.
 | |
|  *
 | |
|  * @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 } }) {
 | |
|   logger.info(`${loggerPrefix} UPGRADE BEGIN: ${migrationName}`)
 | |
| 
 | |
|   if (await queryInterface.tableExists('mediaItemShares')) {
 | |
|     const tableDescription = await queryInterface.describeTable('mediaItemShares')
 | |
|     if (!tableDescription.isDownloadable) {
 | |
|       logger.info(`${loggerPrefix} Adding isDownloadable column to mediaItemShares table`)
 | |
|       await queryInterface.addColumn('mediaItemShares', 'isDownloadable', {
 | |
|         type: queryInterface.sequelize.Sequelize.DataTypes.BOOLEAN,
 | |
|         defaultValue: false,
 | |
|         allowNull: false
 | |
|       })
 | |
|       logger.info(`${loggerPrefix} Added isDownloadable column to mediaItemShares table`)
 | |
|     } else {
 | |
|       logger.info(`${loggerPrefix} isDownloadable column already exists in mediaItemShares table`)
 | |
|     }
 | |
|   } else {
 | |
|     logger.info(`${loggerPrefix} mediaItemShares table does not exist`)
 | |
|   }
 | |
| 
 | |
|   logger.info(`${loggerPrefix} UPGRADE END: ${migrationName}`)
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * This migration script removes the isDownloadable column from the mediaItemShares 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 } }) {
 | |
|   logger.info(`${loggerPrefix} DOWNGRADE BEGIN: ${migrationName}`)
 | |
| 
 | |
|   if (await queryInterface.tableExists('mediaItemShares')) {
 | |
|     const tableDescription = await queryInterface.describeTable('mediaItemShares')
 | |
|     if (tableDescription.isDownloadable) {
 | |
|       logger.info(`${loggerPrefix} Removing isDownloadable column from mediaItemShares table`)
 | |
|       await queryInterface.removeColumn('mediaItemShares', 'isDownloadable')
 | |
|       logger.info(`${loggerPrefix} Removed isDownloadable column from mediaItemShares table`)
 | |
|     } else {
 | |
|       logger.info(`${loggerPrefix} isDownloadable column does not exist in mediaItemShares table`)
 | |
|     }
 | |
|   } else {
 | |
|     logger.info(`${loggerPrefix} mediaItemShares table does not exist`)
 | |
|   }
 | |
| 
 | |
|   logger.info(`${loggerPrefix} DOWNGRADE END: ${migrationName}`)
 | |
| }
 | |
| 
 | |
| module.exports = { up, down }
 |