1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-19 18:26:46 +01:00

refactor(server): library asset deletion (#4366)

This commit is contained in:
Jason Rasmussen 2023-10-07 13:44:10 -04:00 committed by GitHub
parent c68702c0a7
commit 982dcd7b8d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -139,8 +139,10 @@ export class LibraryService {
// TODO use pagination // TODO use pagination
const assetIds = await this.repository.getAssetIds(job.id); const assetIds = await this.repository.getAssetIds(job.id);
this.logger.debug(`Will delete ${assetIds.length} asset(s) in library ${job.id}`); this.logger.debug(`Will delete ${assetIds.length} asset(s) in library ${job.id}`);
// TODO queue a job for asset deletion for (const assetId of assetIds) {
await this.deleteAssets(assetIds); await this.jobRepository.queue({ name: JobName.ASSET_DELETION, data: { id: assetId, fromExternal: true } });
}
this.logger.log(`Deleting library ${job.id}`); this.logger.log(`Deleting library ${job.id}`);
await this.repository.delete(job.id); await this.repository.delete(job.id);
return true; return true;
@ -333,20 +335,17 @@ export class LibraryService {
} }
async handleOfflineRemoval(job: IEntityJob): Promise<boolean> { async handleOfflineRemoval(job: IEntityJob): Promise<boolean> {
const assetPagination = usePagination(JOBS_ASSET_PAGINATION_SIZE, (pagination) => { const assetPagination = usePagination(JOBS_ASSET_PAGINATION_SIZE, (pagination) =>
return this.assetRepository.getWith(pagination, WithProperty.IS_OFFLINE, job.id); this.assetRepository.getWith(pagination, WithProperty.IS_OFFLINE, job.id),
}); );
const assetIds: string[] = [];
for await (const assets of assetPagination) { for await (const assets of assetPagination) {
this.logger.debug(`Removing ${assets.length} offline assets`);
for (const asset of assets) { for (const asset of assets) {
assetIds.push(asset.id); await this.jobRepository.queue({ name: JobName.ASSET_DELETION, data: { id: asset.id, fromExternal: true } });
} }
} }
this.logger.verbose(`Found ${assetIds.length} offline assets to remove`);
await this.deleteAssets(assetIds);
return true; return true;
} }
@ -439,19 +438,4 @@ export class LibraryService {
} }
return library; return library;
} }
private async deleteAssets(assetIds: string[]) {
for (const assetId of assetIds) {
const asset = await this.assetRepository.getById(assetId);
if (!asset) {
continue;
}
this.logger.debug(`Removing asset from library: ${asset.originalPath}`);
await this.jobRepository.queue({
name: JobName.ASSET_DELETION,
data: { id: asset.id, fromExternal: true },
});
}
}
} }