UserExtractController.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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. ], $request);
  66. if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-2})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  67. $user = $request->user();
  68. $broken_time = intval(sys_config('extract_time'));
  69. $search_time = time() - 86400 * $broken_time;
  70. //可提现佣金
  71. //返佣 +
  72. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  73. ->where('add_time', '>', $search_time)
  74. ->where('pm', 1)
  75. ->sum('number');
  76. //退款退的佣金 -
  77. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'now_money', 'type' => 'brokerage'])
  78. ->where('add_time', '>', $search_time)
  79. ->where('pm', 0)
  80. ->sum('number');
  81. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  82. if ($data['broken_commission'] < 0)
  83. $data['broken_commission'] = 0;
  84. $data['brokerage_price'] = $user['brokerage_price'];
  85. //可提现佣金
  86. $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  87. if ($extractInfo['money'] > $commissionCount) return app('json')->fail('可提现佣金不足');
  88. if (!$extractInfo['cardnum'] == '')
  89. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18})$/', $extractInfo['cardnum']))
  90. return app('json')->fail('银行卡号输入有误');
  91. if (UserExtract::userExtract($request->user(), $extractInfo))
  92. return app('json')->successful('申请提现成功!');
  93. else
  94. return app('json')->fail(UserExtract::getErrorInfo('提现失败'));
  95. }
  96. }