У меня есть список электронных писем, для каждого из которых я посмотрю его в таблице электронной почты, чтобы увидеть, существует ли это письмо. если это произойдет, больше ничего не сделаю, я выдам ошибку. вот мой код;
def lookupEmailStatus(email: EmailAddress, requestId: RequestId)(
implicit ec: ExecutionContext): HttpServiceResult[List[EmailStatusDTO]] = {
emailDatabase
.getEmailStatusByEmail(email, requestId)
.map(
l =>
if (l.isEmpty) {
logger.error(
LoggingMessage(
requestId,
s"Email status not found by ${email.email} failed"))
EntityNotFound(s"${email.email}", requestId)
} else {
l
}
)
.leftMap[HttpError] {
case e =>
logger.error(
LoggingMessage(
requestId,
s"Retrieve email status by ${email.email} failed"))
DatabaseError(e.message, requestId)
}
}
когда я запускал код получил ошибку:
Error:(57, 27) type mismatch;
found : cats.data.EitherT[model.HttpError,Product with Serializable]
required: model.HttpServiceResult[List[EmailStatusDTO]]
(which expands to) cats.data.EitherT[model.HttpError,List[EmailStatusDTO]]
.leftMap[HttpError] {
если я уберу метод .map (..), он будет работать нормально, но это не то, что я хочу:
def lookupEmailStatus(email: EmailAddress, requestId: RequestId)(
implicit ec: ExecutionContext): HttpServiceResult[List[EmailStatusDTO]] = {
emailDatabase
.getEmailStatusByEmail(email, requestId)
.leftMap[HttpError] {
case e =>
logger.error(
LoggingMessage(
requestId,
s"Retrieve email status by ${email.email} failed"))
DatabaseError(e.message, requestId)
}
}
вот определения типов:
type HttpServiceResult[A] = ServiceResult[HttpError, A]
type ServiceResult[Err, A] = EitherT[Future, Err, A]