UserExtractController.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  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\Request;
  8. use crmeb\services\UtilService;
  9. /**
  10. * 提现类
  11. * Class UserExtractController
  12. * @package app\api\controller\user
  13. */
  14. class UserExtractController
  15. {
  16. /**
  17. * 提现银行
  18. * @param Request $request
  19. * @return mixed
  20. */
  21. public function bank(Request $request)
  22. {
  23. $user = $request->user();
  24. $broken_time = intval(sys_config('extract_time'));
  25. $search_time = time() - 86400 * $broken_time;
  26. //可提现佣金
  27. //返佣 +
  28. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  29. ->where('add_time', '>', $search_time)
  30. ->where('pm', 1)
  31. ->sum('number');
  32. //退款退的佣金 -
  33. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  34. ->where('add_time', '>', $search_time)
  35. ->where('pm', 0)
  36. ->sum('number');
  37. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  38. if ($data['broken_commission'] < 0)
  39. $data['broken_commission'] = 0;
  40. // return $data;
  41. $data['brokerage_price'] = $user['brokerage_price'];
  42. //可提现佣金
  43. $data['commissionCount'] = $data['brokerage_price'] - $data['broken_commission'];
  44. $extractBank = sys_config('user_extract_bank') ?? []; //提现银行
  45. $extractBank = str_replace("\r\n", "\n", $extractBank);//防止不兼容
  46. $data['extractBank'] = explode("\n", is_array($extractBank) ? (isset($extractBank[0]) ? $extractBank[0] : $extractBank) : $extractBank);
  47. $data['minPrice'] = sys_config('user_extract_min_price');//提现最低金额
  48. return app('json')->successful($data);
  49. }
  50. /**
  51. * 提现申请
  52. * @param Request $request
  53. * @return mixed
  54. */
  55. public function cash(Request $request)
  56. {
  57. $extractInfo = UtilService::postMore([
  58. ['alipay_code', ''],
  59. ['extract_type', ''],
  60. ['money', 0],
  61. ['name', ''],
  62. ['bankname', ''],
  63. ['cardnum', ''],
  64. ['weixin', ''],
  65. ['balance_type',0],
  66. ], $request);
  67. if (!preg_match('/^(([1-9][0-9]*)|(([0]\.\d{1,2}|[1-9][0-9]*\.\d{1,2})))$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  68. //提现设置最低金额
  69. if($extractInfo['money'] < sys_config('user_extract_min_price')) return app('json')->fail('金额小于最低提现金额');
  70. $user = $request->user();
  71. //if($user['is_real']!=2) return app('json')->fail('请先实名认证,通过后可以提现');
  72. $broken_time = intval(sys_config('extract_time'));
  73. $search_time = time() - 86400 * $broken_time;
  74. if(cache(md5('cash-'.$user['uid'].'-'.$extractInfo['balance_type'].'-'.date("Y-m-d"))) && false)
  75. {
  76. switch ($extractInfo['balance_type'])
  77. {
  78. case 0:
  79. return app('json')->fail('佣金每60秒只能提一次');
  80. break;
  81. case 1:
  82. return app('json')->fail('余额每60秒只能提一次');
  83. break;
  84. case 2:
  85. return app('json')->fail('余额每60秒只能提一次');
  86. break;
  87. }
  88. }
  89. cache(md5('cash-'.$user['uid'].'-'.$extractInfo['balance_type'].'-'.date("Y-m-d")),1,60);
  90. //可提现佣金
  91. if($extractInfo['balance_type']==0) {
  92. //可提现佣金
  93. //返佣 +
  94. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  95. ->where('add_time', '>', $search_time)
  96. ->where('pm', 1)
  97. ->sum('number');
  98. //退款退的佣金 -
  99. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  100. ->where('add_time', '>', $search_time)
  101. ->where('pm', 0)
  102. ->sum('number');
  103. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  104. if ($data['broken_commission'] < 0)
  105. $data['broken_commission'] = 0;
  106. $data['brokerage_price'] = $user['brokerage_price'];
  107. //可提现佣金
  108. $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  109. if ($extractInfo['money'] > $commissionCount) return app('json')->fail('可提现佣金不足');
  110. }
  111. if (!$extractInfo['cardnum'] == '')
  112. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  113. return app('json')->fail('银行卡号输入有误');
  114. if (UserExtract::userExtract($request->user(), $extractInfo))
  115. return app('json')->successful('申请提现成功!');
  116. else
  117. return app('json')->fail(UserExtract::getErrorInfo('提现失败'));
  118. }
  119. }