UserExtract.php 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  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 app\admin\model\wechat\WechatUser;
  11. use app\models\system\SystemStoreMember;
  12. use app\models\user\UserBill;
  13. use think\facade\Route as Url;
  14. use crmeb\services\JsonService;
  15. use app\admin\model\user\UserExtract as UserExtractModel;
  16. use crmeb\services\{UtilService as Util, FormBuilder as Form, WechatService};
  17. /**
  18. * 用户提现管理
  19. * Class UserExtract
  20. * @package app\admin\controller\finance
  21. */
  22. class UserExtract extends AuthController
  23. {
  24. public function index()
  25. {
  26. $where = Util::getMore([
  27. ['status', ''],
  28. ['nickname', ''],
  29. ['extract_type', ''],
  30. ['nireid', ''],
  31. ['date', ''],
  32. ], $this->request);
  33. $limitTimeList = [
  34. 'today' => implode(' - ', [date('Y/m/d'), date('Y/m/d', strtotime('+1 day'))]),
  35. 'week' => implode(' - ', [
  36. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  37. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  38. ]),
  39. 'month' => implode(' - ', [date('Y/m') . '/01', date('Y/m') . '/' . date('t')]),
  40. 'quarter' => implode(' - ', [
  41. date('Y') . '/' . (ceil((date('n')) / 3) * 3 - 3 + 1) . '/01',
  42. date('Y') . '/' . (ceil((date('n')) / 3) * 3) . '/' . date('t', mktime(0, 0, 0, (ceil((date('n')) / 3) * 3), 1, date('Y')))
  43. ]),
  44. 'year' => implode(' - ', [
  45. date('Y') . '/01/01', date('Y/m/d', strtotime(date('Y') . '/01/01 + 1year -1 day'))
  46. ])
  47. ];
  48. $this->assign('where', $where);
  49. $this->assign('limitTimeList', $limitTimeList);
  50. $this->assign(UserExtractModel::extractStatistics());
  51. $this->assign(UserExtractModel::systemPage($where));
  52. return $this->fetch();
  53. }
  54. public function edit($id)
  55. {
  56. if (!$id) return $this->failed('数据不存在');
  57. $UserExtract = UserExtractModel::get($id);
  58. if (!$UserExtract) return JsonService::fail('数据不存在!');
  59. $f = array();
  60. $f[] = Form::input('real_name', '姓名', $UserExtract['real_name']);
  61. $f[] = Form::number('extract_price', '提现金额', $UserExtract['extract_price'])->precision(2);
  62. if ($UserExtract['extract_type'] == 'alipay') {
  63. $f[] = Form::input('alipay_code', '支付宝账号', $UserExtract['alipay_code']);
  64. } else if ($UserExtract['extract_type'] == 'weixin') {
  65. $f[] = Form::input('wechat', '微信号', $UserExtract['wechat']);
  66. } else {
  67. $f[] = Form::input('bank_code', '银行卡号', $UserExtract['bank_code']);
  68. $f[] = Form::input('bank_address', '开户行', $UserExtract['bank_address']);
  69. }
  70. $f[] = Form::input('mark', '备注', $UserExtract['mark'])->type('textarea');
  71. $form = Form::make_post_form('编辑', $f, Url::buildUrl('update', array('id' => $id)));
  72. $this->assign(compact('form'));
  73. return $this->fetch('public/form-builder');
  74. }
  75. public function update($id)
  76. {
  77. $UserExtract = UserExtractModel::get($id);
  78. if (!$UserExtract) return JsonService::fail('数据不存在!');
  79. if ($UserExtract['extract_type'] == 'alipay') {
  80. $data = Util::postMore([
  81. 'real_name',
  82. 'mark',
  83. 'extract_price',
  84. 'alipay_code',
  85. ]);
  86. if (!$data['real_name']) return JsonService::fail('请输入姓名');
  87. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  88. if (!$data['alipay_code']) return JsonService::fail('请输入支付宝账号');
  89. } else if ($UserExtract['extract_type'] == 'weixin') {
  90. $data = Util::postMore([
  91. 'real_name',
  92. 'mark',
  93. 'extract_price',
  94. 'wechat',
  95. ]);
  96. // if(!$data['real_name']) return JsonService::fail('请输入姓名');
  97. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  98. if (!$data['wechat']) return JsonService::fail('请输入微信账号');
  99. } else {
  100. $data = Util::postMore([
  101. 'real_name',
  102. 'extract_price',
  103. 'mark',
  104. 'bank_code',
  105. 'bank_address',
  106. ]);
  107. if (!$data['real_name']) return JsonService::fail('请输入姓名');
  108. if ($data['extract_price'] <= -1) return JsonService::fail('请输入提现金额');
  109. if (!$data['bank_code']) return JsonService::fail('请输入银行卡号');
  110. if (!$data['bank_address']) return JsonService::fail('请输入开户行');
  111. }
  112. if (!UserExtractModel::edit($data, $id))
  113. return JsonService::fail(UserExtractModel::getErrorInfo('修改失败'));
  114. else
  115. return JsonService::successful('修改成功!');
  116. }
  117. public function fail($id)
  118. {
  119. if (!UserExtractModel::be(['id' => $id, 'status' => 0])) return JsonService::fail('操作记录不存在或状态错误!');
  120. $fail_msg = request()->post();
  121. $extract = UserExtractModel::get($id);
  122. if (!$extract) return JsonService::fail('操作记录不存在!');
  123. if ($extract->status == 1) return JsonService::fail('已经提现,错误操作');
  124. if ($extract->status == -1) return JsonService::fail('您的提现申请已被拒绝,请勿重复操作!');
  125. $res = UserExtractModel::changeFail($id, $fail_msg['message']);
  126. if ($res) {
  127. return JsonService::successful('操作成功!');
  128. } else {
  129. return JsonService::fail('操作失败!');
  130. }
  131. }
  132. public function succ($id)
  133. {
  134. if (!UserExtractModel::be(['id' => $id, 'status' => 0]))
  135. return JsonService::fail('操作记录不存在或状态错误!');
  136. UserExtractModel::beginTrans();
  137. $extract = UserExtractModel::get($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 ($extract['commission_consumer'] > 0) {
  143. $res = $res && UserBill::income('提现转换(消费券)', $extract['uid'], 'consumer', 'extract_get_consumer', $extract['commission_consumer'], $extract['id'], \app\admin\model\user\User::where('uid', $extract['uid'])->value('consumer') + $extract['commission_consumer'], '提现申请通过,其中部分佣金转换为消费券' . $extract['commission_consumer']);
  144. $res = $res && \app\admin\model\user\User::where('uid', $extract['uid'])->inc('consumer', $extract['commission_consumer'])->update();
  145. }
  146. if ($extract['commission_yue'] > 0) {
  147. $res = $res && UserBill::income('提现转换(余额)', $extract['uid'], 'now_money', 'extract_get_now_money', $extract['commission_yue'], $extract['id'], \app\admin\model\user\User::where('uid', $extract['uid'])->value('now_money') + $extract['commission_yue'], '提现申请通过,其中部分佣金转换为余额' . $extract['commission_yue']);
  148. $res = $res && \app\admin\model\user\User::where('uid', $extract['uid'])->inc('now_money', $extract['commission_yue'])->update();
  149. }
  150. if ($extract['commission_gf'] > 0) {
  151. $res = $res && UserBill::income('提现转换(股份)', $extract['uid'], 'gf', 'extract_get_gf', $extract['commission_gf'], $extract['id'], \app\admin\model\user\User::where('uid', $extract['uid'])->value('gf') + $extract['commission_gf'], '提现申请通过,其中部分佣金转换为股份' . $extract['commission_gf']);
  152. $res = $res && \app\admin\model\user\User::where('uid', $extract['uid'])->inc('gf', $extract['commission_gf'])->update();
  153. }
  154. $real_get = $extract['extract_price'] - $extract['commission_gf'] - $extract['commission_consumer'] - $extract['commission_yue'] - $extract['commission'];
  155. if ($res && $real_get >= 0.3 && $extract['extract_type'] == 'weixin') {
  156. $open_id = WechatUser::where('uid', $extract['uid'])->find();
  157. if ($open_id['openid']) {
  158. try {
  159. WechatService::paymentService()->batches(
  160. 'ex' . date('YmdHis') . $extract['id'],
  161. $open_id['openid'],
  162. $real_get * 100,
  163. sys_config('site_name') . '-' . '用户提现到账'
  164. );
  165. } catch (\Exception $e) {
  166. UserExtractModel::rollbackTrans();
  167. return JsonService::fail($e->getMessage());
  168. }
  169. }
  170. }
  171. // if ($extract['commission_gf'] > 0 && SystemStoreMember::be(['uid' => $extract['uid']])) {
  172. // $res = $res && SystemStoreMember::where('uid', $extract['uid'])->inc('consume_rights', $extract['commission_gf'])->update();
  173. // }
  174. if ($res) {
  175. UserExtractModel::commitTrans();
  176. return JsonService::successful('操作成功!');
  177. } else {
  178. UserExtractModel::rollbackTrans();
  179. return JsonService::fail('操作失败!');
  180. }
  181. }
  182. }