Files
doneit-web/src/app/module/chat/domain/use-case/socket/socket-message-create-use-case.service.ts
T

42 lines
1.3 KiB
TypeScript
Raw Normal View History

2024-08-02 16:20:26 +01:00
import { Injectable, Input } from '@angular/core';
2024-08-19 16:01:58 +01:00
import { MessageLocalDataSourceService } from '../../../data/repository/message/message-local-data-source.service';
2024-08-08 15:53:00 +01:00
import { TracingType, XTracerAsync } from 'src/app/services/monitoring/opentelemetry/tracer';
import { ParamsValidation } from 'src/app/services/decorators/validate-schema.decorator';
import { MessageOutPutDataDTOSchema } from '../../../data/dto/message/messageOutputDTO';
2024-08-02 16:20:26 +01:00
@Injectable({
providedIn: 'root'
})
export class SocketMessageCreateUseCaseService {
constructor(
private messageLocalDataSourceService: MessageLocalDataSourceService,
) { }
2024-08-08 15:53:00 +01:00
@XTracerAsync({name:'Socket-Message-Create-UseCase', bugPrint: true})
async execute(input: any, tracing?: TracingType) {
ParamsValidation(MessageOutPutDataDTOSchema, input, tracing)
2024-08-02 16:20:26 +01:00
const incomingMessage = {
...input,
2024-08-08 15:53:00 +01:00
sending: false
2024-08-02 16:20:26 +01:00
}
2024-08-08 15:53:00 +01:00
console.log('create message', {incomingMessage});
2024-08-06 11:24:00 +01:00
2024-08-08 15:53:00 +01:00
tracing?.addEvent("Message Create start")
const result = await this.messageLocalDataSourceService.createMessage(incomingMessage)
tracing?.addEvent("Message Create end")
2024-08-02 16:20:26 +01:00
if(result.isOk()) {
} else {
2024-08-08 15:53:00 +01:00
tracing?.addEvent("error while creating message")
tracing.log("error while creating message", {
error: result.error
})
2024-08-02 16:20:26 +01:00
}
}
}