This commit is contained in:
2025-12-21 17:05:36 +01:00
parent 08b0d59e45
commit f2d8a23583
66 changed files with 1131 additions and 1342 deletions

View File

@@ -5,7 +5,7 @@ import { IAuthRepository } from '../../domain/repositories/IAuthRepository';
import { IPasswordHashingService } from '../../domain/services/PasswordHashingService';
import { Result } from '@core/shared/application/Result';
import type { ApplicationErrorCode } from '@core/shared/errors/ApplicationErrorCode';
import type { UseCaseOutputPort, Logger } from '@core/shared/application';
import type { UseCaseOutputPort, Logger, UseCase } from '@core/shared/application';
export type SignupInput = {
email: string;
@@ -26,24 +26,26 @@ export type SignupApplicationError = ApplicationErrorCode<SignupErrorCode, { mes
*
* Handles user registration.
*/
export class SignupUseCase {
export class SignupUseCase implements UseCase<SignupInput, SignupResult, SignupErrorCode> {
constructor(
private readonly authRepo: IAuthRepository,
private readonly passwordService: IPasswordHashingService,
private readonly logger: Logger,
private readonly output: UseCaseOutputPort<SignupResult>,
private readonly output: UseCaseOutputPort<Result<SignupResult, SignupApplicationError>>,
) {}
async execute(input: SignupInput): Promise<Result<void, SignupApplicationError>> {
async execute(input: SignupInput): Promise<Result<SignupResult, SignupApplicationError>> {
try {
const emailVO = EmailAddress.create(input.email);
const existingUser = await this.authRepo.findByEmail(emailVO);
if (existingUser) {
return Result.err({
const result = Result.err<SignupResult, SignupApplicationError>({
code: 'USER_ALREADY_EXISTS',
details: { message: 'User already exists' },
} as SignupApplicationError);
});
this.output.present(result);
return result;
}
const hashedPassword = await this.passwordService.hash(input.password);
@@ -60,10 +62,9 @@ export class SignupUseCase {
await this.authRepo.save(user);
const result: SignupResult = { user };
const result = Result.ok<SignupResult, SignupApplicationError>({ user });
this.output.present(result);
return Result.ok(undefined);
return result;
} catch (error) {
const message =
error instanceof Error && error.message
@@ -74,10 +75,12 @@ export class SignupUseCase {
input,
});
return Result.err({
const result = Result.err<SignupResult, SignupApplicationError>({
code: 'REPOSITORY_ERROR',
details: { message },
} as SignupApplicationError);
});
this.output.present(result);
return result;
}
}
}