OrderLib.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <?php
  2. declare (strict_types=1);
  3. // +----------------------------------------------------------------------
  4. // | [ WE CAN DO IT MORE SIMPLE ]
  5. // +----------------------------------------------------------------------
  6. // | Copyright (c) 2018-2020 rights reserved.
  7. // +----------------------------------------------------------------------
  8. // | 支付结算
  9. // +----------------------------------------------------------------------
  10. // | Date: 2020-08-25 17:23
  11. // +----------------------------------------------------------------------
  12. namespace app\lib;
  13. use app\model\api\PayTrade;
  14. use app\model\api\Order;
  15. use app\model\api\ShowTemplateOrder;
  16. use app\model\api\UserShowTemplate;
  17. use app\model\api\OrderInfo;
  18. use app\model\api\User as UserModel;
  19. use app\model\api\UserDetail as UserDetailModel;
  20. use app\model\api\Sys as SysModel;
  21. use think\facade\Db;
  22. class OrderLib
  23. {
  24. /**
  25. * 支付反馈
  26. * @param $orderId
  27. * @return bool|string
  28. * @throws \think\db\exception\DataNotFoundException
  29. * @throws \think\db\exception\DbException
  30. * @throws \think\db\exception\ModelNotFoundException
  31. */
  32. public function orderPay($payOn,$payDataInfo="")
  33. {
  34. $payTradeData = (new PayTrade)->where('pay_no', $payOn)->find();
  35. if (empty($payTradeData)) {
  36. return false;
  37. }
  38. //已支付
  39. if ($payTradeData['status'] == 1) {
  40. return false;
  41. }
  42. $userData = (new UserModel)->where('uid', $payTradeData['uid'])->find();
  43. if(empty($userData)){
  44. return false;
  45. }
  46. //处理支付成功
  47. PayTrade::beginTrans();
  48. try {
  49. (new PayTrade)->where('id', $payTradeData['id'])->update(['status' => 1, 'pay_time' => time(),'pay_json' => $payDataInfo]);
  50. //购买模板
  51. if($payTradeData["type"]=="temp"){
  52. $tempOrderData = (new ShowTemplateOrder)->where("id",$payTradeData['o_id'])->find();
  53. if(empty($tempOrderData)){
  54. PayTrade::rollbackTrans();
  55. return false;
  56. }
  57. (new ShowTemplateOrder)->where("id",$payTradeData['o_id'])->update(['status' => 1, 'pay_time' => time()]);
  58. //验证用户是否已经购买过当前模板
  59. $count = (new UserShowTemplate)->where("uid",$userData['uid'])->where("show_template_id",$tempOrderData["show_template_id"])->count();
  60. if($count<=0){
  61. (new UserShowTemplate)->insert([
  62. "uid" => $tempOrderData["uid"],
  63. "show_template_id" => $tempOrderData["show_template_id"],
  64. "start_time" => time(),
  65. "end_time" => time()+100*365*24*60*60,//100年
  66. "is_default" => 0,
  67. ]);
  68. }
  69. //添加消费记录
  70. if(in_array($payTradeData["pay_type"],["alipay","wxpay"])){
  71. (new UserDetailModel)->consumeLog($payTradeData['uid'],$payTradeData["money"],"show_temp_buy","购买名片模板");
  72. }
  73. PayTrade::commitTrans();
  74. return true;
  75. }
  76. //商城订单
  77. if($payTradeData["type"]=="shop"){
  78. (new Order)->where("id",$payTradeData['o_id'])->update(['status' => 1, 'pay_time' => time()]);
  79. PayTrade::commitTrans();
  80. return true;
  81. }
  82. PayTrade::commitTrans();
  83. } catch (DbException $dbException) {
  84. PayTrade::rollbackTrans();
  85. return false;
  86. }
  87. //后台管理人员支付直接返回
  88. if($payTradeData["pay_type"]=="system"){
  89. return true;
  90. }
  91. return true;
  92. }
  93. }