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,4 @@
import type { Logger, UseCaseOutputPort } from '@core/shared/application';
import type { Logger } from '@core/shared/application';
import { Result } from '@core/shared/application/Result';
import type { ApplicationErrorCode } from '@core/shared/errors/ApplicationErrorCode';
import type { League } from '../../domain/entities/League';
@@ -36,7 +36,6 @@ export class GetLeagueScheduleUseCase {
private readonly seasonRepository: ISeasonRepository,
private readonly raceRepository: IRaceRepository,
private readonly logger: Logger,
private readonly output: UseCaseOutputPort<GetLeagueScheduleResult>,
) {}
private async resolveSeasonForSchedule(params: {
@@ -110,7 +109,7 @@ export class GetLeagueScheduleUseCase {
async execute(
input: GetLeagueScheduleInput,
): Promise<
Result<void, ApplicationErrorCode<GetLeagueScheduleErrorCode, { message: string }>>
Result<GetLeagueScheduleResult, ApplicationErrorCode<GetLeagueScheduleErrorCode, { message: string }>>
> {
this.logger.debug('Fetching league schedule', { input });
const { leagueId } = input;
@@ -148,9 +147,7 @@ export class GetLeagueScheduleUseCase {
races: scheduledRaces,
};
this.output.present(result);
return Result.ok(undefined);
return Result.ok(result);
} catch (error) {
this.logger.error(
'Failed to load league schedule due to an unexpected error',