1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-01 08:31:59 +00:00

fix(web): auth on navigation from shared link to timeline (#12385)

This commit is contained in:
Michel Heusschen 2024-09-06 15:15:48 +02:00 committed by GitHub
parent aa0097bde2
commit 9fc30d6bf6
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 14 additions and 1 deletions

View file

@ -69,4 +69,15 @@ test.describe('Shared Links', () => {
await page.goto('/share/invalid'); await page.goto('/share/invalid');
await page.getByRole('heading', { name: 'Invalid share key' }).waitFor(); await page.getByRole('heading', { name: 'Invalid share key' }).waitFor();
}); });
test('auth on navigation from shared link to timeline', async ({ context, page }) => {
await utils.setAuthCookies(context, admin.accessToken);
await page.goto(`/share/${sharedLink.key}`);
await page.getByRole('heading', { name: 'Test Album' }).waitFor();
await page.locator('a[href="/"]').click();
await page.waitForURL('/photos');
await page.locator(`[data-asset-id="${asset.id}"]`).waitFor();
});
}); });

View file

@ -156,7 +156,7 @@ export const getJobName = derived(t, ($t) => {
let _key: string | undefined; let _key: string | undefined;
let _sharedLink: SharedLinkResponseDto | undefined; let _sharedLink: SharedLinkResponseDto | undefined;
export const setKey = (key: string) => (_key = key); export const setKey = (key?: string) => (_key = key);
export const getKey = (): string | undefined => _key; export const getKey = (): string | undefined => _key;
export const setSharedLink = (sharedLink: SharedLinkResponseDto) => (_sharedLink = sharedLink); export const setSharedLink = (sharedLink: SharedLinkResponseDto) => (_sharedLink = sharedLink);
export const getSharedLink = (): SharedLinkResponseDto | undefined => _sharedLink; export const getSharedLink = (): SharedLinkResponseDto | undefined => _sharedLink;

View file

@ -71,6 +71,8 @@
} }
beforeNavigate(({ from, to }) => { beforeNavigate(({ from, to }) => {
setKey(isSharedLinkRoute(to?.route.id) ? to?.params?.key : undefined);
if (isAssetViewerRoute(from) && isAssetViewerRoute(to)) { if (isAssetViewerRoute(from) && isAssetViewerRoute(to)) {
return; return;
} }