refactor use cases
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
import type { IdentitySessionPort } from '../ports/IdentitySessionPort';
|
||||
import { Result } from '@core/shared/application/Result';
|
||||
import type { ApplicationErrorCode } from '@core/shared/errors/ApplicationErrorCode';
|
||||
import type { UseCaseOutputPort, Logger, UseCase } from '@core/shared/application';
|
||||
import type { Logger, UseCase } from '@core/shared/application';
|
||||
|
||||
export type LogoutInput = {};
|
||||
|
||||
@@ -13,25 +13,23 @@ export type LogoutErrorCode = 'REPOSITORY_ERROR';
|
||||
|
||||
export type LogoutApplicationError = ApplicationErrorCode<LogoutErrorCode, { message: string }>;
|
||||
|
||||
export class LogoutUseCase implements UseCase<LogoutInput, void, LogoutErrorCode> {
|
||||
export class LogoutUseCase implements UseCase<LogoutInput, LogoutResult, LogoutErrorCode> {
|
||||
private readonly sessionPort: IdentitySessionPort;
|
||||
|
||||
constructor(
|
||||
sessionPort: IdentitySessionPort,
|
||||
private readonly logger: Logger,
|
||||
private readonly output: UseCaseOutputPort<LogoutResult>,
|
||||
) {
|
||||
this.sessionPort = sessionPort;
|
||||
}
|
||||
|
||||
async execute(): Promise<Result<void, LogoutApplicationError>> {
|
||||
async execute(): Promise<Result<LogoutResult, LogoutApplicationError>> {
|
||||
try {
|
||||
await this.sessionPort.clearSession();
|
||||
|
||||
const result: LogoutResult = { success: true };
|
||||
this.output.present(result);
|
||||
|
||||
return Result.ok(undefined);
|
||||
return Result.ok(result);
|
||||
} catch (error) {
|
||||
const message =
|
||||
error instanceof Error && error.message
|
||||
|
||||
Reference in New Issue
Block a user