mirror of
https://github.com/immich-app/immich.git
synced 2025-06-20 17:03:14 +02:00
* chore: add typeorm commands to npm and set default database config values * feat: move to server side authentication tokens * fix: websocket should emit error and disconnect on error thrown by the server * refactor: rename cookie-auth-strategy to user-auth-strategy * feat: user tokens and API keys now use SHA256 hash for performance improvements * test: album e2e test remove unneeded module import * infra: truncate api key table as old keys will no longer work with new hash algorithm * fix(server): e2e tests (#1435) * fix: root module paths * chore: linting * chore: rename user-auth to strategy.ts and make validate return AuthUserDto * fix: we should always send HttpOnly for our auth cookies * chore: remove now unused crypto functions and jwt dependencies * fix: return the extra fields for AuthUserDto in auth service validate --------- Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
38 lines
1.3 KiB
TypeScript
38 lines
1.3 KiB
TypeScript
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
import { TestingModuleBuilder } from '@nestjs/testing';
|
|
import { DataSource } from 'typeorm';
|
|
import { AuthUserDto } from '../src/decorators/auth-user.decorator';
|
|
import { AuthGuard } from '../src/modules/immich-auth/guards/auth.guard';
|
|
|
|
type CustomAuthCallback = () => AuthUserDto;
|
|
|
|
export async function clearDb(db: DataSource) {
|
|
const entities = db.entityMetadatas;
|
|
for (const entity of entities) {
|
|
const repository = db.getRepository(entity.name);
|
|
await repository.query(`TRUNCATE ${entity.tableName} RESTART IDENTITY CASCADE;`);
|
|
}
|
|
}
|
|
|
|
export function getAuthUser(): AuthUserDto {
|
|
return {
|
|
id: '3108ac14-8afb-4b7e-87fd-39ebb6b79750',
|
|
email: 'test@email.com',
|
|
isAdmin: false,
|
|
};
|
|
}
|
|
|
|
export function auth(builder: TestingModuleBuilder): TestingModuleBuilder {
|
|
return authCustom(builder, getAuthUser);
|
|
}
|
|
|
|
export function authCustom(builder: TestingModuleBuilder, callback: CustomAuthCallback): TestingModuleBuilder {
|
|
const canActivate: CanActivate = {
|
|
canActivate: (context: ExecutionContext) => {
|
|
const req = context.switchToHttp().getRequest();
|
|
req.user = callback();
|
|
return true;
|
|
},
|
|
};
|
|
return builder.overrideGuard(AuthGuard).useValue(canActivate);
|
|
}
|