UserExtract.php 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: lianghuan
  5. * Date: 2018-03-03
  6. * Time: 16:37
  7. */
  8. namespace app\admin\controller\finance;
  9. use app\admin\controller\AuthController;
  10. use think\facade\Route as Url;
  11. use crmeb\services\JsonService;
  12. use app\admin\model\user\UserExtract as UserExtractModel;
  13. use crmeb\services\{UtilService as Util, FormBuilder as Form};
  14. /**
  15. * 用户提现管理
  16. * Class UserExtract
  17. * @package app\admin\controller\finance
  18. */
  19. class UserExtract extends AuthController
  20. {
  21. public function index()
  22. {
  23. $where = Util::getMore([
  24. ['status', ''],
  25. ['nickname', ''],
  26. ['extract_type', ''],
  27. ['nireid', ''],
  28. ['date', ''],
  29. ['uid', '']
  30. ], $this->request);
  31. $limitTimeList = [
  32. 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
  33. 'week' => implode(' - ', [
  34. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  35. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  36. ]),
  37. 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
  38. 'quarter' => implode(' - ', [
  39. date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
  40. date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
  41. ]),
  42. 'year' => implode(' - ', [
  43. date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
  44. ])
  45. ];
  46. $this->assign('where', $where);
  47. $this->assign('limitTimeList', $limitTimeList);
  48. $this->assign(UserExtractModel::extractStatistics());
  49. $this->assign(UserExtractModel::systemPage($where));
  50. return $this->fetch();
  51. }
  52. public function edit($id)
  53. {
  54. if (!$id) return $this->failed('数据不存在');
  55. $UserExtract = UserExtractModel::get($id);
  56. if (!$UserExtract) return JsonService::fail('数据不存在!');
  57. $f = array();
  58. $f[] = Form::input('real_name', '姓名', $UserExtract['real_name']);
  59. $f[] = Form::number('extract_price', '提现金额', $UserExtract['extract_price'])->precision(2);
  60. if ($UserExtract['extract_type'] == 'alipay') {
  61. $f[] = Form::input('alipay_code', '支付宝账号', $UserExtract['alipay_code']);
  62. } else if ($UserExtract['extract_type'] == 'weixin') {
  63. $f[] = Form::input('wechat', '微信号', $UserExtract['wechat']);
  64. } else {
  65. $f[] = Form::input('bank_code', '银行卡号', $UserExtract['bank_code']);
  66. $f[] = Form::input('bank_address', '开户行', $UserExtract['bank_address']);
  67. }
  68. $f[] = Form::input('mark', '备注', $UserExtract['mark'])->type('textarea');
  69. $form = Form::make_post_form('编辑', $f, Url::buildUrl('update', array('id' => $id)));
  70. $this->assign(compact('form'));
  71. return $this->fetch('public/form-builder');
  72. }
  73. public function update($id)
  74. {
  75. $UserExtract = UserExtractModel::get($id);
  76. if (!$UserExtract) return JsonService::fail('数据不存在!');
  77. if ($UserExtract['extract_type'] == 'alipay') {
  78. $data = Util::postMore([
  79. 'real_name',
  80. 'mark',
  81. 'extract_price',
  82. 'alipay_code',
  83. ]);
  84. if (!$data['real_name']) return JsonService::fail('请输入姓名');
  85. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  86. if (!$data['alipay_code']) return JsonService::fail('请输入支付宝账号');
  87. } else if ($UserExtract['extract_type'] == 'weixin') {
  88. $data = Util::postMore([
  89. 'real_name',
  90. 'mark',
  91. 'extract_price',
  92. 'wechat',
  93. ]);
  94. // if(!$data['real_name']) return JsonService::fail('请输入姓名');
  95. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  96. if (!$data['wechat']) return JsonService::fail('请输入微信账号');
  97. } else {
  98. $data = Util::postMore([
  99. 'real_name',
  100. 'extract_price',
  101. 'mark',
  102. 'bank_code',
  103. 'bank_address',
  104. ]);
  105. if (!$data['real_name']) return JsonService::fail('请输入姓名');
  106. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  107. if (!$data['bank_code']) return JsonService::fail('请输入银行卡号');
  108. if (!$data['bank_address']) return JsonService::fail('请输入开户行');
  109. }
  110. if (!UserExtractModel::edit($data, $id))
  111. return JsonService::fail(UserExtractModel::getErrorInfo('修改失败'));
  112. else
  113. return JsonService::successful('修改成功!');
  114. }
  115. public function fail($id)
  116. {
  117. if (!UserExtractModel::be(['id' => $id, 'status' => 0])) return JsonService::fail('操作记录不存在或状态错误!');
  118. $fail_msg = request()->post();
  119. $extract = UserExtractModel::get($id);
  120. if (!$extract) return JsonService::fail('操作记录不存在!');
  121. if ($extract->status == 1) return JsonService::fail('已经提现,错误操作');
  122. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝,请勿重复操作!');
  123. $res = UserExtractModel::changeFail($id, $fail_msg['message']);
  124. if ($res) {
  125. return JsonService::successful('操作成功!');
  126. } else {
  127. return JsonService::fail('操作失败!');
  128. }
  129. }
  130. public function succ($id)
  131. {
  132. if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
  133. return JsonService::fail('操作记录不存在或状态错误!');
  134. if (cache('admin')) return JsonService::fail('操作时间请间隔5秒');
  135. cache('admin', 1, 5);
  136. UserExtractModel::beginTrans();
  137. $extract = UserExtractModel::lock(true)->find($id);
  138. if (!$extract) return JsonService::fail('操作记录不存!');
  139. if ($extract->status == 1) return JsonService::fail('您已提现,请勿重复提现!');
  140. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝!');
  141. $res = UserExtractModel::changeSuccess($id);
  142. if ($res) {
  143. $this->withdrawal($extract);
  144. UserExtractModel::commitTrans();
  145. return JsonService::successful('操作成功!');
  146. } else {
  147. UserExtractModel::rollbackTrans();
  148. return JsonService::fail('操作失败!');
  149. }
  150. }
  151. public function withdrawal($extract)
  152. {
  153. if ($extract['extract_type'] == 'alipay'){
  154. $data = [
  155. 'merchantId' => '7277383783', // 商户号
  156. 'merReqNo' => time(), // 交易流水号
  157. 'amt' => $extract['extract_price']*100,//交易金额
  158. 'pubOrPri' => 0,//支付宝通道: 1 到卡 0 到户
  159. 'cardName' => $extract['real_name'],
  160. 'notifyUrl' => '',// 回调地址
  161. 'pan' => $extract['alipay_code'], // 银行卡号
  162. 'orderTitle' => '提现', // 提款标题
  163. 'tranDateTime' => date('YmdHis')
  164. ];
  165. }elseif ($extract['extract_type'] == 'bank'){
  166. $data = [
  167. 'merchantId' => '7277383783', // 商户号
  168. 'merReqNo' => time(), // 交易流水号
  169. 'amt' => $extract['extract_price']*100,//交易金额
  170. 'pubOrPri' => 1,//支付宝通道: 1 到卡 0 到户
  171. 'cardName' => $extract['bank_address'],
  172. 'notifyUrl' => '',// 回调地址
  173. 'pan' => $extract['bank_code'], // 银行卡号
  174. 'orderTitle' => '提现', // 提款标题
  175. 'tranDateTime' => date('YmdHis')
  176. ];
  177. }
  178. $data['sign'] = sing($data, 'gcn08Swhn3W5ZrTLAJANtOoZd7AXWGlV');
  179. $url = 'http://sandcash.huaweigu.com/ctp/view/server/aotori/propayTrans';
  180. $result = do_request($url, $data);
  181. $res = json_decode($result);
  182. if ($res->respCode != 0000){
  183. return JsonService::fail($res->respDesc);
  184. }
  185. }
  186. }