package com.ynxbd.common.service; import com.alibaba.fastjson.JSONObject; import com.ynxbd.common.action.pay.PQREnum; import com.ynxbd.common.bean.enums.MerchantEnum; import com.ynxbd.common.bean.pay.PayCasebook; import com.ynxbd.common.dao.CasebookDao; import com.ynxbd.common.helper.common.CodeHelper; import com.ynxbd.common.helper.common.DateHelper; import com.ynxbd.common.helper.common.JsonHelper; import com.ynxbd.common.helper.xbd.XBDEnum; import com.ynxbd.common.helper.xbd.XBDHttpHelper; import com.ynxbd.common.result.Result; import com.ynxbd.common.result.ResultEnum; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.ObjectUtils; import java.math.BigDecimal; @Slf4j public class CasebookService { public Result placeOrder(MerchantEnum merchantEnum, String ip, String openid, String patientId, String treatNum, String totalFee,String applyId,String getWay, String useToName) { if (openid == null || patientId == null || totalFee == null) { return Result.error(ResultEnum.PARAM_IS_DEFECT); } if (new BigDecimal(totalFee).compareTo(BigDecimal.ZERO)==0) { return Result.error(ResultEnum.PAY_MONEY_IS_ZERO); } if(isPay(patientId,treatNum,applyId,getWay,useToName)){ log.info("{} [病历]订单已支付 applyId-{}, patientId={},treatNum-{},getWay-{},useToName-{}", merchantEnum.NAME, applyId,patientId,treatNum,getWay,useToName); return Result.error(ResultEnum.APPLY_REPEAT); } String outTradeNo = CodeHelper.getOutTradeNo(merchantEnum); if (!isSaveCasebookInfo(patientId,treatNum,applyId,new BigDecimal(totalFee),outTradeNo,getWay,useToName)) { log.info("{} [病历]下单信息存储失败 applyId-{}, patientId={},treatNum-{}", merchantEnum.NAME, applyId,patientId,treatNum); return Result.error(ResultEnum.SPECIFIED_QUESTIONED_USER_NOT_EXIST); } String body = "病历复印缴费 住院号="+treatNum; JSONObject respJson = PayService.createOrder(merchantEnum, openid, patientId, totalFee, outTradeNo, PQREnum.CASEBOOK.CODE, ip, body); if (respJson == null) { return Result.error(ResultEnum.PAY_ERROR); // 支付异常 } return Result.success(respJson); } public boolean isExit(String patientId, String treatNum,String getWay, String useToName){ if (patientId == null||treatNum == null) { log.info("[病历复印]唤起支付 存入 applyId失败,patientId-{},treatNum-{},",patientId,treatNum); return false; } return new CasebookDao().selectIsExit(patientId,treatNum,getWay,useToName); } /** * @param patientId 患者id * @param treatNum 住院号 * @return 是否成功 */ public boolean isSaveCasebookInfo(String patientId, String treatNum, String applyId,BigDecimal totalFee,String outTradeNo,String getWay, String useToName) { if (patientId == null||treatNum == null) { log.info("[病历复印]唤起支付 存入 applyId失败,patientId-{},treatNum-{},totalFee-{}",patientId,treatNum,totalFee); return false; } return new CasebookDao().updatePayStatePre(patientId,treatNum,applyId,totalFee,outTradeNo,getWay,useToName); } public boolean isPay(String patientId, String treatNum, String applyId,String getWay, String useToName){ if (patientId == null||treatNum == null) { log.info("[病历复印]查重失败,patientId-{},treatNum-{},applyId-{}",patientId,treatNum,applyId); return false; } return new CasebookDao().selectIsPay(patientId,treatNum,applyId,getWay,useToName); } /** * 新增预约记录首次存入 * @param casebook 病历订单信息 * @return 是否成功 */ public boolean addApply(PayCasebook casebook,String openId,String patientId){ if (casebook == null) { log.info("casebook is null"); return false; } return new CasebookDao().insert(casebook,openId,patientId); } public void payNotify(MerchantEnum merchantEnum, String openid, BigDecimal totalFee, String outTradeNo, String bankTransNo, String payInfo) { CasebookDao casebookDao = new CasebookDao(); PayCasebook order = casebookDao.selectByOutTradeNo(outTradeNo); String casebookId = order.getApplyId(); if (ObjectUtils.isEmpty(casebookId)) { log.error("[病历]病历申请ID缺失 outTradeNo={}, bankTransNo={}, casebookId={}", outTradeNo, bankTransNo, casebookId); return; } Integer payStates = order.getPayStatus(); if (payStates == 0) { log.error("[病历]订单已支付 outTradeNo={}, bankTransNo={}, casebookId={}", outTradeNo, bankTransNo, casebookId); return; } if (!casebookDao.updatePayStateOk(outTradeNo, bankTransNo)) { log.info("[病历]修改支付状态失败 outTradeNo={}, bankTransNo={}, casebookId={}", outTradeNo, bankTransNo, casebookId); } log.info("[病历] 开始回调支付状态 borrowNo-{}",casebookId); String jsonString = XBDHttpHelper.ExecMethodGet(XBDEnum.BLSM_Appointment_SetISPay.Name, params->{ params.put("borrowNo",casebookId); params.put("payDateTime", DateHelper.getCurDateTime()); }); log.info("[病历]回调返回 resp={}", jsonString); String code = JsonHelper.parseObject(jsonString).getString("Code"); if (code==null) { if (!casebookDao.updateNotifyOk(outTradeNo)) { log.info("[病历]更新订单信息失败 outTradeNo={}, bankTransNo={}, casebookId={}", outTradeNo, bankTransNo, casebookId); } return; } String message = JsonHelper.parseObject(jsonString).getString("Msg"); log.info("[病历]回调失败 code={}, message={}", code, message); if (!casebookDao.updateNotifyErr(outTradeNo, message)) { log.info("[病历]更新订单错误信息失败 outTradeNo={}, code={}, message={}", outTradeNo, code, message); } } }