UserExtractController.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  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\Request;
  9. use crmeb\services\UtilService;
  10. use crmeb\services\CacheService;
  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 cash(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 (time() - CacheService::get('UserExtract_' . $request->uid(), time()) < 10) return app('json')->fail('请勿连续多次提交');
  69. else CacheService::set('UserExtract_' . $request->uid(), time());
  70. if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-2})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  71. $user = $request->user();
  72. $broken_time = intval(sys_config('extract_time'));
  73. $search_time = time() - 86400 * $broken_time;
  74. //可提现佣金
  75. //返佣 +
  76. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  77. ->where('add_time', '>', $search_time)
  78. ->where('pm', 1)
  79. ->where('status', 1)
  80. ->sum('number');
  81. //退款退的佣金 -
  82. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  83. ->where('add_time', '>', $search_time)
  84. ->where('pm', 0)
  85. ->where('status', 1)
  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. $brokerage = round($extractInfo['money'] * 0.1, 2);
  94. if ($user['now_money'] < $brokerage) return app('json')->fail('手续费不足,请保持账户余额拥有提现的百分之十手续费');
  95. $user['now_money'] -= $brokerage;// 收取手续费
  96. if ($extractInfo['money'] > $commissionCount) return app('json')->fail('可提现佣金不足');
  97. if (!$extractInfo['cardnum'] == '')
  98. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  99. return app('json')->fail('银行卡号输入有误');
  100. if (UserExtract::userExtract($request->user(), $extractInfo)){
  101. User::where('uid', $user['uid'])->update(['now_money' => $user['now_money']]);
  102. UserBill::expend('收取手续费', $user['uid'], 'now_money', 'brokerage_money', $brokerage, 0, $user['now_money'], '收取提现手续费');
  103. return app('json')->successful('申请提现成功!');
  104. } else{
  105. return app('json')->fail(UserExtract::getErrorInfo('提现失败'));
  106. }
  107. }
  108. }