64 lines
2.7 KiB
TypeScript
64 lines
2.7 KiB
TypeScript
import type { ITeamMembershipRepository } from '../../domain/repositories/ITeamMembershipRepository';
|
|
import type { IDriverRepository } from '../../domain/repositories/IDriverRepository';
|
|
import type { IImageServicePort } from '../ports/IImageServicePort';
|
|
import type {
|
|
ITeamMembersPresenter,
|
|
TeamMembersResultDTO,
|
|
TeamMembersViewModel,
|
|
} from '../presenters/ITeamMembersPresenter';
|
|
import type { UseCase } from '@core/shared/application';
|
|
import type { Logger } from '@core/shared/application';
|
|
|
|
/**
|
|
* Use Case for retrieving team members.
|
|
* Orchestrates domain logic and delegates presentation to the presenter.
|
|
*/
|
|
export class GetTeamMembersUseCase
|
|
implements UseCase<{ teamId: string }, TeamMembersResultDTO, TeamMembersViewModel, ITeamMembersPresenter>
|
|
{
|
|
constructor(
|
|
private readonly membershipRepository: ITeamMembershipRepository,
|
|
private readonly driverRepository: IDriverRepository,
|
|
private readonly imageService: IImageServicePort,
|
|
private readonly logger: Logger,
|
|
// Kept for backward compatibility; callers must pass their own presenter.
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
public readonly presenter: ITeamMembersPresenter,
|
|
) {}
|
|
|
|
async execute(input: { teamId: string }, presenter: ITeamMembersPresenter): Promise<void> {
|
|
this.logger.debug(`Executing GetTeamMembersUseCase for teamId: ${input.teamId}`);
|
|
presenter.reset();
|
|
|
|
try {
|
|
const memberships = await this.membershipRepository.getTeamMembers(input.teamId);
|
|
this.logger.info(`Found ${memberships.length} memberships for teamId: ${input.teamId}`);
|
|
|
|
const driverNames: Record<string, string> = {};
|
|
const avatarUrls: Record<string, string> = {};
|
|
|
|
for (const membership of memberships) {
|
|
this.logger.debug(`Processing membership for driverId: ${membership.driverId}`);
|
|
const driver = await this.driverRepository.findById(membership.driverId);
|
|
if (driver) {
|
|
driverNames[membership.driverId] = driver.name;
|
|
} else {
|
|
this.logger.warn(`Driver with ID ${membership.driverId} not found while fetching team members for team ${input.teamId}.`);
|
|
}
|
|
avatarUrls[membership.driverId] = this.imageService.getDriverAvatar(membership.driverId);
|
|
}
|
|
|
|
const dto: TeamMembersResultDTO = {
|
|
memberships,
|
|
driverNames,
|
|
avatarUrls,
|
|
};
|
|
|
|
presenter.present(dto);
|
|
this.logger.info(`Successfully presented team members for teamId: ${input.teamId}`);
|
|
} catch (error) {
|
|
this.logger.error(`Error in GetTeamMembersUseCase for teamId: ${input.teamId}, error: ${error instanceof Error ? error.message : String(error)}`);
|
|
throw error;
|
|
}
|
|
}
|
|
} |