UserExtractController.php 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. <?php
  2. namespace app\api\controller\user;
  3. use app\admin\model\system\SystemConfig;
  4. use app\models\store\StoreOrder;
  5. use app\models\user\User;
  6. use app\models\user\UserBill;
  7. use app\models\user\UserExtract;
  8. use app\models\user\UserTransfer;
  9. use app\Request;
  10. use crmeb\services\UtilService;
  11. /**
  12. * 提现类
  13. * Class UserExtractController
  14. * @package app\api\controller\user
  15. */
  16. class UserExtractController
  17. {
  18. /**
  19. * 提现银行
  20. * @param Request $request
  21. * @return mixed
  22. */
  23. public function bank(Request $request)
  24. {
  25. $user = $request->user();
  26. $broken_time = intval(sys_config('extract_time'));
  27. $search_time = time() - 86400 * $broken_time;
  28. //可提现佣金
  29. //返佣 +
  30. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  31. ->where('add_time', '>', $search_time)
  32. ->where('pm', 1)
  33. ->sum('number');
  34. //退款退的佣金 -
  35. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  36. ->where('add_time', '>', $search_time)
  37. ->where('pm', 0)
  38. ->sum('number');
  39. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  40. if ($data['broken_commission'] < 0)
  41. $data['broken_commission'] = 0;
  42. // return $data;
  43. $data['brokerage_price'] = $user['brokerage_price'];
  44. //可提现佣金
  45. $data['commissionCount'] = $data['brokerage_price'] - $data['broken_commission'];
  46. $extractBank = sys_config('user_extract_bank') ?? []; //提现银行
  47. $extractBank = str_replace("\r\n", "\n", $extractBank);//防止不兼容
  48. $data['extractBank'] = explode("\n", is_array($extractBank) ? (isset($extractBank[0]) ? $extractBank[0] : $extractBank) : $extractBank);
  49. $data['minPrice'] = sys_config('user_extract_min_price');//提现最低金额
  50. $data['commission'] = sys_config('commission',10);//提现手续费
  51. return app('json')->successful($data);
  52. }
  53. /**
  54. * 提现申请
  55. * @param Request $request
  56. * @return mixed
  57. */
  58. public function cash(Request $request)
  59. {
  60. $extractInfo = UtilService::postMore([
  61. ['alipay_code', ''],
  62. ['extract_type', ''],
  63. ['money', 0],
  64. ['name', ''],
  65. ['bankname', ''],
  66. ['cardnum', ''],
  67. ['weixin', ''],
  68. ['balance_type',0],
  69. ], $request);
  70. if (!preg_match('/^(([1-9][0-9]*)|(([0]\.\d{1,2}|[1-9][0-9]*\.\d{1,2})))$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  71. //提现设置最低金额
  72. if($extractInfo['money'] < sys_config('user_extract_min_price')) return app('json')->fail('金额小于最低提现金额');
  73. $user = $request->user();
  74. $broken_time = intval(sys_config('extract_time'));
  75. $search_time = time() - 86400 * $broken_time;
  76. //可提现佣金
  77. //返佣 +
  78. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  79. ->where('add_time', '>', $search_time)
  80. ->where('pm', 1)
  81. ->sum('number');
  82. //退款退的佣金 -
  83. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  84. ->where('add_time', '>', $search_time)
  85. ->where('pm', 0)
  86. ->sum('number');
  87. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  88. if ($data['broken_commission'] < 0)
  89. $data['broken_commission'] = 0;
  90. $data['brokerage_price'] = $user['brokerage_price'];
  91. //可提现佣金
  92. $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  93. if ($extractInfo['money'] > $commissionCount) return app('json')->fail('可提现佣金不足');
  94. /*
  95. if (!$extractInfo['cardnum'] == '')
  96. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  97. return app('json')->fail('银行卡号输入有误');*/
  98. if (UserExtract::userExtract($request->user(), $extractInfo))
  99. return app('json')->successful('申请提现成功!');
  100. else
  101. return app('json')->fail(UserExtract::getErrorInfo('提现失败'));
  102. }
  103. /**
  104. * 余额转账
  105. * @param Request $request
  106. */
  107. public function transfer(Request $request)
  108. {
  109. list($to_uid,$pass,$merber,$type) = UtilService::postMore([
  110. ['to_uid',''],
  111. ['pass',''],
  112. ['merber',0],
  113. ['type',0],
  114. ],$request,true);
  115. if(!User::be(['uid'=>$to_uid])) return app('json')->fail('用户不存在');
  116. if(strlen($pass)!=6) return app('json')->fail('交易密码只能输入6位数字');
  117. $user = $request->user();
  118. $money = $user['now_money'];$in = "转出余额";$out = "转入余额";$field="now_money";
  119. if($type==1)
  120. {
  121. $money = $user['consume'];
  122. $in = "转入钻石";$out = "转出钻石";
  123. $field = "consume";
  124. }
  125. if(md5(md5($user['salt'].$pass).$user['salt'])!=$user['transaction'])return app('json')->fail('交易密码错误');
  126. if(bcsub($money,$merber,2)>=0)
  127. {
  128. $user = User::where('uid',$request->uid())->lock(true)->find();
  129. User::where('uid',$request->uid())->dec($field,$merber)->update();
  130. $touser = User::where('uid',$to_uid)->find();
  131. User::where('uid',$to_uid)->inc($field,$merber)->update();
  132. $data['uid'] = $request->uid();
  133. $data['touid'] = $touser['uid'];
  134. $data['money'] = $merber;
  135. $data['order_id'] = UserTransfer::getNewOrderId();
  136. $data['add_time'] = time();
  137. $data['type'] = $type;
  138. $data['paid'] =1;
  139. UserTransfer::create($data);
  140. UserBill::expend($out,$request->uid(),'now_money','transfer_out',$merber,0,bcsub($user['now_money'],$merber,2),'转给'.$touser['nickname']."用户",1);
  141. UserBill::income($in,$touser['uid'],'now_money','transfer_in',$merber,0,bcadd($touser['now_money'],$merber,2),'收到用户'.$user['uid'].'转账号');
  142. return app('json')->successful('转账成功!');
  143. }
  144. else
  145. {
  146. return app('json')->fail($out.'不足');
  147. }
  148. }
  149. /**
  150. * 转账记录
  151. * @param Request $request
  152. */
  153. public function transfer_list(Request $request)
  154. {
  155. list($page,$limit,$pm,$type) = UtilService::postMore([
  156. ['page',1],
  157. ['limit',20],
  158. ['pm',0],
  159. ['type',0]
  160. ],$request,true);
  161. if($pm==0)
  162. {
  163. $count = UserTransfer::where('uid',$request->uid())->where('type',$type)->count();
  164. $data = UserTransfer::where('uid',$request->uid())->where('type',$type)->page($page,$limit)->order("id desc")->select();
  165. foreach ($data as &$v)
  166. {
  167. $v['to_user'] = User::where('uid',$v['touid'])->value('nickname');
  168. $v['_add_time'] = date("Y-m-d H:i:s",$v['add_time']);
  169. }
  170. }
  171. else
  172. {
  173. $count = UserTransfer::where('touid',$request->uid())->where('type',$type)->count();
  174. $data = UserTransfer::where('touid',$request->uid())->where('type',$type)->page($page,$limit)->order("id desc")->select();
  175. foreach ($data as &$v)
  176. {
  177. $v['to_user'] = User::where('uid',$v['uid'])->value('nickname');
  178. $v['_add_time'] = date("Y-m-d H:i:s",$v['add_time']);
  179. }
  180. }
  181. return app('json')->successful(compact('count','data'));
  182. }
  183. }