1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-04-06 16:16:26 +02:00

fix(server): no exif metadata in the deduplication utility ()

add exif to `getDuplicates`
This commit is contained in:
Mert 2025-01-24 12:42:39 -05:00 committed by GitHub
parent ede9c99adb
commit a6ace5151c
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 33 additions and 14 deletions
server/src

View file

@ -306,17 +306,26 @@ order by
with
"duplicates" as (
select
"duplicateId",
jsonb_agg("assets") as "assets"
"assets"."duplicateId",
jsonb_agg("asset") as "assets"
from
"assets"
left join lateral (
select
"assets".*,
"exif" as "exifInfo"
from
"exif"
where
"exif"."assetId" = "assets"."id"
) as "asset" on true
where
"ownerId" = $1::uuid
and "duplicateId" is not null
and "deletedAt" is null
and "isVisible" = $2
"assets"."ownerId" = $1::uuid
and "assets"."duplicateId" is not null
and "assets"."deletedAt" is null
and "assets"."isVisible" = $2
group by
"duplicateId"
"assets"."duplicateId"
),
"unique" as (
select

View file

@ -677,13 +677,23 @@ export class AssetRepository implements IAssetRepository {
.with('duplicates', (qb) =>
qb
.selectFrom('assets')
.select('duplicateId')
.select((eb) => eb.fn<Assets[]>('jsonb_agg', [eb.table('assets')]).as('assets'))
.where('ownerId', '=', asUuid(userId))
.where('duplicateId', 'is not', null)
.where('deletedAt', 'is', null)
.where('isVisible', '=', true)
.groupBy('duplicateId'),
.leftJoinLateral(
(qb) =>
qb
.selectFrom('exif')
.selectAll('assets')
.select((eb) => eb.table('exif').as('exifInfo'))
.whereRef('exif.assetId', '=', 'assets.id')
.as('asset'),
(join) => join.onTrue(),
)
.select('assets.duplicateId')
.select((eb) => eb.fn('jsonb_agg', [eb.table('asset')]).as('assets'))
.where('assets.ownerId', '=', asUuid(userId))
.where('assets.duplicateId', 'is not', null)
.where('assets.deletedAt', 'is', null)
.where('assets.isVisible', '=', true)
.groupBy('assets.duplicateId'),
)
.with('unique', (qb) =>
qb