mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-26 00:02:34 -04:00 
			
		
		
		
	fix: album start/end dates on shared links (#21268)
This commit is contained in:
		
							parent
							
								
									840e43430c
								
							
						
					
					
						commit
						acfd40b77a
					
				| @ -38,7 +38,11 @@ from | ||||
|     select | ||||
|       "album".*, | ||||
|       coalesce( | ||||
|         json_agg("assets") filter ( | ||||
|         json_agg( | ||||
|           "assets" | ||||
|           order by | ||||
|             "assets"."fileCreatedAt" asc | ||||
|         ) filter ( | ||||
|           where | ||||
|             "assets"."id" is not null | ||||
|         ), | ||||
|  | ||||
| @ -86,7 +86,16 @@ export class SharedLinkRepository { | ||||
|               (join) => join.onTrue(), | ||||
|             ) | ||||
|             .select((eb) => | ||||
|               eb.fn.coalesce(eb.fn.jsonAgg('assets').filterWhere('assets.id', 'is not', null), sql`'[]'`).as('assets'), | ||||
|               eb.fn | ||||
|                 .coalesce( | ||||
|                   eb.fn | ||||
|                     .jsonAgg('assets') | ||||
|                     .orderBy('assets.fileCreatedAt', 'asc') | ||||
|                     .filterWhere('assets.id', 'is not', null), | ||||
| 
 | ||||
|                   sql`'[]'`, | ||||
|                 ) | ||||
|                 .as('assets'), | ||||
|             ) | ||||
|             .select((eb) => eb.fn.toJson('owner').as('owner')) | ||||
|             .groupBy(['album.id', sql`"owner".*`]) | ||||
|  | ||||
| @ -33,6 +33,7 @@ import { PartnerRepository } from 'src/repositories/partner.repository'; | ||||
| import { PersonRepository } from 'src/repositories/person.repository'; | ||||
| import { SearchRepository } from 'src/repositories/search.repository'; | ||||
| import { SessionRepository } from 'src/repositories/session.repository'; | ||||
| import { SharedLinkRepository } from 'src/repositories/shared-link.repository'; | ||||
| import { StackRepository } from 'src/repositories/stack.repository'; | ||||
| import { StorageRepository } from 'src/repositories/storage.repository'; | ||||
| import { SyncCheckpointRepository } from 'src/repositories/sync-checkpoint.repository'; | ||||
| @ -286,6 +287,7 @@ const newRealRepository = <T>(key: ClassConstructor<T>, db: Kysely<DB>): T => { | ||||
|     case PersonRepository: | ||||
|     case SearchRepository: | ||||
|     case SessionRepository: | ||||
|     case SharedLinkRepository: | ||||
|     case StackRepository: | ||||
|     case SyncRepository: | ||||
|     case SyncCheckpointRepository: | ||||
| @ -391,7 +393,7 @@ const assetInsert = (asset: Partial<Insertable<AssetTable>> = {}) => { | ||||
|     checksum: randomBytes(32), | ||||
|     type: AssetType.Image, | ||||
|     originalPath: '/path/to/something.jpg', | ||||
|     ownerId: '@immich.cloud', | ||||
|     ownerId: 'not-a-valid-uuid', | ||||
|     isFavorite: false, | ||||
|     fileCreatedAt: now, | ||||
|     fileModifiedAt: now, | ||||
|  | ||||
| @ -0,0 +1,65 @@ | ||||
| import { Kysely } from 'kysely'; | ||||
| import { randomBytes } from 'node:crypto'; | ||||
| import { SharedLinkType } from 'src/enum'; | ||||
| import { AccessRepository } from 'src/repositories/access.repository'; | ||||
| import { DatabaseRepository } from 'src/repositories/database.repository'; | ||||
| import { LoggingRepository } from 'src/repositories/logging.repository'; | ||||
| import { SharedLinkRepository } from 'src/repositories/shared-link.repository'; | ||||
| import { StorageRepository } from 'src/repositories/storage.repository'; | ||||
| import { DB } from 'src/schema'; | ||||
| import { SharedLinkService } from 'src/services/shared-link.service'; | ||||
| import { newMediumService } from 'test/medium.factory'; | ||||
| import { factory } from 'test/small.factory'; | ||||
| import { getKyselyDB } from 'test/utils'; | ||||
| 
 | ||||
| let defaultDatabase: Kysely<DB>; | ||||
| 
 | ||||
| const setup = (db?: Kysely<DB>) => { | ||||
|   return newMediumService(SharedLinkService, { | ||||
|     database: db || defaultDatabase, | ||||
|     real: [AccessRepository, DatabaseRepository, SharedLinkRepository], | ||||
|     mock: [LoggingRepository, StorageRepository], | ||||
|   }); | ||||
| }; | ||||
| 
 | ||||
| beforeAll(async () => { | ||||
|   defaultDatabase = await getKyselyDB(); | ||||
| }); | ||||
| 
 | ||||
| describe(SharedLinkService.name, () => { | ||||
|   describe('get', () => { | ||||
|     it('should return the correct dates on the shared link album', async () => { | ||||
|       const { sut, ctx } = setup(); | ||||
| 
 | ||||
|       const { user } = await ctx.newUser(); | ||||
|       const auth = factory.auth({ user }); | ||||
|       const { album } = await ctx.newAlbum({ ownerId: user.id }); | ||||
| 
 | ||||
|       const dates = ['2021-01-01T00:00:00.000Z', '2022-01-01T00:00:00.000Z', '2020-01-01T00:00:00.000Z']; | ||||
| 
 | ||||
|       for (const date of dates) { | ||||
|         const { asset } = await ctx.newAsset({ fileCreatedAt: date, localDateTime: date, ownerId: user.id }); | ||||
|         await ctx.newExif({ assetId: asset.id, make: 'Canon' }); | ||||
|         await ctx.newAlbumAsset({ albumId: album.id, assetId: asset.id }); | ||||
|       } | ||||
| 
 | ||||
|       const sharedLinkRepo = ctx.get(SharedLinkRepository); | ||||
| 
 | ||||
|       const sharedLink = await sharedLinkRepo.create({ | ||||
|         key: randomBytes(16), | ||||
|         id: factory.uuid(), | ||||
|         userId: user.id, | ||||
|         albumId: album.id, | ||||
|         allowUpload: true, | ||||
|         type: SharedLinkType.Album, | ||||
|       }); | ||||
| 
 | ||||
|       await expect(sut.get(auth, sharedLink.id)).resolves.toMatchObject({ | ||||
|         album: expect.objectContaining({ | ||||
|           startDate: '2020-01-01T00:00:00+00:00', | ||||
|           endDate: '2022-01-01T00:00:00+00:00', | ||||
|         }), | ||||
|       }); | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user