import type { Logger } from '@core/shared/domain/Logger'; import { Result } from '@core/shared/domain/Result'; import type { ApplicationErrorCode } from '@core/shared/errors/ApplicationErrorCode'; import { FeedRepository } from '../../domain/repositories/FeedRepository'; import type { FeedItem } from '../../domain/types/FeedItem'; export interface GetUserFeedParams { driverId: string; limit?: number; } export type GetUserFeedInput = GetUserFeedParams; export interface GetUserFeedResult { items: FeedItem[]; } export type GetUserFeedErrorCode = 'REPOSITORY_ERROR'; export type GetUserFeedApplicationError = ApplicationErrorCode< GetUserFeedErrorCode, { message: string } >; export class GetUserFeedUseCase { constructor( private readonly feedRepository: FeedRepository, private readonly logger: Logger, ) {} async execute( input: GetUserFeedInput, ): Promise> { const { driverId, limit } = input; this.logger.debug('GetUserFeedUseCase.execute started', { driverId, limit }); try { const items = await this.feedRepository.getFeedForDriver(driverId, limit); this.logger.info('GetUserFeedUseCase.execute succeeded', { driverId, itemCount: items.length, }); if (items.length === 0) { this.logger.warn(`No feed items found for driverId: ${driverId}`); } const result: GetUserFeedResult = { items, }; return Result.ok(result); } catch (error) { const err = error instanceof Error ? error : new Error(String(error)); this.logger.error( 'GetUserFeedUseCase.execute failed', err, { input }, ); return Result.err({ code: 'REPOSITORY_ERROR', details: { message: err.message, }, } as GetUserFeedApplicationError); } } }