refactor use cases
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
import type { Logger, UseCaseOutputPort } from '@core/shared/application';
|
||||
import type { Logger } from '@core/shared/application';
|
||||
import { Result } from '@core/shared/application/Result';
|
||||
import type { ApplicationErrorCode } from '@core/shared/errors/ApplicationErrorCode';
|
||||
import type { ITeamMembershipRepository } from '../../domain/repositories/ITeamMembershipRepository';
|
||||
@@ -29,12 +29,16 @@ export class RejectTeamJoinRequestUseCase {
|
||||
private readonly teamRepository: ITeamRepository,
|
||||
private readonly membershipRepository: ITeamMembershipRepository,
|
||||
private readonly logger: Logger,
|
||||
private readonly output: UseCaseOutputPort<RejectTeamJoinRequestResult>,
|
||||
) {}
|
||||
|
||||
async execute(
|
||||
input: RejectTeamJoinRequestInput,
|
||||
): Promise<Result<void, ApplicationErrorCode<RejectTeamJoinRequestErrorCode, { message: string }>>> {
|
||||
): Promise<
|
||||
Result<
|
||||
RejectTeamJoinRequestResult,
|
||||
ApplicationErrorCode<RejectTeamJoinRequestErrorCode, { message: string }>
|
||||
>
|
||||
> {
|
||||
const { teamId, managerId, requestId, reason } = input;
|
||||
|
||||
try {
|
||||
@@ -97,8 +101,6 @@ export class RejectTeamJoinRequestUseCase {
|
||||
status: 'rejected',
|
||||
};
|
||||
|
||||
this.output.present(result);
|
||||
|
||||
this.logger.info('Team join request rejected successfully', {
|
||||
teamId,
|
||||
managerId,
|
||||
@@ -106,7 +108,7 @@ export class RejectTeamJoinRequestUseCase {
|
||||
reason,
|
||||
});
|
||||
|
||||
return Result.ok(undefined);
|
||||
return Result.ok(result);
|
||||
} catch (error) {
|
||||
const err = error instanceof Error ? error : new Error('Unknown error');
|
||||
this.logger.error('Failed to reject team join request', err, {
|
||||
|
||||
Reference in New Issue
Block a user