forked from DebaucheryLibrarian/traxxx
				
			Fixed S3 display support for movies.
This commit is contained in:
		
							parent
							
								
									c1829c64c2
								
							
						
					
					
						commit
						2b5aac7633
					
				|  | @ -59,7 +59,7 @@ | ||||||
| 				<a | 				<a | ||||||
| 					v-for="cover in release.covers" | 					v-for="cover in release.covers" | ||||||
| 					:key="`cover-${cover.id}`" | 					:key="`cover-${cover.id}`" | ||||||
| 					:href="`${config.media.mediaPath}/${cover.path}`" | 					:href="getPath(cover)" | ||||||
| 					target="_blank" | 					target="_blank" | ||||||
| 					rel="noopener noreferrer" | 					rel="noopener noreferrer" | ||||||
| 				> | 				> | ||||||
|  |  | ||||||
|  | @ -84,7 +84,7 @@ | ||||||
| 						<span class="movie-title">{{ movie.title }}</span> | 						<span class="movie-title">{{ movie.title }}</span> | ||||||
| 						<img | 						<img | ||||||
| 							v-if="movie.covers.length > 0" | 							v-if="movie.covers.length > 0" | ||||||
| 							:src="`/media/${movie.covers[0].thumbnail}`" | 							:src="getPath(movie.covers[0], 'thumbnail')" | ||||||
| 							class="movie-cover" | 							class="movie-cover" | ||||||
| 						> | 						> | ||||||
| 					</router-link> | 					</router-link> | ||||||
|  |  | ||||||
|  | @ -315,6 +315,7 @@ const releaseFragment = ` | ||||||
| 					path | 					path | ||||||
| 					thumbnail | 					thumbnail | ||||||
| 					lazy | 					lazy | ||||||
|  | 					isS3 | ||||||
| 					comment | 					comment | ||||||
| 					sfw: sfwMedia { | 					sfw: sfwMedia { | ||||||
| 						id | 						id | ||||||
|  |  | ||||||
|  | @ -103,6 +103,7 @@ function initReleasesActions(store, router) { | ||||||
| 								path | 								path | ||||||
| 								thumbnail | 								thumbnail | ||||||
| 								lazy | 								lazy | ||||||
|  | 								isS3 | ||||||
| 								sfw: sfwMedia { | 								sfw: sfwMedia { | ||||||
| 									id | 									id | ||||||
| 									path | 									path | ||||||
|  | @ -157,6 +158,16 @@ function initReleasesActions(store, router) { | ||||||
| 							path | 							path | ||||||
| 							thumbnail | 							thumbnail | ||||||
| 							lazy | 							lazy | ||||||
|  | 							isS3 | ||||||
|  | 						} | ||||||
|  | 					} | ||||||
|  | 					posters: moviesPosterByMovieId { | ||||||
|  | 						media { | ||||||
|  | 							id | ||||||
|  | 							path | ||||||
|  | 							thumbnail | ||||||
|  | 							lazy | ||||||
|  | 							isS3 | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
| 					covers: moviesCovers { | 					covers: moviesCovers { | ||||||
|  | @ -165,12 +176,14 @@ function initReleasesActions(store, router) { | ||||||
| 							path | 							path | ||||||
| 							thumbnail | 							thumbnail | ||||||
| 							lazy | 							lazy | ||||||
|  | 							isS3 | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
| 					trailer: moviesTrailerByMovieId { | 					trailer: moviesTrailerByMovieId { | ||||||
| 						media { | 						media { | ||||||
| 							id | 							id | ||||||
| 							path | 							path | ||||||
|  | 							isS3 | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
| 					scenes: moviesScenes { | 					scenes: moviesScenes { | ||||||
|  | @ -189,6 +202,7 @@ function initReleasesActions(store, router) { | ||||||
| 						path | 						path | ||||||
| 						thumbnail | 						thumbnail | ||||||
| 						lazy | 						lazy | ||||||
|  | 						isS3 | ||||||
| 						comment | 						comment | ||||||
| 						sfw: sfwMedia { | 						sfw: sfwMedia { | ||||||
| 							id | 							id | ||||||
|  |  | ||||||
|  | @ -901,7 +901,7 @@ exports.up = knex => Promise.resolve() | ||||||
| 			.references('id') | 			.references('id') | ||||||
| 			.inTable('media'); | 			.inTable('media'); | ||||||
| 
 | 
 | ||||||
| 		table.unique(['movie_id', 'media_id']); | 		table.unique('movie_id'); | ||||||
| 	})) | 	})) | ||||||
| 	.then(() => knex.schema.createTable('clips', (table) => { | 	.then(() => knex.schema.createTable('clips', (table) => { | ||||||
| 		table.increments('id', 16); | 		table.increments('id', 16); | ||||||
|  |  | ||||||
							
								
								
									
										33
									
								
								src/media.js
								
								
								
								
							
							
						
						
									
										33
									
								
								src/media.js
								
								
								
								
							|  | @ -26,7 +26,7 @@ const { get } = require('./utils/qu'); | ||||||
| const pipeline = util.promisify(stream.pipeline); | const pipeline = util.promisify(stream.pipeline); | ||||||
| const streamQueue = taskQueue(); | const streamQueue = taskQueue(); | ||||||
| 
 | 
 | ||||||
| const endpoint = new AWS.Endpoint('s3.wasabisys.com'); | const endpoint = new AWS.Endpoint('s3.eu-central-1.wasabisys.com'); | ||||||
| 
 | 
 | ||||||
| const s3 = new AWS.S3({ | const s3 = new AWS.S3({ | ||||||
| 	// region: 'eu-central-1',
 | 	// region: 'eu-central-1',
 | ||||||
|  | @ -869,6 +869,29 @@ async function associateAvatars(profiles) { | ||||||
| 	return profilesWithAvatarIds; | 	return profilesWithAvatarIds; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | async function deleteS3Objects(media) { | ||||||
|  | 	const objects = media | ||||||
|  | 		.map(item => [ | ||||||
|  | 			{ Key: item.path }, | ||||||
|  | 			{ Key: item.thumbnail }, | ||||||
|  | 			{ Key: item.lazy }, | ||||||
|  | 		]) | ||||||
|  | 		.flat() | ||||||
|  | 		.filter(item => item.Key); | ||||||
|  | 
 | ||||||
|  | 	const status = await s3.deleteObjects({ | ||||||
|  | 		Bucket: config.s3.bucket, | ||||||
|  | 		Delete: { | ||||||
|  | 			Objects: objects, | ||||||
|  | 			Quiet: false, | ||||||
|  | 		}, | ||||||
|  | 	}).promise(); | ||||||
|  | 
 | ||||||
|  | 	logger.info(`Removed ${status.Deleted.length} media files from S3 bucket '${config.s3.bucket}', ${status.Errors.length} errors`); | ||||||
|  | 
 | ||||||
|  | 	return status; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| async function flushOrphanedMedia() { | async function flushOrphanedMedia() { | ||||||
| 	const orphanedMedia = await knex('media') | 	const orphanedMedia = await knex('media') | ||||||
| 		.where('is_sfw', false) | 		.where('is_sfw', false) | ||||||
|  | @ -896,10 +919,10 @@ async function flushOrphanedMedia() { | ||||||
| 				) | 				) | ||||||
| 				.whereRaw('associations.media_id = media.id'), | 				.whereRaw('associations.media_id = media.id'), | ||||||
| 		) | 		) | ||||||
| 		.returning(['media.path', 'media.thumbnail', 'media.lazy']) | 		.returning(['media.id', 'media.is_s3', 'media.path', 'media.thumbnail', 'media.lazy']) | ||||||
| 		.delete(); | 		.delete(); | ||||||
| 
 | 
 | ||||||
| 	await Promise.all(orphanedMedia.map(media => Promise.all([ | 	await Promise.all(orphanedMedia.filter(media => !media.is_s3).map(media => Promise.all([ | ||||||
| 		media.path && fsPromises.unlink(path.join(config.media.path, media.path)).catch(() => { /* probably file not found */ }), | 		media.path && fsPromises.unlink(path.join(config.media.path, media.path)).catch(() => { /* probably file not found */ }), | ||||||
| 		media.thumbnail && fsPromises.unlink(path.join(config.media.path, media.thumbnail)).catch(() => { /* probably file not found */ }), | 		media.thumbnail && fsPromises.unlink(path.join(config.media.path, media.thumbnail)).catch(() => { /* probably file not found */ }), | ||||||
| 		media.lazy && fsPromises.unlink(path.join(config.media.path, media.lazy)).catch(() => { /* probably file not found */ }), | 		media.lazy && fsPromises.unlink(path.join(config.media.path, media.lazy)).catch(() => { /* probably file not found */ }), | ||||||
|  | @ -907,6 +930,10 @@ async function flushOrphanedMedia() { | ||||||
| 
 | 
 | ||||||
| 	logger.info(`Removed ${orphanedMedia.length} media files from database and storage`); | 	logger.info(`Removed ${orphanedMedia.length} media files from database and storage`); | ||||||
| 
 | 
 | ||||||
|  | 	if (config.s3.enabled) { | ||||||
|  | 		await deleteS3Objects(orphanedMedia.filter(media => media.is_s3)); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	await fsPromises.rmdir(path.join(config.media.path, 'temp'), { recursive: true }); | 	await fsPromises.rmdir(path.join(config.media.path, 'temp'), { recursive: true }); | ||||||
| 
 | 
 | ||||||
| 	logger.info('Cleared temporary media directory'); | 	logger.info('Cleared temporary media directory'); | ||||||
|  |  | ||||||
|  | @ -200,8 +200,6 @@ function scrapeAll(html, site, networkUrl, hasTeaser = true) { | ||||||
| 			]; | 			]; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		console.log(release); |  | ||||||
| 
 |  | ||||||
| 		return release; | 		return release; | ||||||
| 	}); | 	}); | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue