2023-03-30 21:38:55 +02:00
|
|
|
import { AlbumEntity } from '@app/infra/entities';
|
2023-03-03 03:47:08 +01:00
|
|
|
|
2023-02-25 15:12:03 +01:00
|
|
|
export const IAlbumRepository = 'IAlbumRepository';
|
|
|
|
|
2023-03-26 04:46:48 +02:00
|
|
|
export interface AlbumAssetCount {
|
|
|
|
albumId: string;
|
|
|
|
assetCount: number;
|
|
|
|
}
|
|
|
|
|
2023-08-15 20:34:02 +02:00
|
|
|
export interface AlbumInfoOptions {
|
|
|
|
withAssets: boolean;
|
|
|
|
}
|
|
|
|
|
2023-10-18 17:56:00 +02:00
|
|
|
export interface AlbumAsset {
|
|
|
|
albumId: string;
|
|
|
|
assetId: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface AlbumAssets {
|
|
|
|
albumId: string;
|
|
|
|
assetIds: string[];
|
|
|
|
}
|
|
|
|
|
2023-02-25 15:12:03 +01:00
|
|
|
export interface IAlbumRepository {
|
2023-08-15 20:34:02 +02:00
|
|
|
getById(id: string, options: AlbumInfoOptions): Promise<AlbumEntity | null>;
|
2023-03-18 14:44:42 +01:00
|
|
|
getByIds(ids: string[]): Promise<AlbumEntity[]>;
|
2023-03-26 04:46:48 +02:00
|
|
|
getByAssetId(ownerId: string, assetId: string): Promise<AlbumEntity[]>;
|
2023-10-18 17:56:00 +02:00
|
|
|
addAssets(assets: AlbumAssets): Promise<void>;
|
fix(server): Check album asset membership in bulk (#4603)
Add `AlbumRepository` method to retrieve an album's asset ids, with an
optional parameter to only filter by the provided asset ids. With this,
we can now check asset membership using a single query.
When adding or removing assets to an album, checking whether each asset
is already present in the album now requires a single query, instead of
one query per asset.
Related to #4539 performance improvements.
Before:
```
// Asset membership and permissions check (2 queries per asset)
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "albums" "AlbumEntity" LEFT JOIN "albums_assets_assets" "AlbumEntity_AlbumEntity__AlbumEntity_assets" ON "AlbumEntity_AlbumEntity__AlbumEntity_assets"."albumsId"="AlbumEntity"."id" LEFT JOIN "assets" "AlbumEntity__AlbumEntity_assets" ON "AlbumEntity__AlbumEntity_assets"."id"="AlbumEntity_AlbumEntity__AlbumEntity_assets"."assetsId" AND ("AlbumEntity__AlbumEntity_assets"."deletedAt" IS NULL) WHERE ( ("AlbumEntity"."id" = $1 AND "AlbumEntity__AlbumEntity_assets"."id" = $2) ) AND ( "AlbumEntity"."deletedAt" IS NULL )) LIMIT 1 -- PARAMETERS: ["3fdf0e58-a1c7-4efe-8288-06e4c3f38df9","b666ae6c-afa8-4d6f-a1ad-7091a0659320"]
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "assets" "AssetEntity" WHERE ("AssetEntity"."id" = $1 AND "AssetEntity"."ownerId" = $2)) LIMIT 1 -- PARAMETERS: ["b666ae6c-afa8-4d6f-a1ad-7091a0659320","6bc60cf1-bd18-4501-a1c2-120b51276fda"]
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "albums" "AlbumEntity" LEFT JOIN "albums_assets_assets" "AlbumEntity_AlbumEntity__AlbumEntity_assets" ON "AlbumEntity_AlbumEntity__AlbumEntity_assets"."albumsId"="AlbumEntity"."id" LEFT JOIN "assets" "AlbumEntity__AlbumEntity_assets" ON "AlbumEntity__AlbumEntity_assets"."id"="AlbumEntity_AlbumEntity__AlbumEntity_assets"."assetsId" AND ("AlbumEntity__AlbumEntity_assets"."deletedAt" IS NULL) WHERE ( ("AlbumEntity"."id" = $1 AND "AlbumEntity__AlbumEntity_assets"."id" = $2) ) AND ( "AlbumEntity"."deletedAt" IS NULL )) LIMIT 1 -- PARAMETERS: ["3fdf0e58-a1c7-4efe-8288-06e4c3f38df9","c656ab1c-7775-4ff7-b56f-01308c072a76"]
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "assets" "AssetEntity" WHERE ("AssetEntity"."id" = $1 AND "AssetEntity"."ownerId" = $2)) LIMIT 1 -- PARAMETERS: ["c656ab1c-7775-4ff7-b56f-01308c072a76","6bc60cf1-bd18-4501-a1c2-120b51276fda"]
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "albums" "AlbumEntity" LEFT JOIN "albums_assets_assets" "AlbumEntity_AlbumEntity__AlbumEntity_assets" ON "AlbumEntity_AlbumEntity__AlbumEntity_assets"."albumsId"="AlbumEntity"."id" LEFT JOIN "assets" "AlbumEntity__AlbumEntity_assets" ON "AlbumEntity__AlbumEntity_assets"."id"="AlbumEntity_AlbumEntity__AlbumEntity_assets"."assetsId" AND ("AlbumEntity__AlbumEntity_assets"."deletedAt" IS NULL) WHERE ( ("AlbumEntity"."id" = $1 AND "AlbumEntity__AlbumEntity_assets"."id" = $2) ) AND ( "AlbumEntity"."deletedAt" IS NULL )) LIMIT 1 -- PARAMETERS: ["3fdf0e58-a1c7-4efe-8288-06e4c3f38df9","cf82adb2-1fcc-4f9e-9013-8fc03cc8d3a9"]
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "assets" "AssetEntity" WHERE ("AssetEntity"."id" = $1 AND "AssetEntity"."ownerId" = $2)) LIMIT 1 -- PARAMETERS: ["cf82adb2-1fcc-4f9e-9013-8fc03cc8d3a9","6bc60cf1-bd18-4501-a1c2-120b51276fda"]
```
After:
```
// Asset membership check (1 query for all assets)
immich_server | query: SELECT "albums_assets"."assetsId" AS "assetId" FROM "albums_assets_assets" "albums_assets" WHERE "albums_assets"."albumsId" = $1 AND "albums_assets"."assetsId" IN ($2, $3, $4) -- PARAMETERS: ["ca870d76-6311-4e89-bf9a-f5b51ea2452c","b666ae6c-afa8-4d6f-a1ad-7091a0659320","c656ab1c-7775-4ff7-b56f-01308c072a76","cf82adb2-1fcc-4f9e-9013-8fc03cc8d3a9"]
// Permissions check (1 query per asset)
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "assets" "AssetEntity" WHERE ("AssetEntity"."id" = $1 AND "AssetEntity"."ownerId" = $2)) LIMIT 1 -- PARAMETERS: ["b666ae6c-afa8-4d6f-a1ad-7091a0659320","6bc60cf1-bd18-4501-a1c2-120b51276fda"]
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "assets" "AssetEntity" WHERE ("AssetEntity"."id" = $1 AND "AssetEntity"."ownerId" = $2)) LIMIT 1 -- PARAMETERS: ["c656ab1c-7775-4ff7-b56f-01308c072a76","6bc60cf1-bd18-4501-a1c2-120b51276fda"]
immich_server | query: SELECT 1 AS "row_exists" FROM (SELECT 1 AS dummy_column) "dummy_table" WHERE EXISTS (SELECT 1 FROM "assets" "AssetEntity" WHERE ("AssetEntity"."id" = $1 AND "AssetEntity"."ownerId" = $2)) LIMIT 1 -- PARAMETERS: ["cf82adb2-1fcc-4f9e-9013-8fc03cc8d3a9","6bc60cf1-bd18-4501-a1c2-120b51276fda"]
```
2023-10-23 15:02:27 +02:00
|
|
|
getAssetIds(albumId: string, assetIds?: string[]): Promise<Set<string>>;
|
2023-10-18 17:56:00 +02:00
|
|
|
hasAsset(asset: AlbumAsset): Promise<boolean>;
|
|
|
|
removeAsset(assetId: string): Promise<void>;
|
|
|
|
removeAssets(assets: AlbumAssets): Promise<void>;
|
2023-03-26 04:46:48 +02:00
|
|
|
getAssetCountForIds(ids: string[]): Promise<AlbumAssetCount[]>;
|
|
|
|
getInvalidThumbnail(): Promise<string[]>;
|
|
|
|
getOwned(ownerId: string): Promise<AlbumEntity[]>;
|
|
|
|
getShared(ownerId: string): Promise<AlbumEntity[]>;
|
|
|
|
getNotShared(ownerId: string): Promise<AlbumEntity[]>;
|
2023-09-18 17:56:50 +02:00
|
|
|
restoreAll(userId: string): Promise<void>;
|
|
|
|
softDeleteAll(userId: string): Promise<void>;
|
2023-02-25 15:12:03 +01:00
|
|
|
deleteAll(userId: string): Promise<void>;
|
2023-03-03 03:47:08 +01:00
|
|
|
getAll(): Promise<AlbumEntity[]>;
|
2023-05-25 04:10:45 +02:00
|
|
|
create(album: Partial<AlbumEntity>): Promise<AlbumEntity>;
|
2023-05-25 21:37:19 +02:00
|
|
|
update(album: Partial<AlbumEntity>): Promise<AlbumEntity>;
|
2023-05-26 15:04:09 +02:00
|
|
|
delete(album: AlbumEntity): Promise<void>;
|
2023-08-02 03:29:14 +02:00
|
|
|
updateThumbnails(): Promise<number | undefined>;
|
2023-02-25 15:12:03 +01:00
|
|
|
}
|