WithdrawController.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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. }elseif ($param['mold']==1){
  79. $msg = '提现成功';
  80. }elseif ($param['mold']==55){
  81. $msg = '提现成功';
  82. } else{
  83. $account_holder = Db::table('wa_bank_card')->where('uid', $request->user_data['id'])->value('account_holder');
  84. if (empty($account_holder)) {
  85. throw new \Exception('请绑定银行卡!');
  86. }
  87. if ($account_holder != $name) {
  88. throw new \Exception('实名人和开户人不一致,请绑定实名人的银行卡!');
  89. }
  90. $msg = '提现成功';
  91. }
  92. $arr = WithdrawBusiness::applyfor($param);
  93. } catch (\Throwable $exception) {
  94. Db::rollBack();
  95. return error($exception->getMessage());
  96. }
  97. Db::commit();
  98. return success($arr, $msg);
  99. }
  100. #[Apidoc\Title("提现记录")]
  101. #[Apidoc\Url("api/withdraw/stream.html")]
  102. #[Apidoc\Method("POST")]
  103. #[Apidoc\Header("token", type: "string", require: true, desc: "身份令牌Token", mock: "@token")]
  104. #[Apidoc\Param("page", type: "int", require: true, desc: "页面", mock: 1)]
  105. #[Apidoc\Param("limit", type: "int", require: true, desc: "输入条数", mock: 10)]
  106. #[Apidoc\Param("mold", type: "int", require: true, desc: "钱包类型 不传查所有 ", mock: 1)]
  107. #[Apidoc\Returned(name: "order_no", type: "string", require: true, desc: '订单号', default: '23213213213217182937291')]
  108. #[Apidoc\Returned(name: "money", type: "string", require: true, desc: '提现金额', default: '100.00')]
  109. #[Apidoc\Returned(name: "status", type: "string", require: true, desc: '提现状态 1 待审核 2打款中 3审核通过 4驳回', default: '1')]
  110. #[Apidoc\Returned(name: "affiliated_bank", type: "string", require: true, desc: '归属银行', default: '中国银行')]
  111. #[Apidoc\Returned(name: "account_holder", type: "string", require: true, desc: '开户人', default: '张三')]
  112. #[Apidoc\Returned(name: "card_number", type: "string", require: true, desc: '卡号', default: '12321321376763274682374681')]
  113. #[Apidoc\Returned(name: "created_at", type: "date", require: true, desc: '申请时间', default: '2023-05-20 23:49:49')]
  114. #[Apidoc\Returned(name: "remarks", type: "date", require: true, desc: '驳回备注', default: '')]
  115. public function stream(Request $request)
  116. {
  117. $param = $request->param_data;
  118. $param = Arr::only($param, ['page', 'limit', 'mold']);
  119. $param['user_data'] = $request->user_data;
  120. try {
  121. Validator::input($param, [
  122. 'page' => Validator::notEmpty()->intType()->setName('页码'),
  123. 'limit' => Validator::notEmpty()->intType()->setName('输出条数'),
  124. ]);
  125. $data = WithdrawBusiness::stream($param);
  126. } catch (\Throwable $exception) {
  127. return error($exception->getMessage());
  128. }
  129. return success($data['data'], '成功', 200, $data['total']);
  130. }
  131. #[Apidoc\Title("转账")]
  132. #[Apidoc\Url("api/withdraw/transfer.html")]
  133. #[Apidoc\Method("POST")]
  134. #[Apidoc\Header("token", type: "string", require: true, desc: "身份令牌Token", mock: "@token")]
  135. #[Apidoc\Param("money", type: "int", require: true, desc: "提现金额", mock: 10)]
  136. #[Apidoc\Param("account_number", type: "string", require: true, desc: "收款账号:转账时候传 ", mock: 1)]
  137. #[Apidoc\Param(name: "pay_characteristic", type: "int", require: true, desc: '支付通道标识', default: '1')]
  138. public function transfer(Request $request)
  139. {
  140. $param = $request->param_data;
  141. $param['user_data'] = $request->user_data;
  142. Db::beginTransaction();
  143. try {
  144. Validator::input($param, [
  145. 'money' => Validator::notEmpty()->Number()->setName('提现金额'),
  146. 'account_number' => Validator::notEmpty()->setName('转账账号'),
  147. ]);
  148. if (!empty(Redis::get('1212' . $request->user_data['id']))) {
  149. throw new \Exception('请不要连续操作');
  150. }
  151. Redis::setEx('1212' . $request->user_data['id'], 10, $request->user_data['id']);
  152. $name = Db::table('wa_user_identity')->where('uid', $request->user_data['id'])->value('name');
  153. if (empty($name)) {
  154. throw new \Exception('请实名后再进行转账!');
  155. }
  156. $accountUser = Db::table('wa_users')->where('mobile',$param['account_number'])->first();
  157. if(empty($accountUser)){
  158. throw new \Exception('转账账号不存在!');
  159. }
  160. $userdata = Db::table('wa_users')->where('id',$param['user_data']['id'])->first();
  161. if(!empty($userdata) && $userdata->money_five>=$param['money']){
  162. StreamBusiness::delStream($param['user_data']['id'], $param['money'], streamType17, moldType5, moldTypefild5, $param['user_data']['id']);
  163. StreamBusiness::addStream($accountUser->id, $param['money'], streamType17, moldType5, moldTypefild5, $param['user_data']['id']);
  164. }else{
  165. throw new \Exception('世界币不足!');
  166. }
  167. } catch (\Throwable $exception) {
  168. Db::rollBack();
  169. return error($exception->getMessage());
  170. }
  171. Db::commit();
  172. return success([], '转账成功');
  173. }
  174. }