From d46e50213a0d72c5cd7ca0feabc2df89196bb6d3 Mon Sep 17 00:00:00 2001 From: Zack Pollard Date: Tue, 1 Oct 2024 14:03:19 +0100 Subject: [PATCH] fix(server): offline assets don't restore when coming back online (#13087) --- server/src/services/library.service.ts | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/server/src/services/library.service.ts b/server/src/services/library.service.ts index 4b296570eb38f..07313e4ec8aa8 100644 --- a/server/src/services/library.service.ts +++ b/server/src/services/library.service.ts @@ -141,7 +141,13 @@ export class LibraryService extends BaseService { const handler = async () => { this.logger.debug(`File add event received for ${path} in library ${library.id}}`); if (matcher(path)) { - await this.syncFiles(library, [path]); + const asset = await this.assetRepository.getByLibraryIdAndOriginalPath(library.id, path); + if (asset) { + await this.syncAssets(library, [asset.id]); + } + if (matcher(path)) { + await this.syncFiles(library, [path]); + } } }; return handlePromiseError(handler(), this.logger); @@ -604,7 +610,7 @@ export class LibraryService extends BaseService { this.logger.log(`Scanning library ${library.id} for removed assets`); const onlineAssets = usePagination(JOBS_LIBRARY_PAGINATION_SIZE, (pagination) => - this.assetRepository.getAll(pagination, { libraryId: job.id }), + this.assetRepository.getAll(pagination, { libraryId: job.id, withDeleted: true }), ); let assetCount = 0;