/** * Use Case: SelectAvatarUseCase * * Handles the business logic for selecting a generated avatar from the options. */ import type { Logger } from '@core/shared/domain/Logger'; import { Result } from '@core/shared/domain/Result'; import type { ApplicationErrorCode } from '@core/shared/errors/ApplicationErrorCode'; import { AvatarGenerationRepository } from '../../domain/repositories/AvatarGenerationRepository'; export interface SelectAvatarInput { requestId: string; selectedIndex: number; } export interface SelectAvatarResult { requestId: string; selectedAvatarUrl: string; } export type SelectAvatarErrorCode = | 'REQUEST_NOT_FOUND' | 'REQUEST_NOT_COMPLETED' | 'REPOSITORY_ERROR'; export type SelectAvatarApplicationError = ApplicationErrorCode< SelectAvatarErrorCode, { message: string } >; export class SelectAvatarUseCase { constructor( private readonly avatarRepo: AvatarGenerationRepository, private readonly logger: Logger, ) {} async execute(input: SelectAvatarInput): Promise> { this.logger.info('[SelectAvatarUseCase] Selecting avatar', { requestId: input.requestId, selectedIndex: input.selectedIndex, }); try { const request = await this.avatarRepo.findById(input.requestId); if (!request) { return Result.err({ code: 'REQUEST_NOT_FOUND', details: { message: 'Avatar generation request not found' }, }); } if (request.status !== 'completed') { return Result.err({ code: 'REQUEST_NOT_COMPLETED', details: { message: 'Avatar generation is not completed yet' }, }); } request.selectAvatar(input.selectedIndex); await this.avatarRepo.save(request); const selectedAvatarUrl = request.selectedAvatarUrl!; this.logger.info('[SelectAvatarUseCase] Avatar selected successfully', { requestId: input.requestId, selectedAvatarUrl, }); return Result.ok({ requestId: input.requestId, selectedAvatarUrl, }); } catch (error) { const err = error instanceof Error ? error : new Error(String(error)); this.logger.error('[SelectAvatarUseCase] Error selecting avatar', err, { requestId: input.requestId, }); return Result.err({ code: 'REPOSITORY_ERROR', details: { message: err.message ?? 'Unexpected repository error' }, }); } } }