RefundOrderService.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. <?php
  2. /**
  3. *
  4. * @file:RefundOrderSeivce.php
  5. * @Date: 2023/5/29
  6. * @Time: 09:48
  7. */
  8. namespace Modules\OrderRefund\Services;
  9. use App\Libs\Pay\Palmpay;
  10. use Catch\Exceptions\FailedException;
  11. use Illuminate\Support\Facades\DB;
  12. use Modules\Channel\Services\Order\OrderService;
  13. use Modules\Manage\Models\Miniprogram;
  14. use Modules\OrderRefund\Models\OrdersRefundVerify;
  15. use Modules\User\Models\User;
  16. class RefundOrderService extends BaseServices
  17. {
  18. /**
  19. * 退款订单查询
  20. * name: orderList
  21. * @param array $param
  22. * date 2023/05/29 09:58
  23. */
  24. public static function orderList(array $param, $isAll = false)
  25. {
  26. $list = self::listQuery($param);
  27. $list->select("orders_refund_verify.id","orders_refund_verify.uid","orders_refund_verify.pt_verify_remark","orders_refund_verify.sh_verify_remark", "orders_refund_verify.sh_verify_status","orders_refund_verify.pt_verify_status","orders_refund_verify.pay_at","orders_refund_verify.refund_status","orders_refund_verify.refund_no","orders_refund_verify.trade_no","orders_refund_verify.refund_price","orders_refund_verify.order_price","orders.puser_id","orders.promotion_id","orders.miniprogram_id","orders.created_at as order_created_at","orders.ranse_created_at","promotions.name as promotion_name",'orders.order_type',"orders.pay_merchant_source");
  28. if ($isAll){
  29. $list = $list->get();
  30. }else{
  31. $list = $list->paginate(getProp($param,'limit',15));
  32. }
  33. if (!$list->isEmpty()) {
  34. $types = array_column(OrderService::getOrderType(), null, 'value');
  35. $verifTxt = self::getVerifyText();
  36. foreach ($list as $val){
  37. $val->username = $val->user_id > 0 ? User::where('id', $val->user_id)->value('username') : "";
  38. $val->company_name = "-";
  39. $val->play_name = '-';
  40. $val->xcx_name = '-';
  41. $company = Miniprogram::where('id', $val->miniprogram_id)->first();
  42. if ($company) {
  43. $val->company_name = $val->puser_id > 0 ? $company->company() : "-";
  44. $val->play_name = $company->play_name;
  45. $val->xcx_name = $company->name;
  46. }
  47. if (!$val->promotion_name){
  48. $val->promotion_name = "-";
  49. }
  50. $val->tip_text = $types[$val->order_type]['name'] ?? "-";
  51. $val->pay_name = '微信支付';
  52. $val->pt_verify_status_text = $verifTxt[$val->pt_verify_status]['name'] ?? "-";
  53. if ($val->puser_id > 0){
  54. $val->sh_verify_status_text = $verifTxt[$val->sh_verify_status]['name'] ?? "-";
  55. $val->can_pay = $val->sh_verify_status == 1 && $val->pt_verify_status == 1 ? 1: 0;
  56. }else{
  57. $val->sh_verify_status_text = "-";
  58. $val->can_pay = $val->pt_verify_status == 1 ? 1: 0;
  59. }
  60. $val->status_text = $val->status == 1 ? "已退款": "已付款";
  61. }
  62. }
  63. return $list;
  64. }
  65. protected static function getVerifyText(){
  66. return [
  67. ['value' => 0,'name' => "待审核"],
  68. ['value' => 1,'name' => "审核通过"],
  69. ['value' => 2,'name' => "审核不通过"],
  70. ];
  71. }
  72. /**
  73. * 构建查询语句
  74. * name: listQuery
  75. * @param array $param
  76. * date 2023/05/29 09:59
  77. */
  78. private static function listQuery(array $param)
  79. {
  80. $sql = OrdersRefundVerify::query()->leftJoin("orders",'orders_refund_verify.order_id','=','orders.id')->leftJoin('promotions','orders.promotion_id','=','promotions.id')
  81. ->where('orders_refund_verify.refund_status', getProp($param,'refund_status',0));
  82. if (!empty(getProp($param, 'user_id'))) {
  83. $sql->where('orders.user_id', $param['user_id']);
  84. }
  85. // 公司查询
  86. if (!empty(getProp($param, 'puser_id'))) {
  87. $sql->where('orders.puser_id', $param['puser_id']);
  88. }
  89. // 小程序
  90. if (!empty(getProp($param, 'miniprogram_id'))) {
  91. $sql->where('orders.miniprogram_id', $param['miniprogram_id']);
  92. }
  93. // 推广id
  94. if (!empty(getProp($param, 'promotion_id'))) {
  95. $sql->where('orders.promotion_id', $param['promotion_id']);
  96. }
  97. // 状态查询
  98. if (!empty(getProp($param, 'status'))) {
  99. $sql->where('orders.status', $param['status']);
  100. }
  101. // 充值项类型
  102. if (!empty(getProp($param, 'order_type'))) {
  103. $sql->where('orders.order_type', $param['order_type']);
  104. }
  105. // 用户
  106. if (!empty(getProp($param, 'uid'))) {
  107. $sql->where('orders.uid', $param['uid']);
  108. }
  109. // 订单号查询
  110. if (!empty(getProp($param, 'trade_no'))) {
  111. $sql->where('orders.trade_no', "like", "%" . $param['trade_no'] . "%");
  112. // $sql->where('orders.trade_no', $param['trade_no']);
  113. }
  114. if (getProp($param,'created_at_start','')){
  115. $sql->where('orders.created_at',">=".$param['created_at_start']);
  116. }
  117. if (getProp($param,'created_at_start','')){
  118. $end =$param['created_at_end'];
  119. if ($end == getProp($param,'created_at_start','')){
  120. $end = date("Y-m-d",strtotime($end)) . " 23:59:59";
  121. }
  122. $sql->where('orders.created_at',"<=".$end);
  123. }
  124. if (getProp($param,'checked_at_start','')){
  125. $sql->where('orders_refund_verify.checked_at',">=".$param['checked_at_start']);
  126. }
  127. if (getProp($param,'checked_at_start','')){
  128. $end =$param['checked_at_end'];
  129. if ($end == getProp($param,'checked_at_start','')){
  130. $end = date("Y-m-d",strtotime($end)) . " 23:59:59";
  131. }
  132. $sql->where('orders_refund_verify.checked_at',"<=".$end);
  133. }
  134. return $sql;
  135. }
  136. /**
  137. * 申请退款
  138. * name: applyRefund
  139. * @param $param
  140. * $param [
  141. * "order_id" => 1, // 订单id
  142. * 'price' => 1, // 金额
  143. * 'create_user_id' => 1, // 申请人id
  144. * ];
  145. * date 2023/05/29 11:46
  146. */
  147. public static function applyRefund($param)
  148. {
  149. $order = DB::table('orders')->where('id',$param['order_id'])->first();
  150. if (empty($order)){
  151. self::throwErrMsg('订单不存在!');
  152. }
  153. if ($order->status != "PAID"){
  154. self::throwErrMsg('此订单未付款,无需退款!');
  155. }
  156. if ($param['price'] > $order->price){
  157. self::throwErrMsg('退款金额不能超过支付金额!');
  158. }
  159. $data = [
  160. 'create_user_id' => $param['create_user_id'],
  161. 'refund_no' => self::CreateRefundNo("RE"),
  162. 'order_id' => $order->id,
  163. 'puser_id' => $order->puser_id,
  164. 'user_id' => $order->user_id,
  165. 'uid' => $order->uid,
  166. 'order_price' => $order->price,
  167. 'trade_no' => $order->trade_no,
  168. 'third_orderid' => $order->third_orderid,
  169. 'refund_price' => $param['price'],
  170. ];
  171. if (OrdersRefundVerify::updateOrCreate(['order_id' => $data['order_id']],$data)){
  172. return '操作成功';
  173. }
  174. return '操作失败';
  175. }
  176. /**
  177. * 生成退款单号
  178. * name: CreateRefundNo
  179. * date 2023/05/29 13:46
  180. */
  181. private static function CreateRefundNo($prefix = '', $time = 0)
  182. {
  183. $time = $time == 0 ? time() : $time;
  184. $billno = $prefix . date('YmdHis', $time) . random(4, true);
  185. if (!empty($table)) {
  186. while (1) {
  187. $count = OrdersRefundVerify::where('refund_no',$billno)->value('id');
  188. if (empty($count)) {
  189. break;
  190. }
  191. $billno = $prefix . date('YmdHis') . random(4, true);
  192. }
  193. }
  194. return $billno;
  195. }
  196. /**
  197. * 更新审核状态
  198. * name: updateRefundVerify
  199. * @param $refundId 退款id
  200. * @param array $param
  201. * @param int $isPlatform 是否平台 1是 0否
  202. * @return string
  203. * date 2023/05/29 16:43
  204. */
  205. public static function updateRefundVerify($refundId, array $param, $isPlatform = 0)
  206. {
  207. $info = OrdersRefundVerify::where('id',$refundId)->first();
  208. if(!$info){
  209. self::throwErrMsg("退款申请不存在");
  210. }
  211. if ($isPlatform ==0 && $info->puser_id < 1){
  212. self::throwErrMsg("无需商户审核");
  213. }
  214. if ($isPlatform == 1 && $info->pt_verify_status == 1){
  215. self::throwErrMsg("已审核通过无需再次操作");
  216. }else if ($isPlatform ==0 && $info->sh_verify_status == 1){
  217. self::throwErrMsg("已审核通过无需再次操作");
  218. }
  219. $res = OrdersRefundVerify::where('id',$refundId)->update($param);
  220. return $res ? "操作成功" : "操作失败";
  221. }
  222. /**
  223. * 退款操作
  224. * name: payToUser
  225. * @param mixed $refundId 申请id
  226. * @param array $option 操作人信息
  227. * date 2023/05/29 16:53
  228. */
  229. public static function payToUser(mixed $refundId, array $option)
  230. {
  231. $info = OrdersRefundVerify::where('id',$refundId)->first();
  232. if(!$info){
  233. self::throwErrMsg("退款申请不存在");
  234. }
  235. if($info->status == 1){
  236. self::throwErrMsg("已退款,无需再次操作");
  237. }
  238. if ($info->puser_id > 0){
  239. if ($info->pt_verify_status != 1 || $info->sh_verify_status != 1){
  240. self::throwErrMsg("双方审核未全部通过,不能退款");
  241. }
  242. }else{
  243. if ($info->pt_verify_status != 1 ){
  244. self::throwErrMsg("审核未通过,不能退款");
  245. }
  246. }
  247. DB::beginTransaction();
  248. try {
  249. $payParam = [
  250. 'third_orderid' => $info->third_orderid,
  251. 'price' => $info->order_price,
  252. 'refund_no' => $info->refund_no,
  253. 'refund_price' => $info->refund_price,
  254. ];
  255. $appid = DB::table(getMiniProgramTableName(1,'users'))->where('id',$info->uid)->value('appid');
  256. $resut = (new Palmpay(['subAppid'=>$appid]))->refund($payParam);
  257. if (!$resut['status']){
  258. self::throwErrMsg($resut['msg']);
  259. }
  260. $param = [
  261. 'refund_status' => 1,
  262. 'pay_at' => get_date(),
  263. 'pay_op_user' => $option,
  264. ];
  265. OrdersRefundVerify::where('id',$refundId)->update($param);
  266. DB::commit();
  267. return "操作成功";
  268. }catch (\Exception $exception){
  269. DB::rollBack();
  270. self::throwErrMsg($exception->getMessage());
  271. }
  272. self::throwErrMsg("操作失败");
  273. }
  274. }