UserExtractController.php 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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\UserBill;
  6. use app\models\user\UserExtract;
  7. use app\models\user\UserMoney;
  8. use app\Request;
  9. use crmeb\services\UtilService;
  10. /**
  11. * 提现类
  12. * Class UserExtractController
  13. * @package app\api\controller\user
  14. */
  15. class UserExtractController
  16. {
  17. /**
  18. * 提现银行
  19. * @param Request $request
  20. * @return mixed
  21. */
  22. public function bank(Request $request)
  23. {
  24. $user = $request->user();
  25. $broken_time = intval(sys_config('extract_time'));
  26. $search_time = time() - 86400 * $broken_time;
  27. //可提现佣金
  28. //返佣 +
  29. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  30. ->where('add_time', '>', $search_time)
  31. ->where('pm', 1)
  32. ->sum('number');
  33. //退款退的佣金 -
  34. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  35. ->where('add_time', '>', $search_time)
  36. ->where('pm', 0)
  37. ->sum('number');
  38. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  39. if ($data['broken_commission'] < 0)
  40. $data['broken_commission'] = 0;
  41. // return $data;
  42. $data['brokerage_price'] = $user['brokerage_price'];
  43. //可提现佣金
  44. $data['commissionCount'] = $data['brokerage_price'] - $data['broken_commission'];
  45. $extractBank = sys_config('user_extract_bank') ?? []; //提现银行
  46. $extractBank = str_replace("\r\n", "\n", $extractBank);//防止不兼容
  47. $data['extractBank'] = explode("\n", is_array($extractBank) ? (isset($extractBank[0]) ? $extractBank[0] : $extractBank) : $extractBank);
  48. $data['minPrice'] = sys_config('user_extract_min_price');//提现最低金额
  49. return app('json')->successful($data);
  50. }
  51. public function cash_calculator(Request $request)
  52. {
  53. $extractInfo = UtilService::postMore([
  54. ['money', 0],
  55. ['money_type', ''],
  56. ['way', '']
  57. ], $request);
  58. // if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-8})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  59. $user = $request->user();
  60. $money_type = sys_data('money_type');
  61. foreach ($money_type as $v) {
  62. if ($v['code'] == $extractInfo['money_type']) {
  63. if (!$v['can_cash']) {
  64. return app('json')->fail('该币种不可提币');
  65. }
  66. switch ($extractInfo['way']) {
  67. case 'ERC20':
  68. $v['cash_commission_ratio'] = $v['cash_commission_ratio2'];
  69. break;
  70. case 'TRC20':
  71. break;
  72. default:
  73. return app('json')->fail('提币通道错误');
  74. break;
  75. }
  76. if ($v['cash_commission_count_type'] == 1) {
  77. $service = bcmul(bcdiv($v['cash_commission_ratio'], 100, 2), $extractInfo['money'], 8);
  78. } else {
  79. $service = $v['cash_commission_ratio'];
  80. }
  81. $service_type = $v['cash_commission_type'];
  82. }
  83. }
  84. if (!isset($service) || !isset($service_type)) {
  85. return app('json')->fail('该币种不可提币');
  86. }
  87. $extractInfo = array_merge($extractInfo, compact('service', 'service_type'));
  88. if ($extractInfo['money_type'] != $extractInfo['service_type']) {
  89. $extractInfo['extract_price'] = $extractInfo['money'];
  90. } else {
  91. $extractInfo['extract_price'] = bcsub($extractInfo['money'], $extractInfo['service'], 8);
  92. }
  93. $extractInfo['_money_type'] = init_money_type()[$extractInfo['money_type']];
  94. $extractInfo['_service_type'] = init_money_type()[$extractInfo['service_type']];
  95. return app('json')->success('ok', $extractInfo);
  96. }
  97. /**
  98. * 提现申请
  99. * @param Request $request
  100. * @return mixed
  101. */
  102. public function cash(Request $request)
  103. {
  104. $extractInfo = UtilService::postMore([
  105. ['alipay_code', ''],
  106. ['extract_type', ''],
  107. ['money', 0],
  108. ['name', ''],
  109. ['bankname', ''],
  110. ['cardnum', ''],
  111. ['weixin', ''],
  112. ['money_type', ''],
  113. ['address', ''],
  114. ['way', '']
  115. ], $request);
  116. // if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-8})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  117. $user = $request->user();
  118. if (!$extractInfo['way']) {
  119. return app('json')->fail('请选择提币通道');
  120. }
  121. // $broken_time = intval(sys_config('extract_time'));
  122. // $search_time = time() - 86400 * $broken_time;
  123. // //可提现佣金
  124. // //返佣 +
  125. // $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  126. // ->where('add_time', '>', $search_time)
  127. // ->where('pm', 1)
  128. // ->sum('number');
  129. // //退款退的佣金 -
  130. // $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  131. // ->where('add_time', '>', $search_time)
  132. // ->where('pm', 0)
  133. // ->sum('number');
  134. // $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  135. // if ($data['broken_commission'] < 0)
  136. // $data['broken_commission'] = 0;
  137. // $data['brokerage_price'] = $user['brokerage_price'];
  138. // //可提现佣金
  139. // $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  140. $money_type = sys_data('money_type');
  141. foreach ($money_type as $v) {
  142. if ($v['code'] == $extractInfo['money_type']) {
  143. if (!$v['can_cash']) {
  144. return app('json')->fail('该币种不可提币');
  145. }
  146. switch ($extractInfo['way']) {
  147. case 'ERC20':
  148. $v['cash_commission_ratio'] = $v['cash_commission_ratio2'];
  149. break;
  150. case 'TRC20':
  151. break;
  152. default:
  153. return app('json')->fail('提币通道错误');
  154. break;
  155. }
  156. if ($v['cash_commission_count_type'] == 1) {
  157. $service = bcmul(bcdiv($v['cash_commission_ratio'], 100, 2), $extractInfo['money'], 8);
  158. } else {
  159. $service = $v['cash_commission_ratio'];
  160. }
  161. $service_type = $v['cash_commission_type'];
  162. }
  163. }
  164. if (!isset($service) || !isset($service_type)) {
  165. return app('json')->fail('该币种不可提币');
  166. }
  167. $extractInfo = array_merge($extractInfo, compact('service', 'service_type'));
  168. $money = UserMoney::initialUserMoney($request->uid(), $extractInfo['money_type']);
  169. $money2 = UserMoney::initialUserMoney($request->uid(), $service_type);
  170. if ($extractInfo['money_type'] != $service_type) {
  171. if ($extractInfo['money'] > $money['money']) return app('json')->fail('可提现佣金不足');
  172. if ($service > $money2['money']) return app('json')->fail('用于支付手续费的' . init_money_type()[$service_type] . '不足');
  173. } else {
  174. if ($extractInfo['money'] > $money['money']) return app('json')->fail('可提现佣金不足');
  175. // if (bcadd($extractInfo['money'], $service, 8) > $money['money']) return app('json')->fail('可提现佣金不足');
  176. }
  177. if ($extractInfo['address'] == '') return app('json')->fail('钱包地址错误');
  178. // if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  179. // return app('json')->fail('银行卡号输入有误');
  180. $res = UserExtract::userExtract($user, $extractInfo);
  181. if ($res) {
  182. return app('json')->successful('申请提币成功!', ['data' => $res]);
  183. } else
  184. return app('json')->fail(UserExtract::getErrorInfo('提币失败'));
  185. }
  186. }