refactor use cases

This commit is contained in:
2026-01-08 15:34:51 +01:00
parent d984ab24a8
commit 52e9a2f6a7
362 changed files with 5192 additions and 8409 deletions

View File

@@ -1,4 +1,3 @@
import type { UseCaseOutputPort } from '@core/shared/application';
import { Result } from '@core/shared/application/Result';
import type { ApplicationErrorCode } from '@core/shared/errors/ApplicationErrorCode';
import type { Driver } from '../../domain/entities/Driver';
@@ -30,12 +29,11 @@ export class GetLeagueJoinRequestsUseCase {
private readonly leagueMembershipRepository: ILeagueMembershipRepository,
private readonly driverRepository: IDriverRepository,
private readonly leagueRepository: ILeagueRepository,
private readonly output: UseCaseOutputPort<GetLeagueJoinRequestsResult>,
) {}
async execute(
input: GetLeagueJoinRequestsInput,
): Promise<Result<void, ApplicationErrorCode<GetLeagueJoinRequestsErrorCode, { message: string }>>> {
): Promise<Result<GetLeagueJoinRequestsResult, ApplicationErrorCode<GetLeagueJoinRequestsErrorCode, { message: string }>>> {
try {
const leagueExists = await this.leagueRepository.exists(input.leagueId);
@@ -69,9 +67,7 @@ export class GetLeagueJoinRequestsUseCase {
joinRequests: enrichedJoinRequests,
};
this.output.present(result);
return Result.ok(undefined);
return Result.ok(result);
} catch (error: unknown) {
const message = error instanceof Error ? error.message : 'Failed to load league join requests';
@@ -81,4 +77,4 @@ export class GetLeagueJoinRequestsUseCase {
});
}
}
}
}