WithdrawController.php 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. <?php
  2. namespace app\controller;
  3. use app\business\GoodsBusiness;
  4. use app\business\LoginBusiness;
  5. use app\business\PayorderBusiness;
  6. use app\business\StreamBusiness;
  7. use app\business\WithdrawBusiness;
  8. use Illuminate\Support\Arr;
  9. use Respect\Validation\Validator;
  10. use support\Db;
  11. use support\Redis;
  12. use support\Request;
  13. use hg\apidoc\annotation as Apidoc;
  14. use Webman\Captcha\CaptchaBuilder;
  15. use Webman\Captcha\PhraseBuilder;
  16. #[Apidoc\Title("提现")]
  17. #[Apidoc\Group("Stream")]
  18. #[Apidoc\Sort(5)]
  19. class WithdrawController
  20. {
  21. #[Apidoc\Title("提现申请")]
  22. #[Apidoc\Url("api/withdraw.html")]
  23. #[Apidoc\Method("POST")]
  24. #[Apidoc\Header("token", type: "string", require: true, desc: "身份令牌Token", mock: "@token")]
  25. #[Apidoc\Param("money", type: "int", require: true, desc: "提现金额", mock: 10)]
  26. #[Apidoc\Param("mold", type: "int", require: true, desc: "钱包类型 ", mock: 1)]
  27. #[Apidoc\Param(name: "pay_characteristic", type: "int", require: true, desc: '支付通道标识', default: '1')]
  28. public function applyfor(Request $request)
  29. {
  30. $param = $request->param_data;
  31. $param['user_data'] = $request->user_data;
  32. Db::beginTransaction();
  33. try {
  34. Validator::input($param, [
  35. 'money' => Validator::notEmpty()->Number()->setName('提现金额'),
  36. 'mold' => Validator::notEmpty()->intType()->setName('钱包类型'),
  37. ]);
  38. if (!empty(Redis::get($param['mold'] . $request->user_data['id']))) {
  39. throw new \Exception('请不要连续操作');
  40. }
  41. Redis::setEx($param['mold'] . $request->user_data['id'], 10, $request->user_data['id']);
  42. $name = Db::table('wa_user_identity')->where('uid', $request->user_data['id'])->value('name');
  43. if (empty($name)) {
  44. throw new \Exception('请实名后再进行提现!');
  45. }
  46. // $is_buy = Db::table('wa_payorder')
  47. // ->where('user_id', $param['user_data']['id'])
  48. // ->where('is_pay', 2)
  49. // ->where('goods_type', 1)
  50. // ->first();
  51. // if(!$is_buy){
  52. // Db::rollBack();
  53. // return error('功能暂未开放!',[],4006);
  54. // }
  55. if($param['mold']==2){
  56. $carkdatalist = Db::table('wa_user_social_cark')
  57. ->where('user_id', $request->user_data['id'])->where('type', 1)->first();
  58. if(empty($carkdatalist)){
  59. throw new \Exception('先领取WB.U卡在兑换!');
  60. }
  61. $msg = '兑换成功';
  62. }elseif ($param['mold']==5){
  63. $carkdatalist = Db::table('wa_user_social_cark')
  64. ->where('user_id', $request->user_data['id'])->where('type', 1)->first();
  65. if(empty($carkdatalist)){
  66. throw new \Exception('先领取WB.U卡在提现!');
  67. }
  68. $msg = '兑换成功';
  69. }elseif ($param['mold']==6){
  70. $carkdatalist = Db::table('wa_user_social_cark')
  71. ->where('user_id', $request->user_data['id'])->where('type', 1)->first();
  72. if(empty($carkdatalist)){
  73. throw new \Exception('先领取WB.U卡在来提现!');
  74. }
  75. $msg = '提现成功';
  76. }elseif ($param['mold']==10){
  77. $msg = '解冻成功';
  78. } else{
  79. $account_holder = Db::table('wa_bank_card')->where('uid', $request->user_data['id'])->value('account_holder');
  80. if (empty($account_holder)) {
  81. throw new \Exception('请绑定银行卡!');
  82. }
  83. if ($account_holder != $name) {
  84. throw new \Exception('实名人和开户人不一致,请绑定实名人的银行卡!');
  85. }
  86. $msg = '提现成功';
  87. }
  88. $arr = WithdrawBusiness::applyfor($param);
  89. } catch (\Throwable $exception) {
  90. Db::rollBack();
  91. return error($exception->getMessage());
  92. }
  93. Db::commit();
  94. return success($arr, $msg);
  95. }
  96. #[Apidoc\Title("提现记录")]
  97. #[Apidoc\Url("api/withdraw/stream.html")]
  98. #[Apidoc\Method("POST")]
  99. #[Apidoc\Header("token", type: "string", require: true, desc: "身份令牌Token", mock: "@token")]
  100. #[Apidoc\Param("page", type: "int", require: true, desc: "页面", mock: 1)]
  101. #[Apidoc\Param("limit", type: "int", require: true, desc: "输入条数", mock: 10)]
  102. #[Apidoc\Param("mold", type: "int", require: true, desc: "钱包类型 不传查所有 ", mock: 1)]
  103. #[Apidoc\Returned(name: "order_no", type: "string", require: true, desc: '订单号', default: '23213213213217182937291')]
  104. #[Apidoc\Returned(name: "money", type: "string", require: true, desc: '提现金额', default: '100.00')]
  105. #[Apidoc\Returned(name: "status", type: "string", require: true, desc: '提现状态 1 待审核 2打款中 3审核通过 4驳回', default: '1')]
  106. #[Apidoc\Returned(name: "affiliated_bank", type: "string", require: true, desc: '归属银行', default: '中国银行')]
  107. #[Apidoc\Returned(name: "account_holder", type: "string", require: true, desc: '开户人', default: '张三')]
  108. #[Apidoc\Returned(name: "card_number", type: "string", require: true, desc: '卡号', default: '12321321376763274682374681')]
  109. #[Apidoc\Returned(name: "created_at", type: "date", require: true, desc: '申请时间', default: '2023-05-20 23:49:49')]
  110. #[Apidoc\Returned(name: "remarks", type: "date", require: true, desc: '驳回备注', default: '')]
  111. public function stream(Request $request)
  112. {
  113. $param = $request->param_data;
  114. $param = Arr::only($param, ['page', 'limit', 'mold']);
  115. $param['user_data'] = $request->user_data;
  116. try {
  117. Validator::input($param, [
  118. 'page' => Validator::notEmpty()->intType()->setName('页码'),
  119. 'limit' => Validator::notEmpty()->intType()->setName('输出条数'),
  120. ]);
  121. $data = WithdrawBusiness::stream($param);
  122. } catch (\Throwable $exception) {
  123. return error($exception->getMessage());
  124. }
  125. return success($data['data'], '成功', 200, $data['total']);
  126. }
  127. #[Apidoc\Title("转账")]
  128. #[Apidoc\Url("api/withdraw/transfer.html")]
  129. #[Apidoc\Method("POST")]
  130. #[Apidoc\Header("token", type: "string", require: true, desc: "身份令牌Token", mock: "@token")]
  131. #[Apidoc\Param("money", type: "int", require: true, desc: "提现金额", mock: 10)]
  132. #[Apidoc\Param("account_number", type: "string", require: true, desc: "收款账号:转账时候传 ", mock: 1)]
  133. #[Apidoc\Param(name: "pay_characteristic", type: "int", require: true, desc: '支付通道标识', default: '1')]
  134. public function transfer(Request $request)
  135. {
  136. $param = $request->param_data;
  137. $param['user_data'] = $request->user_data;
  138. Db::beginTransaction();
  139. try {
  140. Validator::input($param, [
  141. 'money' => Validator::notEmpty()->Number()->setName('提现金额'),
  142. 'account_number' => Validator::notEmpty()->setName('转账账号'),
  143. ]);
  144. if (!empty(Redis::get('1212' . $request->user_data['id']))) {
  145. throw new \Exception('请不要连续操作');
  146. }
  147. Redis::setEx('1212' . $request->user_data['id'], 10, $request->user_data['id']);
  148. $name = Db::table('wa_user_identity')->where('uid', $request->user_data['id'])->value('name');
  149. if (empty($name)) {
  150. throw new \Exception('请实名后再进行转账!');
  151. }
  152. $accountUser = Db::table('wa_users')->where('mobile',$param['account_number'])->first();
  153. if(empty($accountUser)){
  154. throw new \Exception('转账账号不存在!');
  155. }
  156. $userdata = Db::table('wa_users')->where('id',$param['user_data']['id'])->first();
  157. if(!empty($userdata) && $userdata->money_five>=$param['money']){
  158. StreamBusiness::delStream($param['user_data']['id'], $param['money'], streamType17, moldType5, moldTypefild5, $param['user_data']['id']);
  159. StreamBusiness::addStream($accountUser->id, $param['money'], streamType17, moldType5, moldTypefild5, $param['user_data']['id']);
  160. }else{
  161. throw new \Exception('世界币不足!');
  162. }
  163. } catch (\Throwable $exception) {
  164. Db::rollBack();
  165. return error($exception->getMessage());
  166. }
  167. Db::commit();
  168. return success([], '转账成功');
  169. }
  170. }