WithdrawController.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  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. $is_buy_jiaona = Db::table('wa_payorder')
  56. ->where('user_id', $request->user_data['id'])
  57. ->where('is_pay', 2)
  58. ->where('goods_type', 6)
  59. ->exists();
  60. if (!$is_buy_jiaona) {
  61. Db::rollBack();
  62. return error('请先完成全球通金卡激活后即可免费提现!', [], 4006);
  63. }
  64. $is_buy_jnbaozj = Db::table('wa_payorder')
  65. ->where('user_id', $request->user_data['id'])
  66. ->where('is_pay', 2)
  67. ->where('goods_type', 7)
  68. ->exists();
  69. if (!$is_buy_jnbaozj) {
  70. Db::rollBack();
  71. return error('请缴纳保证金,缴纳成功立即返还保证金!', [], 4006);
  72. }
  73. if ($param['mold'] == 2) {
  74. $carkdatalist = Db::table('wa_user_social_cark')
  75. ->where('user_id', $request->user_data['id'])->where('type', 1)->first();
  76. if (empty($carkdatalist)) {
  77. throw new \Exception('先领取WB.U卡在兑换!');
  78. }
  79. $msg = '兑换成功';
  80. } elseif ($param['mold'] == 5) {
  81. $carkdatalist = Db::table('wa_user_social_cark')
  82. ->where('user_id', $request->user_data['id'])->where('type', 1)->first();
  83. if (empty($carkdatalist)) {
  84. throw new \Exception('先领取WB.U卡在兑换!');
  85. }
  86. $msg = '兑换成功';
  87. } elseif ($param['mold'] == 6) {
  88. $carkdatalist = Db::table('wa_user_social_cark')
  89. ->where('user_id', $request->user_data['id'])->where('type', 1)->first();
  90. if (empty($carkdatalist)) {
  91. throw new \Exception('先领取WB.U卡在来提现!');
  92. }
  93. $msg = '提现成功';
  94. } elseif ($param['mold'] == 10) {
  95. $msg = '提现成功';
  96. } elseif ($param['mold'] == 1) {
  97. $msg = '提现成功';
  98. } elseif ($param['mold'] == 55) {
  99. $msg = '提现成功';
  100. } else {
  101. $account_holder = Db::table('wa_bank_card')->where('uid', $request->user_data['id'])->value('account_holder');
  102. if (empty($account_holder)) {
  103. throw new \Exception('请绑定银行卡!');
  104. }
  105. if ($account_holder != $name) {
  106. throw new \Exception('实名人和开户人不一致,请绑定实名人的银行卡!');
  107. }
  108. $msg = '提现成功';
  109. }
  110. $arr = WithdrawBusiness::applyfor($param);
  111. } catch (\Throwable $exception) {
  112. Db::rollBack();
  113. return error($exception->getMessage());
  114. }
  115. Db::commit();
  116. return success($arr, $msg);
  117. }
  118. #[Apidoc\Title("提现记录")]
  119. #[Apidoc\Url("api/withdraw/stream.html")]
  120. #[Apidoc\Method("POST")]
  121. #[Apidoc\Header("token", type: "string", require: true, desc: "身份令牌Token", mock: "@token")]
  122. #[Apidoc\Param("page", type: "int", require: true, desc: "页面", mock: 1)]
  123. #[Apidoc\Param("limit", type: "int", require: true, desc: "输入条数", mock: 10)]
  124. #[Apidoc\Param("mold", type: "int", require: true, desc: "钱包类型 不传查所有 ", mock: 1)]
  125. #[Apidoc\Returned(name: "order_no", type: "string", require: true, desc: '订单号', default: '23213213213217182937291')]
  126. #[Apidoc\Returned(name: "money", type: "string", require: true, desc: '提现金额', default: '100.00')]
  127. #[Apidoc\Returned(name: "status", type: "string", require: true, desc: '提现状态 1 待审核 2打款中 3审核通过 4驳回', default: '1')]
  128. #[Apidoc\Returned(name: "affiliated_bank", type: "string", require: true, desc: '归属银行', default: '中国银行')]
  129. #[Apidoc\Returned(name: "account_holder", type: "string", require: true, desc: '开户人', default: '张三')]
  130. #[Apidoc\Returned(name: "card_number", type: "string", require: true, desc: '卡号', default: '12321321376763274682374681')]
  131. #[Apidoc\Returned(name: "created_at", type: "date", require: true, desc: '申请时间', default: '2023-05-20 23:49:49')]
  132. #[Apidoc\Returned(name: "remarks", type: "date", require: true, desc: '驳回备注', default: '')]
  133. public function stream(Request $request)
  134. {
  135. $param = $request->param_data;
  136. $param = Arr::only($param, ['page', 'limit', 'mold']);
  137. $param['user_data'] = $request->user_data;
  138. try {
  139. Validator::input($param, [
  140. 'page' => Validator::notEmpty()->intType()->setName('页码'),
  141. 'limit' => Validator::notEmpty()->intType()->setName('输出条数'),
  142. ]);
  143. $data = WithdrawBusiness::stream($param);
  144. } catch (\Throwable $exception) {
  145. return error($exception->getMessage());
  146. }
  147. return success($data['data'], '成功', 200, $data['total']);
  148. }
  149. #[Apidoc\Title("转账")]
  150. #[Apidoc\Url("api/withdraw/transfer.html")]
  151. #[Apidoc\Method("POST")]
  152. #[Apidoc\Header("token", type: "string", require: true, desc: "身份令牌Token", mock: "@token")]
  153. #[Apidoc\Param("money", type: "int", require: true, desc: "提现金额", mock: 10)]
  154. #[Apidoc\Param("account_number", type: "string", require: true, desc: "收款账号:转账时候传 ", mock: 1)]
  155. #[Apidoc\Param(name: "pay_characteristic", type: "int", require: true, desc: '支付通道标识', default: '1')]
  156. public function transfer(Request $request)
  157. {
  158. $param = $request->param_data;
  159. $param['user_data'] = $request->user_data;
  160. Db::beginTransaction();
  161. try {
  162. Validator::input($param, [
  163. 'money' => Validator::notEmpty()->Number()->setName('提现金额'),
  164. 'account_number' => Validator::notEmpty()->setName('转账账号'),
  165. ]);
  166. if (!empty(Redis::get('1212' . $request->user_data['id']))) {
  167. throw new \Exception('请不要连续操作');
  168. }
  169. Redis::setEx('1212' . $request->user_data['id'], 10, $request->user_data['id']);
  170. $name = Db::table('wa_user_identity')->where('uid', $request->user_data['id'])->value('name');
  171. if (empty($name)) {
  172. throw new \Exception('请实名后再进行转账!');
  173. }
  174. $accountUser = Db::table('wa_users')->where('mobile', $param['account_number'])->first();
  175. if (empty($accountUser)) {
  176. throw new \Exception('转账账号不存在!');
  177. }
  178. $userdata = Db::table('wa_users')->where('id', $param['user_data']['id'])->first();
  179. if (!empty($userdata) && $userdata->money_five >= $param['money']) {
  180. StreamBusiness::delStream($param['user_data']['id'], $param['money'], streamType17, moldType5, moldTypefild5, $param['user_data']['id']);
  181. StreamBusiness::addStream($accountUser->id, $param['money'], streamType17, moldType5, moldTypefild5, $param['user_data']['id']);
  182. } else {
  183. throw new \Exception('世界币不足!');
  184. }
  185. } catch (\Throwable $exception) {
  186. Db::rollBack();
  187. return error($exception->getMessage());
  188. }
  189. Db::commit();
  190. return success([], '转账成功');
  191. }
  192. #[Apidoc\Title("银行转账")]
  193. #[Apidoc\Url("api/withdraw/cardtransfer.html")]
  194. #[Apidoc\Method("POST")]
  195. #[Apidoc\Header("token", type: "string", require: true, desc: "身份令牌Token", mock: "@token")]
  196. #[Apidoc\Param("affiliated_bank", type: "string", require: true, desc: "所属银行 ", mock: 1)]
  197. #[Apidoc\Param("name", type: "int", require: true, desc: '姓名', default: '')]
  198. #[Apidoc\Param("card_number", type: "int", require: true, desc: '卡号', default: '')]
  199. #[Apidoc\Param("remarks", type: "int", require: true, desc: '附言', default: '')]
  200. public function cardtransfer(Request $request)
  201. {
  202. $param = $request->param_data;
  203. $param['user_data'] = $request->user_data;
  204. Db::beginTransaction();
  205. try {
  206. Validator::input($param, [
  207. 'name' => Validator::notEmpty()->setName('姓名'),
  208. 'affiliated_bank' => Validator::notEmpty()->setName('所属银行'),
  209. ]);
  210. if (!empty(Redis::get('1212' . $request->user_data['id']))) {
  211. throw new \Exception('请不要连续操作');
  212. }
  213. Redis::setEx('1212' . $request->user_data['id'], 10, $request->user_data['id']);
  214. $userdata = Db::table('wa_users')->where('id', $param['user_data']['id'])->first();
  215. if (!empty($userdata) && 2000000 <= $param['user_data']['money_eighteen']) {
  216. $withdrawId = Db::table('wa_withdraw')->insertGetId([
  217. 'order_no' => date('YmdHis') . mt_rand(10000, 99999),
  218. 'user_id' => $param['user_data']['id'],
  219. 'money' => 2000000,
  220. 'type' => 18,
  221. 'affiliated_bank' => $param['affiliated_bank'],
  222. 'account_holder' => $param['name'],
  223. 'card_number' => $param['card_number'],
  224. 'name' => Arr::get($param, 'name', ''),
  225. 'identity' => Arr::get($param, 'identity', ''),
  226. 'img' => !empty(Arr::get($param, 'img', '')) ? implode(',', Arr::get($param, 'img', '')) : '',
  227. 'created_at' => date('Y-m-d H:i:s'),
  228. 'updated_at' => date('Y-m-d H:i:s'),
  229. 'status' => 1,
  230. 'remarks' => Arr::get($param, 'remarks', ''),
  231. ]);
  232. StreamBusiness::delStream($param['user_data']['id'], 2000000, streamType48, moldType18, moldTypefild18, $param['user_data']['id']);
  233. } else {
  234. throw new \Exception('卡内余额不足!');
  235. }
  236. } catch (\Throwable $exception) {
  237. Db::rollBack();
  238. return error($exception->getMessage());
  239. }
  240. Db::commit();
  241. return success([], '转账成功');
  242. }
  243. }