refactor use cases
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
import { Achievement, AchievementProps } from '@core/identity/domain/entities/Achievement';
|
||||
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 { Logger } from '@core/shared/application';
|
||||
|
||||
export interface IAchievementRepository {
|
||||
save(achievement: Achievement): Promise<void>;
|
||||
@@ -25,20 +25,18 @@ export class CreateAchievementUseCase {
|
||||
constructor(
|
||||
private readonly achievementRepository: IAchievementRepository,
|
||||
private readonly logger: Logger,
|
||||
private readonly output: UseCaseOutputPort<CreateAchievementResult>,
|
||||
) {}
|
||||
|
||||
async execute(input: CreateAchievementInput): Promise<
|
||||
Result<void, CreateAchievementApplicationError>
|
||||
Result<CreateAchievementResult, CreateAchievementApplicationError>
|
||||
> {
|
||||
try {
|
||||
const achievement = Achievement.create(input);
|
||||
await this.achievementRepository.save(achievement);
|
||||
|
||||
const result: CreateAchievementResult = { achievement };
|
||||
this.output.present(result);
|
||||
|
||||
return Result.ok(undefined);
|
||||
return Result.ok(result);
|
||||
} catch (error) {
|
||||
const message =
|
||||
error instanceof Error && error.message
|
||||
@@ -57,4 +55,4 @@ export class CreateAchievementUseCase {
|
||||
} as CreateAchievementApplicationError);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user