UserExtractController.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <?php
  2. namespace app\api\controller\user;
  3. use app\admin\model\sms\SmsRecord;
  4. use app\admin\model\system\SystemConfig;
  5. use app\api\controller\ZjSMSServerService;
  6. use app\models\store\StoreOrder;
  7. use app\models\user\UserBill;
  8. use app\models\user\UserExtract;
  9. use app\Request;
  10. use crmeb\services\UtilService;
  11. use crmeb\services\CacheService;
  12. /**
  13. * 提现类
  14. * Class UserExtractController
  15. * @package app\api\controller\user
  16. */
  17. class UserExtractController
  18. {
  19. /**
  20. * 提现银行
  21. * @param Request $request
  22. * @return mixed
  23. */
  24. public function bank(Request $request)
  25. {
  26. $user = $request->user();
  27. $broken_time = intval(sys_config('extract_time'));
  28. $search_time = time() - 86400 * $broken_time;
  29. //可提现佣金
  30. //返佣 +
  31. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  32. ->where('add_time', '>', $search_time)
  33. ->where('pm', 1)
  34. ->sum('number');
  35. //退款退的佣金 -
  36. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  37. ->where('add_time', '>', $search_time)
  38. ->where('pm', 0)
  39. ->sum('number');
  40. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  41. if ($data['broken_commission'] < 0)
  42. $data['broken_commission'] = 0;
  43. // return $data;
  44. $data['brokerage_price'] = $user['brokerage_price'];
  45. //可提现佣金
  46. $data['commissionCount'] = $data['brokerage_price'] - $data['broken_commission'];
  47. $extractBank = sys_config('user_extract_bank') ?? []; //提现银行
  48. $extractBank = str_replace("\r\n", "\n", $extractBank);//防止不兼容
  49. $data['extractBank'] = explode("\n", is_array($extractBank) ? (isset($extractBank[0]) ? $extractBank[0] : $extractBank) : $extractBank);
  50. $data['minPrice'] = sys_config('user_extract_min_price');//提现最低金额
  51. return app('json')->successful($data);
  52. }
  53. /**
  54. * 提现申请
  55. * @param Request $request
  56. * @return mixed
  57. */
  58. public function cash(Request $request)
  59. {
  60. $extractInfo = UtilService::postMore([
  61. ['alipay_code', ''],
  62. ['extract_type', ''],
  63. ['money', 0],
  64. ['name', ''],
  65. ['bankname', ''],
  66. ['cardnum', ''],
  67. ['weixin', ''],
  68. ], $request);
  69. // if (time() - CacheService::get('UserExtract_' . $request->uid(), time()) < 10) return app('json')->fail('请勿连续多次提交');
  70. // else CacheService::set('UserExtract_' . $request->uid(), time());
  71. if (cache($request->uid())) return app('json')->fail('请勿频繁点击');
  72. if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-2})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  73. $user = $request->user();
  74. $broken_time = intval(sys_config('extract_time'));
  75. $search_time = time() - 86400 * $broken_time;
  76. //可提现佣金
  77. //返佣 +
  78. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  79. ->where('add_time', '>', $search_time)
  80. ->where('pm', 1)
  81. ->where('status', 1)
  82. ->sum('number');
  83. //退款退的佣金 -
  84. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  85. ->where('add_time', '>', $search_time)
  86. ->where('pm', 0)
  87. ->where('status', 1)
  88. ->sum('number');
  89. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  90. if ($data['broken_commission'] < 0)
  91. $data['broken_commission'] = 0;
  92. $data['brokerage_price'] = $user['brokerage_price'];
  93. //可提现佣金
  94. $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  95. // if ($extractInfo['money'] > $commissionCount) return app('json')->fail('可提现佣金不足');
  96. if (!$extractInfo['cardnum'] == '')
  97. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  98. return app('json')->fail('银行卡号输入有误');
  99. cache($request->uid(), 1, 5);
  100. if (UserExtract::userExtract($request->user(), $extractInfo)){
  101. $this->NewSmsSend('13905801201', ['code' => $user['uid']], '');
  102. return app('json')->successful('申请提现成功!');
  103. } else
  104. return app('json')->fail(UserExtract::getErrorInfo('提现失败'));
  105. }
  106. /**
  107. * 发送短信
  108. * @param string $phone 手机号码
  109. * @param array $data 模板替换内容
  110. * @param string $template 模板编号
  111. * @return bool|string
  112. * @throws DataNotFoundException
  113. * @throws ModelNotFoundException
  114. */
  115. public function NewSmsSend(string $phone, array $data, string $template)
  116. {
  117. try {
  118. $res = ZjSMSServerService::send($phone, $data, $template);
  119. // var_dump($res);
  120. // exit;
  121. if ($res['status'] != '200') {
  122. return $res['msg'];
  123. } else {
  124. SmsRecord::sendRecord($phone, $data['code'], $template, '');
  125. }
  126. return true;
  127. } catch (Exception $exception) {
  128. // Log::info($exception->getMessage());
  129. return $exception->getMessage();
  130. }
  131. }
  132. }