wip
This commit is contained in:
@@ -1,29 +1,30 @@
|
||||
import type { ITeamRepository } from '../../domain/repositories/ITeamRepository';
|
||||
import type { ITeamMembershipRepository } from '../../domain/repositories/ITeamMembershipRepository';
|
||||
import type {
|
||||
GetDriverTeamQueryParamsDTO,
|
||||
GetDriverTeamQueryResultDTO,
|
||||
} from '../dto/TeamCommandAndQueryDTO';
|
||||
import type { IDriverTeamPresenter } from '../presenters/IDriverTeamPresenter';
|
||||
|
||||
export class GetDriverTeamQuery {
|
||||
/**
|
||||
* Use Case for retrieving a driver's team.
|
||||
* Orchestrates domain logic and delegates presentation to the presenter.
|
||||
*/
|
||||
export class GetDriverTeamUseCase {
|
||||
constructor(
|
||||
private readonly teamRepository: ITeamRepository,
|
||||
private readonly membershipRepository: ITeamMembershipRepository,
|
||||
public readonly presenter: IDriverTeamPresenter,
|
||||
) {}
|
||||
|
||||
async execute(params: GetDriverTeamQueryParamsDTO): Promise<GetDriverTeamQueryResultDTO | null> {
|
||||
const { driverId } = params;
|
||||
|
||||
async execute(driverId: string): Promise<boolean> {
|
||||
const membership = await this.membershipRepository.getActiveMembershipForDriver(driverId);
|
||||
if (!membership) {
|
||||
return null;
|
||||
return false;
|
||||
}
|
||||
|
||||
const team = await this.teamRepository.findById(membership.teamId);
|
||||
if (!team) {
|
||||
return null;
|
||||
return false;
|
||||
}
|
||||
|
||||
return { team, membership };
|
||||
this.presenter.present(team, membership, driverId);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user