Recharge.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. <?php
  2. namespace app\common\model;
  3. use \think\Db;
  4. /**
  5. * 订单支付模型
  6. */
  7. class Recharge
  8. {
  9. /**
  10. * 支付回调
  11. */
  12. //pc端充值金币
  13. public function rechargepaysucc($orderId,$args){
  14. $order = Db::name('pay_order')->where(array('pay_no'=>$orderId,'status'=>2))->find();
  15. if( $order )
  16. {
  17. $remark = $order['payment_class'] == 'alipay' ? '支付宝' : '微信';
  18. Db::startTrans();
  19. //更新订单状态
  20. $rs = Db::name('pay_order')->where(['id'=>$order['id']])->update(['status'=>1]);
  21. if(!$rs){
  22. Db::rollback();
  23. filePut('[wallet][paySucc] pay_order update fail'.$orderId);
  24. abort(500,'订单更新失败');
  25. }
  26. //先充值
  27. $result = model('Wallet')->lockChangeAccountRemain($args['user_id'],0,'gold',$args['gold'],10, $remark . '金币充值:'.$orderId,'pay_order',$order['id']);
  28. if($result['status']===false)
  29. {
  30. Db::rollback();
  31. filePut('[wallet][paySucc]网银充值入账更新余额失败 recharge money fail'.$orderId.$result['msg']);
  32. abort(500,'网银充值入账 model wallet recharge money fail');
  33. }
  34. Db::commit();
  35. return true;
  36. }else{
  37. filePut('[wallet][paySucc]在线支付订单有误 '.$orderId);
  38. abort(500,'model wallet fail');
  39. return false;
  40. }
  41. }
  42. //app充值金币
  43. public function goldpaysucc($orderId,$args){
  44. $order = Db::name('pay_order')->where(array('pay_no'=>$orderId,'status'=>2))->find();
  45. if( $order )
  46. {
  47. Db::startTrans();
  48. //更新订单状态
  49. $rs = Db::name('pay_order')->where(['id'=>$order['id']])->update(['status'=>1]);
  50. if(!$rs){
  51. Db::rollback();
  52. filePut('[wallet][paySucc] pay_order update fail'.$orderId);
  53. abort(500,'订单更新失败');
  54. }
  55. $remark = $order['payment_class'] == 'alipay' ? '支付宝' : '微信';
  56. //先充值
  57. $result = model('Wallet')->lockChangeAccountRemain($args['user_id'],0,'gold',$args['gold'],10, $remark . '金币充值:'.$orderId,'pay_order',$order['id'],1);
  58. if($result['status']===false)
  59. {
  60. Db::rollback();
  61. filePut('[wallet][paySucc]网银充值入账更新余额失败 recharge money fail'.$orderId.$result['msg']);
  62. abort(500,'网银充值入账 model wallet recharge money fail');
  63. }
  64. //若有上级,给上级返利
  65. if ($args['intro_uid']) {
  66. //获取返利比率
  67. $is_agent = Db::name('user')->where(['id' => $args['intro_uid']])->value('is_agent');
  68. $intro_recharge_rebate_rate = $is_agent ? (int)config('site.h_intro_recharge_rebate_rate') : (int)config('site.intro_recharge_rebate_rate');
  69. if ($intro_recharge_rebate_rate > 0 && $intro_recharge_rebate_rate <= 100) {
  70. //上级获得金额数量
  71. $intro_uid_money = number_format($args['money'] * $intro_recharge_rebate_rate / 100, 2, '.', '');
  72. if ($intro_uid_money > 0) {
  73. $intro_result = model('wallet')->lockChangeAccountRemain($args['intro_uid'],$args['user_id'],'money',$intro_uid_money,65,'邀请人充值奖励:'.$orderId,'pay_order',$order['id']);
  74. if($intro_result['status']===false)
  75. {
  76. Db::rollback();
  77. filePut('[wallet][paySucc]上级返利更新余额失败 recharge money fail'.$orderId.$intro_result['msg']);
  78. abort(500,'上级返利 model wallet recharge money fail');
  79. }
  80. }
  81. }
  82. }
  83. //首充
  84. $first_map = [
  85. 'uid' => $args['user_id'],
  86. // 'pg_id' => $args['pg_id'],
  87. ];
  88. $first_check = Db::name('user_paygold_log')->where($first_map)->find();
  89. if(empty($first_check)){
  90. //首充日志
  91. $first_map['createtime'] = time();
  92. $first_log_id = Db::name('user_paygold_log')->insertGetId($first_map);
  93. if(!$first_log_id){
  94. Db::rollback();
  95. abort(500,'首充赠送失败');
  96. }
  97. //送金币
  98. if(isset($args['first_gold']) && $args['first_gold'] > 0){
  99. $result = model('Wallet')->lockChangeAccountRemain($args['user_id'],0,'gold',$args['first_gold'],14, $remark . '金币充值:'.$orderId,'pay_order',$order['id']);
  100. if($result['status']===false)
  101. {
  102. Db::rollback();
  103. filePut('[wallet][paySucc]网银充值入账更新余额失败 recharge money fail'.$orderId.$result['msg']);
  104. abort(500,'网银充值入账 model wallet recharge money fail');
  105. }
  106. }
  107. //送vip
  108. if(isset($args['first_vipdays']) && $args['first_vipdays'] > 0){
  109. $user_info = Db::name('user_wallet')->where('user_id',$args['user_id'])->lock(true)->find();
  110. if($user_info['vip_endtime'] < time()){
  111. //过期了
  112. $vip_endtime = time() + (intval($args['first_vipdays']) * 86400);
  113. }else{
  114. //追加vip
  115. $vip_endtime = $user_info['vip_endtime'] + (intval($args['first_vipdays']) * 86400);
  116. }
  117. $result = Db::name('user_wallet')->where('user_id',$args['user_id'])->update(['vip_endtime'=>$vip_endtime]);
  118. if($result === false)
  119. {
  120. Db::rollback();
  121. filePut('[wallet][paySucc]网银充值入账更新vip时间失败 recharge money fail'.$orderId);
  122. abort(500,'网银充值入账 model wallet recharge money fail');
  123. }
  124. }
  125. }
  126. //vip充值额外送金币
  127. if(isset($args['vip_gold']) && $args['vip_gold'] > 0){
  128. $result = model('Wallet')->lockChangeAccountRemain($args['user_id'],0,'gold',$args['vip_gold'],101, $remark . '金币充值:'.$orderId,'pay_order',$order['id']);
  129. if($result['status']===false)
  130. {
  131. Db::rollback();
  132. filePut('[wallet][paySucc]网银充值入账更新余额失败 recharge money fail'.$orderId.$result['msg']);
  133. abort(500,'网银充值入账 model wallet recharge money fail');
  134. }
  135. }
  136. Db::commit();
  137. return true;
  138. }else{
  139. filePut('[wallet][paySucc]在线支付订单有误 '.$orderId);
  140. abort(500,'model wallet fail');
  141. return false;
  142. }
  143. }
  144. //app充值vip
  145. public function vippaysucc($orderId,$args){
  146. $order = Db::name('pay_order')->where(array('pay_no'=>$orderId,'status'=>2))->find();
  147. if( $order )
  148. {
  149. Db::startTrans();
  150. //更新订单状态
  151. $rs = Db::name('pay_order')->where(['id'=>$order['id']])->update(['status'=>1]);
  152. if(!$rs){
  153. Db::rollback();
  154. filePut('[wallet][paySucc] pay_order update fail'.$orderId);
  155. abort(500,'订单更新失败');
  156. }
  157. //先充值
  158. $user_info = Db::name('user_wallet')->where('user_id',$args['user_id'])->lock(true)->find();
  159. if($user_info['vip_endtime'] < time()){
  160. //过期了
  161. $vip_endtime = time() + (intval($args['days']) * 86400);
  162. }else{
  163. //追加vip
  164. $vip_endtime = $user_info['vip_endtime'] + (intval($args['days']) * 86400);
  165. }
  166. $update_data = [
  167. 'vip_endtime'=>$vip_endtime,
  168. 'vip_level' =>$args['vip_level'], //修改等级,同级不影响,向上立刻改,向下不允许
  169. 'pay_money' => bcadd($user_info['pay_money'], $args['money'], 2)
  170. ];
  171. $result = Db::name('user_wallet')->where('user_id',$args['user_id'])->update($update_data);
  172. if($result === false)
  173. {
  174. Db::rollback();
  175. filePut('[wallet][paySucc]网银充值入账更新vip时间失败 recharge money fail'.$orderId);
  176. abort(500,'网银充值入账 model wallet recharge money fail');
  177. }
  178. if ($args['gold_num'] > 0) {
  179. //赠送金币
  180. $wallet_rs = model('wallet')->lockChangeAccountRemain($args['user_id'], 0,'gold', $args['gold_num'], 17, '开通会员赠送金币');
  181. if ($wallet_rs['status'] === false) {
  182. Db::rollback();
  183. filePut('[wallet][paySucc] gold update fail' . $orderId);
  184. abort(500, '赠送金币更新失败');
  185. }
  186. }
  187. //tag任务赠送金币
  188. //开通VIP 50金币
  189. // $task_rs = \app\common\model\TaskLog::tofinish($args['user_id'],9);
  190. // if($task_rs === false){
  191. // Db::rollback();
  192. // $this->error('完成任务赠送奖励失败');
  193. // }
  194. Db::commit();
  195. return true;
  196. }else{
  197. filePut('[wallet][paySucc]在线支付订单有误 '.$orderId);
  198. abort(500,'model wallet fail');
  199. return false;
  200. }
  201. }
  202. }