UserExtractController.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  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\CacheService;
  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', 0, true));
  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', '>', date("Y-m-d H:i:s", $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', '>', date("Y-m-d H:i:s", $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. $data['commission'] = sys_config('commission');
  46. $data['commission_gf'] = sys_config('commission_gf');
  47. $data['commission_consumer'] = sys_config('commission_consumer');
  48. $data['commission_yue'] = sys_config('commission_yue');
  49. $extractBank = sys_config('user_extract_bank') ?? []; //提现银行
  50. $extractBank = str_replace("\r\n", "\n", $extractBank);//防止不兼容
  51. $data['extractBank'] = explode("\n", is_array($extractBank) ? (isset($extractBank[0]) ? $extractBank[0] : $extractBank) : $extractBank);
  52. $data['minPrice'] = sys_config('user_extract_min_price');//提现最低金额
  53. return app('json')->successful($data);
  54. }
  55. /**
  56. * 提现申请
  57. * @param Request $request
  58. * @return mixed
  59. */
  60. public function cash(Request $request)
  61. {
  62. $extractInfo = UtilService::postMore([
  63. ['alipay_code', ''],
  64. ['extract_type', ''],
  65. ['money', 0],
  66. ['name', ''],
  67. ['bankname', ''],
  68. ['cardnum', ''],
  69. ['weixin', ''],
  70. ['from', 'brokerage_price']
  71. ], $request);
  72. if (time() - CacheService::get('UserExtract_' . $request->uid(), 0) < 10) return app('json')->fail('请勿连续多次提交');
  73. else CacheService::set('UserExtract_' . $request->uid(), time());
  74. if (!preg_match('/^(([1-9][0-9]*)|(([0]\.\d{1,2}|[1-9][0-9]*\.\d{1,2})))$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  75. //提现设置最低金额
  76. if ($extractInfo['money'] < sys_config('user_extract_min_price')) return app('json')->fail('金额小于最低提现金额');
  77. $user = $request->user();
  78. switch ($extractInfo['from']) {
  79. case 'brokerage_price':
  80. $broken_time = intval(sys_config('extract_time', 0, true));
  81. $search_time = time() - 86400 * $broken_time;
  82. //可提现佣金
  83. //返佣 +
  84. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  85. ->where('add_time', '>', date("Y-m-d H:i:s", $search_time))
  86. ->where('pm', 1)
  87. ->sum('number');
  88. //退款退的佣金 -
  89. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  90. ->where('add_time', '>', date("Y-m-d H:i:s", $search_time))
  91. ->where('pm', 0)
  92. ->sum('number');
  93. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  94. if ($data['broken_commission'] < 0)
  95. $data['broken_commission'] = 0;
  96. $data['brokerage_price'] = $user['brokerage_price'];
  97. //可提现佣金
  98. $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  99. break;
  100. case 'now_money':
  101. $commissionCount = $user['now_money'];
  102. break;
  103. default:
  104. return app('json')->fail('不支持的提现方式');
  105. break;
  106. }
  107. if ($extractInfo['money'] > $commissionCount) return app('json')->fail('可提现佣金不足');
  108. if (!$extractInfo['cardnum'] == '')
  109. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  110. return app('json')->fail('银行卡号输入有误');
  111. if (UserExtract::userExtract($request->user(), $extractInfo))
  112. return app('json')->successful('申请提现成功!');
  113. else
  114. return app('json')->fail(UserExtract::getErrorInfo('提现失败'));
  115. }
  116. }