UserExtractController.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. <?php
  2. namespace app\api\controller\user;
  3. use app\admin\model\system\SystemConfig;
  4. use app\admin\model\user\UserExtract as UserExtractModel;
  5. use app\models\store\StoreOrder;
  6. use app\models\user\UserBill;
  7. use app\models\user\UserExtract;
  8. use app\models\user\UserMoney;
  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. return app('json')->successful($data);
  51. }
  52. /**
  53. * 提现申请
  54. * @param Request $request
  55. * @return mixed
  56. */
  57. public function cashold(Request $request)
  58. {
  59. $extractInfo = UtilService::postMore([
  60. ['alipay_code', ''],
  61. ['extract_type', ''],
  62. ['money', 0],
  63. ['name', ''],
  64. ['bankname', ''],
  65. ['cardnum', ''],
  66. ['weixin', ''],
  67. ], $request);
  68. if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-2})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  69. $user = $request->user();
  70. $broken_time = intval(sys_config('extract_time'));
  71. $search_time = time() - 86400 * $broken_time;
  72. //可提现佣金
  73. //返佣 +
  74. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  75. ->where('add_time', '>', $search_time)
  76. ->where('pm', 1)
  77. ->sum('number');
  78. //退款退的佣金 -
  79. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  80. ->where('add_time', '>', $search_time)
  81. ->where('pm', 0)
  82. ->sum('number');
  83. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  84. if ($data['broken_commission'] < 0)
  85. $data['broken_commission'] = 0;
  86. $data['brokerage_price'] = $user['brokerage_price'];
  87. //可提现佣金
  88. $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  89. if ($extractInfo['money'] > $commissionCount) return app('json')->fail('可提现佣金不足');
  90. if (!$extractInfo['cardnum'] == '')
  91. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  92. return app('json')->fail('银行卡号输入有误');
  93. if (UserExtract::userExtract($request->user(), $extractInfo))
  94. return app('json')->successful('申请提现成功!');
  95. else
  96. return app('json')->fail(UserExtract::getErrorInfo('提现失败'));
  97. }
  98. public function cash_calculator(Request $request)
  99. {
  100. $extractInfo = UtilService::postMore([
  101. ['money', 0],
  102. ['money_type', ''],
  103. ], $request);
  104. // if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-8})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  105. $user = $request->user();
  106. $money_type = sys_data('money_type');
  107. foreach ($money_type as $v) {
  108. if ($v['code'] == $extractInfo['money_type']) {
  109. if (!$v['can_cash']) {
  110. return app('json')->fail('该币种不可提币');
  111. }
  112. if ($v['cash_commission_count_type'] == 1) {
  113. $service = bcmul(bcdiv($v['cash_commission_ratio'], 100, 8), $extractInfo['money'], 8);
  114. } else {
  115. $service = $v['cash_commission_ratio'];
  116. }
  117. $service_type = $v['cash_commission_type'];
  118. if ($service >= $extractInfo['money']) {
  119. return app('json')->fail('提币量太少');
  120. }
  121. }
  122. }
  123. if (!isset($service_type)) {
  124. return app('json')->fail('该币种不可提币');
  125. }
  126. $extractInfo = array_merge($extractInfo, compact('service', 'service_type'));
  127. if ($extractInfo['money_type'] != $extractInfo['service_type']) {
  128. $extractInfo['extract_price'] = $extractInfo['money'];
  129. } else {
  130. $extractInfo['extract_price'] = bcsub($extractInfo['money'], $extractInfo['service'], 8);
  131. }
  132. $extractInfo['_money_type'] = init_money_type()[$extractInfo['money_type']];
  133. $extractInfo['_service_type'] = init_money_type()[$extractInfo['service_type']];
  134. return app('json')->success('ok', $extractInfo);
  135. }
  136. /**
  137. * 提现申请
  138. * @param Request $request
  139. * @return mixed
  140. */
  141. public function cash(Request $request)
  142. {
  143. $extractInfo = UtilService::postMore([
  144. ['alipay_code', ''],
  145. ['extract_type', ''],
  146. ['money', 0],
  147. ['name', ''],
  148. ['bankname', ''],
  149. ['cardnum', ''],
  150. ['weixin', ''],
  151. ['money_type', ''],
  152. ['address', ''],
  153. ], $request);
  154. // if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-8})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  155. $user = $request->user();
  156. // $broken_time = intval(sys_config('extract_time'));
  157. // $search_time = time() - 86400 * $broken_time;
  158. // //可提现佣金
  159. // //返佣 +
  160. // $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  161. // ->where('add_time', '>', $search_time)
  162. // ->where('pm', 1)
  163. // ->sum('number');
  164. // //退款退的佣金 -
  165. // $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  166. // ->where('add_time', '>', $search_time)
  167. // ->where('pm', 0)
  168. // ->sum('number');
  169. // $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  170. // if ($data['broken_commission'] < 0)
  171. // $data['broken_commission'] = 0;
  172. // $data['brokerage_price'] = $user['brokerage_price'];
  173. // //可提现佣金
  174. // $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  175. $money_type = sys_data('money_type');
  176. foreach ($money_type as $v) {
  177. if ($v['code'] == $extractInfo['money_type']) {
  178. if (!$v['can_cash']) {
  179. return app('json')->fail('该币种不可提币');
  180. }
  181. // if ($v['less'] > $extractInfo['money']) {
  182. // return app('json')->fail('该币种' . $v['less'] . '个起提');
  183. // }
  184. if ($v['cash_commission_count_type'] == 1) {
  185. $service = bcmul(bcdiv($v['cash_commission_ratio'], 100, 8), $extractInfo['money'], 8);
  186. } else {
  187. $service = $v['cash_commission_ratio'];
  188. }
  189. if ($service >= $extractInfo['money']) {
  190. return app('json')->fail('提币量太少');
  191. }
  192. $service_type = $v['cash_commission_type'];
  193. }
  194. }
  195. if (!isset($service_type)) {
  196. return app('json')->fail('该币种不可提币');
  197. }
  198. $extractInfo = array_merge($extractInfo, compact('service', 'service_type'));
  199. $money = UserMoney::initialUserMoney($request->uid(), $extractInfo['money_type']);
  200. $money2 = UserMoney::initialUserMoney($request->uid(), $service_type);
  201. if ($extractInfo['money_type'] != $service_type) {
  202. if ($extractInfo['money'] > $money['money']) return app('json')->fail('可提现佣金不足');
  203. if ($service > $money2['money']) return app('json')->fail('用于支付手续费的' . init_money_type()[$service_type] . '不足');
  204. } else {
  205. if ($extractInfo['money'] > $money['money']) return app('json')->fail('可提现佣金不足');
  206. // if (bcadd($extractInfo['money'], $service, 8) > $money['money']) return app('json')->fail('可提现佣金不足');
  207. }
  208. if ($extractInfo['address'] == '') return app('json')->fail('钱包地址错误');
  209. // if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  210. // return app('json')->fail('银行卡号输入有误');
  211. $res = UserExtract::userExtract($user, $extractInfo);
  212. if ($res) {
  213. return app('json')->successful('申请提币成功!', ['data' => $res]);
  214. } else
  215. return app('json')->fail(UserExtract::getErrorInfo('提币失败'));
  216. }
  217. public function lst(Request $request)
  218. {
  219. $where = UtilService::getMore([
  220. ['limit', 10],
  221. ['page', 1],
  222. ], $request);
  223. $model = new UserExtractModel();
  224. $model = $model->where('a.uid', $request->uid());
  225. $model = $model->alias('a');
  226. $model = $model->field('a.*,b.nickname');
  227. $model = $model->join('user b', 'b.uid=a.uid', 'LEFT');
  228. $model = $model->order('a.id desc');
  229. $list = $model->page($where['page'], $where['limit'])->select();
  230. return app('json')->successful('ok!', ['data' => $list]);
  231. }
  232. }