Используйте простой оператор return
, так как async
функция возвращает Promise по умолчанию. Таким образом, ваше возвращаемое значение равно разрешению значения, а выбрасывание - отклонение
try {
await CacheController.getInstance().saveDetailsWrapper(saveDetails,
_passedParams);
return {
getPaymentHistoryResponse: paymentHistoryDetails
};
} catch (err) {
throw {
getPaymentHistoryResponse: err
};
}
Код не достигнет последней строки, потому что есть оператор return в try и catch.
Это как ты пишешь
if(check) {... return 1}
else {return 2}
return 3
И спросите, почему 3 никогда не возвращается
Обновление
Я понял :) Так что async / await дает вам возможность писать асинхронный код синхронно. Если вы хотите сделать запрос без блокировки другого кода, просто используйте простой синтаксис then
:
private combineData(data: any, request: any): any {
const details: any = [];
const indexIDs = this.indexIDs;
delete data.header.IndexOfRequestThatFailed;
const returnValue = {
"header": {
"statusDesc": "",
"statusCode": "",
"refID": ""
},
"details": details
}
as IGetPaymentHistoryResponse;
const paymentHistoryDetails = {
header: returnValue.header,
details: returnValue.details
};
// saving details to cache
const saveDetails = {}
as ICacheRequest;
saveDetails.cacheobject = paymentHistoryDetails;
saveDetails.cachetype = "CombinedPaymentHistoryCache";
saveDetails.key =
request.body.getPaymentHistoryRequest.header.serviceContext.tokenID;
const _passedParams: ILogParams = {}
as ILogParams;
_passedParams.refId =
request.body.getPaymentHistoryRequest.header.serviceContext.refID;
_passedParams.sessionId =
request.body.getPaymentHistoryRequest.header.serviceContext.tokenID;
_passedParams.opname = "getPaymentHistory";
_passedParams.starttime = moment().toString();
_passedParams.endtime = "";
// do not return here to return on the last line
CacheController.getInstance().saveDetailsWrapper(saveDetails, _passedParams).then(response => ..., err => ...);
return returnValue;
}