From 813e29731b4b119af98ab83faec7da9b1184acd8 Mon Sep 17 00:00:00 2001 From: wucongxing <815046773@qq.com> Date: Tue, 14 Mar 2023 17:22:08 +0800 Subject: [PATCH] 1 --- app/Controller/CallBackController.php | 54 +++++++-------- app/Model/OrderProductRefund.php | 94 +++++++++++++++++++++++++++ 2 files changed, 121 insertions(+), 27 deletions(-) create mode 100644 app/Model/OrderProductRefund.php diff --git a/app/Controller/CallBackController.php b/app/Controller/CallBackController.php index f02f30f..4bdc94c 100644 --- a/app/Controller/CallBackController.php +++ b/app/Controller/CallBackController.php @@ -449,85 +449,85 @@ class CallBackController extends AbstractController Log::getInstance()->info("微信退款回调数据:" . json_encode($message->toArray(),JSON_UNESCAPED_UNICODE)); if (empty($message['out_trade_no'])){ - Log::getInstance()->info("微信退款回调数据错误"); + Log::getInstance()->info("药品微信退款回调数据处理失败,缺少外部订单号"); return $server->serve(); } - // 验证订单数据 + // 查询药品订单 $params = array(); - $params['inquiry_no'] = $message['out_trade_no']; - $order_inquiry = OrderInquiry::getOne($params); - if (empty($order_inquiry)){ - Log::getInstance()->info("非法订单"); + $params['order_product_no'] = $message['out_trade_no']; + $order_product = OrderProduct::getOne($params); + if (empty($order_product)){ + Db::rollBack(); + Log::getInstance()->info("药品微信退款回调数据处理失败,无订单数据"); return $server->serve(); } // 验证订单状态 - if ($order_inquiry['inquiry_status'] == 1){ - // 问诊订单状态(1:待支付 2:待分配 3:待接诊 4:已接诊 5:已完成 6:已结束 7:已取消) - Log::getInstance()->info("订单状态错误:当前为" . $order_inquiry['inquiry_status']); + if ($order_product['order_product_status'] == 1){ + // 订单状态(1:待支付 2:待发货 3:已发货 4:已签收 5:已取消) + Log::getInstance()->info("药品微信退款回调数据处理失败,订单状态错误:当前为" . $order_product['order_product_status']); return $server->serve(); } - // 验证订单退款状态 - if ($order_inquiry['inquiry_refund_status'] == 3) { - // 问诊订单退款状态(0:无退款 1:申请退款 2:退款中 3:退款成功 4:拒绝退款 5:退款关闭) - Log::getInstance()->info("订单退款状态错误:当前为" . $order_inquiry['inquiry_refund_status']); + if ($order_product['refund_status'] == 3) { + // 商品订单退款状态(0:无退款 1:申请退款 2:退款中 3:退款成功 4:拒绝退款 5:退款关闭) + Log::getInstance()->info("药品微信退款回调数据处理失败,订单退款状态为" . $order_product['refund_status']); return $server->serve(); } // 验证订单支付状态 - if (in_array($order_inquiry['inquiry_pay_status'],[1,3,4,5,6,7])) { + if (in_array($order_product['pay_status'],[1,3,4,5,6,7])) { // 支付状态(1:未支付 2:已支付 3:支付中 4:支付失败 5:支付超时 6:支付关闭 7:已撤销 8:转入退款) - Log::getInstance()->error("队列执行失败原因:订单未支付"); + Log::getInstance()->error("药品微信退款回调数据处理失败:订单未支付"); return $server->serve(); } // 退款状态 if ($message['refund_status'] == "SUCCESS"){ // 退款成功 - $inquiry_refund_status = 3; + $refund_status = 3; }elseif ($message['refund_status'] == "CLOSED"){ // 退款关闭 - $inquiry_refund_status = 5; + $refund_status = 5; }elseif ($message['refund_status'] == "ABNORMAL"){ // 退款异常 - $inquiry_refund_status = 6; + $refund_status = 6; } - if (empty($inquiry_refund_status)){ + if (empty($refund_status)){ // 错误,无退款状态 - Log::getInstance()->error("队列执行失败原因:订单未支付"); + Log::getInstance()->error("药品微信退款回调数据处理失败:订单未支付"); return $this->wxPayErrorReturn("退款状态错误"); } // 修改订单 $data = array(); - $data['inquiry_refund_status'] = $inquiry_refund_status; + $data['refund_status'] = $refund_status; $params = array(); - $params['order_inquiry_id'] = $order_inquiry['order_inquiry_id']; - OrderInquiry::edit($params,$data); + $params['order_product_id'] = $order_product['order_product_id']; + OrderProduct::edit($params,$data); // 修改退款订单 $data = array(); - $data['inquiry_refund_status'] = $inquiry_refund_status; + $data['product_refund_status'] = $refund_status; $data['success_time'] = $message['success_time']; $params = array(); - $params['order_inquiry_id'] = $order_inquiry['order_inquiry_id']; + $params['order_product_id'] = $order_product['order_product_id']; OrderInquiryRefund::edit($params,$data); Db::commit(); } catch (\Exception $e) { // 验证失败 Db::rollBack(); - Log::getInstance()->error("微信支付回调数据验证失败:" . $e->getMessage()); + Log::getInstance()->error("药品微信退款回调数据处理失败:" . $e->getMessage()); return $this->wxPayErrorReturn($e->getMessage()); } - Log::getInstance()->info("微信退款回调处理成功"); + Log::getInstance()->info("药品微信退款回调数据处理成功"); // 发送短信消息 diff --git a/app/Model/OrderProductRefund.php b/app/Model/OrderProductRefund.php new file mode 100644 index 0000000..0c560fd --- /dev/null +++ b/app/Model/OrderProductRefund.php @@ -0,0 +1,94 @@ +first($fields); + } + + /** + * 获取数据-多 + * @param array $params + * @param array $fields + * @return Collection|array + */ + public static function getList(array $params = [], array $fields = ['*']): Collection|array + { + return self::where($params)->get($fields); + } + + /** + * 获取是否存在 + * @param array $params + * @return bool + */ + public static function getExists(array $params): bool + { + return self::where($params)->exists(); + } + + /** + * 获取数量 + * @param array $params + * @return int + */ + public static function getCount(array $params): int + { + return self::where($params)->count(); + } + + /** + * 修改 + * @param array $params + * @param array $data + * @return int + */ + public static function edit(array $params = [], array $data = []): int + { + return self::where($params)->update($data); + } +}