UserExtractController.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. <?php
  2. namespace app\api\controller\user;
  3. use app\admin\model\system\SystemConfig;
  4. use app\http\validates\user\AddressValidate;
  5. use app\models\store\StoreOrder;
  6. use app\models\system\SystemCity;
  7. use app\models\user\UserBank;
  8. use app\models\user\UserBill;
  9. use app\models\user\UserExtract;
  10. use app\Request;
  11. use crmeb\services\UtilService;
  12. use crmeb\services\CacheService;
  13. use think\db\exception\DataNotFoundException;
  14. use think\db\exception\ModelNotFoundException;
  15. use think\exception\ValidateException;
  16. /**
  17. * 提现类
  18. * Class UserExtractController
  19. * @package app\api\controller\user
  20. */
  21. class UserExtractController
  22. {
  23. /**
  24. * 提现银行
  25. * @param Request $request
  26. * @return mixed
  27. */
  28. public function bank(Request $request)
  29. {
  30. $user = $request->user();
  31. $broken_time = intval(sys_config('extract_time'));
  32. $search_time = time() - 86400 * $broken_time;
  33. //可提现佣金
  34. //返佣 +
  35. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'brokerage_price'])
  36. ->where('add_time', '>', $search_time)
  37. ->where('pm', 1)
  38. ->sum('number');
  39. //退款退的佣金 -
  40. $refund_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'brokerage_price'])
  41. ->where('add_time', '>', $search_time)
  42. ->where('pm', 0)
  43. ->sum('number');
  44. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  45. if ($data['broken_commission'] < 0)
  46. $data['broken_commission'] = 0;
  47. // return $data;
  48. $data['brokerage_price'] = $user['brokerage_price'];
  49. //可提现佣金
  50. $data['commissionCount'] = $data['brokerage_price'] - $data['broken_commission'];
  51. $extractBank = sys_config('user_extract_bank') ?? []; //提现银行
  52. $extractBank = str_replace("\r\n", "\n", $extractBank);//防止不兼容
  53. $data['extractBank'] = explode("\n", is_array($extractBank) ? (isset($extractBank[0]) ? $extractBank[0] : $extractBank) : $extractBank);
  54. $data['minPrice'] = sys_config('user_extract_min_price');//提现最低金额
  55. $data['extractInfo'] = UserExtract::userLastInfo($user['uid']);
  56. $data['extract_commission'] = sys_config('extract_commission', 0);
  57. return app('json')->successful($data);
  58. }
  59. /**
  60. * 提现申请
  61. * @param Request $request
  62. * @return mixed
  63. */
  64. public function cash(Request $request)
  65. {
  66. $extractInfo = UtilService::postMore([
  67. ['alipay_code', ''],
  68. ['extract_type', ''],
  69. ['money', 0],
  70. ['name', ''],
  71. ['bankname', ''],
  72. ['cardnum', ''],
  73. ['weixin', ''],
  74. ], $request);
  75. if ($extractInfo['money'] % 100 != 0) {
  76. return app('json')->fail('只能提现整百数字的金额');
  77. }
  78. if (time() - CacheService::get('UserExtract_' . $request->uid(), 0) < 10) return app('json')->fail('请勿连续多次提交');
  79. else CacheService::set('UserExtract_' . $request->uid(), time());
  80. if (!preg_match('/^(([1-9]\d*)|0)(\.\d{1-2})?$/', $extractInfo['money'])) return app('json')->fail('提现金额输入有误');
  81. $user = $request->user();
  82. $broken_time = intval(sys_config('extract_time'));
  83. $search_time = time() - 86400 * $broken_time;
  84. //可提现佣金
  85. //返佣 +
  86. $brokerage_commission = UserBill::where(['uid' => $user['uid'], 'category' => 'brokerage_price'])
  87. ->where('add_time', '>', $search_time)
  88. ->where('pm', 1)
  89. ->where('status', 1)
  90. ->sum('number');
  91. //退款退的佣金 -
  92. $refund_commission = UserBill::where(['uid' => $user['uid'],'category' => 'brokerage_price'])
  93. ->where('add_time', '>', $search_time)
  94. ->where('pm', 0)
  95. ->where('status', 1)
  96. ->sum('number');
  97. $data['broken_commission'] = bcsub($brokerage_commission, $refund_commission, 2);
  98. if ($data['broken_commission'] < 0)
  99. $data['broken_commission'] = 0;
  100. $data['brokerage_price'] = $user['brokerage_price'];
  101. $retention_money = sys_config('retention_money', 0); //健康币最低保留金额
  102. $brokerage_price = bcsub($user['brokerage_price'], $extractInfo['money'], 2);
  103. if ($brokerage_price < $retention_money){
  104. return app('json')->fail('提现后健康币不能低于'. $retention_money);
  105. }
  106. //可提现佣金
  107. $commissionCount = $data['brokerage_price'] - $data['broken_commission'];
  108. // if ($extractInfo['money'] > $commissionCount) return app('json')->fail('可提现健康币不足');
  109. if (!$extractInfo['cardnum'] == '')
  110. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18}|\d{15})$/', $extractInfo['cardnum']))
  111. return app('json')->fail('银行卡号输入有误');
  112. if (UserExtract::userExtract($request->user(), $extractInfo))
  113. return app('json')->successful('申请提现成功!');
  114. else
  115. return app('json')->fail(UserExtract::getErrorInfo('提现失败'));
  116. }
  117. /**
  118. * 银行卡 获取单个
  119. * @param Request $request
  120. * @param $id
  121. * @return mixed
  122. * @throws DataNotFoundException
  123. * @throws ModelNotFoundException
  124. * @throws \think\exception\DbException
  125. */
  126. public function bank_info(Request $request, $id)
  127. {
  128. $bankInfo = [];
  129. if ($id && is_numeric($id) && UserBank::be(['is_del' => 0, 'id' => $id, 'uid' => $request->uid()])) {
  130. $bankInfo = UserBank::find($id)->toArray();
  131. }
  132. return app('json')->successful($bankInfo);
  133. }
  134. /**
  135. * 银行卡列表
  136. * @param Request $request
  137. * @param $page
  138. * @param $limit
  139. * @return mixed
  140. */
  141. public function bank_list(Request $request)
  142. {
  143. list($page, $limit) = UtilService::getMore([['page', 0], ['limit', 20]], $request, true);
  144. $list = UserBank::getUserValidAddressList($request->uid(), $page, $limit, 'id,bank_code,bank_address,is_default');
  145. return app('json')->successful($list);
  146. }
  147. /**
  148. * 设置默认银行卡
  149. *
  150. * @param Request $request
  151. * @return mixed
  152. */
  153. public function bank_default_set(Request $request)
  154. {
  155. list($id) = UtilService::getMore([['id', 0]], $request, true);
  156. if (!$id || !is_numeric($id)) return app('json')->fail('参数错误!');
  157. if (!UserBank::be(['is_del' => 0, 'id' => $id, 'uid' => $request->uid()]))
  158. return app('json')->fail('银行卡不存在!');
  159. $res = UserBank::setDefaultAddress($id, $request->uid());
  160. if (!$res)
  161. return app('json')->fail('银行卡不存在!');
  162. else
  163. return app('json')->successful();
  164. }
  165. /**
  166. * 获取默认银行卡
  167. * @param Request $request
  168. * @return mixed
  169. */
  170. public function bank_default(Request $request)
  171. {
  172. $defaultAddress = UserBank::getUserDefaultAddress($request->uid(), 'id,bank_code,bank_address,is_default');
  173. if ($defaultAddress) {
  174. $defaultAddress = $defaultAddress->toArray();
  175. return app('json')->successful('ok', $defaultAddress);
  176. }
  177. return app('json')->successful('empty', []);
  178. }
  179. /**
  180. * 修改 添加银行卡
  181. * @param Request $request
  182. * @return mixed
  183. */
  184. public function bank_edit(Request $request)
  185. {
  186. $bankInfo = UtilService::postMore([
  187. ['bank_code', ''],
  188. ['is_default', false],
  189. ['bank_address', ''],
  190. ['id', 0],
  191. ], $request);
  192. $bankInfo['uid']= $request->uid();
  193. if (!$bankInfo['bank_code'] == '')
  194. if (!preg_match('/^([1-9]{1})(\d{14}|\d{18}|\d{15})$/', $bankInfo['bank_code']))
  195. return app('json')->fail('银行卡号输入有误');
  196. if ($bankInfo['id'] && UserBank::be(['id' => $bankInfo['id'], 'uid' => $request->uid(), 'is_del' => 0])) {
  197. $id = $bankInfo['id'];
  198. unset($bankInfo['id']);
  199. if (UserBank::edit($bankInfo, $id, 'id')) {
  200. if ($bankInfo['is_default'])
  201. UserBank::setDefaultAddress($id, $request->uid());
  202. return app('json')->successful();
  203. } else
  204. return app('json')->fail('编辑银行卡失败!');
  205. } else {
  206. $bankInfo['add_time'] = time();
  207. if ($bank = UserBank::create($bankInfo)) {
  208. if ($bankInfo['is_default']) {
  209. UserBank::setDefaultAddress($bank->id, $request->uid());
  210. }
  211. return app('json')->successful(['id' => $bank->id]);
  212. } else {
  213. return app('json')->fail('添加银行卡失败!');
  214. }
  215. }
  216. }
  217. /**
  218. * 删除银行卡
  219. *
  220. * @param Request $request
  221. * @return mixed
  222. */
  223. public function bank_del(Request $request)
  224. {
  225. list($id) = UtilService::postMore([['id', 0]], $request, true);
  226. if (!$id || !is_numeric($id)) return app('json')->fail('参数错误!');
  227. if (!UserBank::be(['is_del' => 0, 'id' => $id, 'uid' => $request->uid()]))
  228. return app('json')->fail('银行卡不存在!');
  229. if (UserBank::edit(['is_del' => '1'], $id, 'id'))
  230. return app('json')->successful();
  231. else
  232. return app('json')->fail('删除银行卡失败!');
  233. }
  234. }