StoreExtract.php 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. <?php
  2. /**
  3. *
  4. * @author: xaboy<365615158@qq.com>
  5. * @day: 2018/3/3
  6. */
  7. namespace app\admin\model\system;
  8. use crmeb\basic\BaseModel;
  9. use crmeb\services\workerman\ChannelService;
  10. use crmeb\traits\ModelTrait;
  11. /**
  12. * TODO 用户提现
  13. * Class UserExtract
  14. * @package app\models\user
  15. */
  16. class StoreExtract extends BaseModel
  17. {
  18. /**
  19. * 数据表主键
  20. * @var string
  21. */
  22. protected $pk = 'id';
  23. /**
  24. * 模型名称
  25. * @var string
  26. */
  27. protected $name = 'store_extract';
  28. use ModelTrait;
  29. //审核中
  30. const AUDIT_STATUS = 0;
  31. //未通过
  32. const FAIL_STATUS = -1;
  33. //已提现
  34. const SUCCESS_STATUS = 1;
  35. protected static $extractType = ['alipay', 'bank', 'weixin'];
  36. protected static $extractTypeMsg = ['alipay' => '支付宝', 'bank' => '银行卡', 'weixin' => '微信'];
  37. protected static $status = array(
  38. -1 => '未通过',
  39. 0 => '审核中',
  40. 1 => '已提现'
  41. );
  42. /**
  43. * 用户自主提现记录提现记录,后台执行审核
  44. * @param array $userInfo 用户个人信息
  45. * @param array $data 提现详细信息
  46. * @return bool
  47. */
  48. public static function userExtract($userInfo, $data)
  49. {
  50. if (!in_array($data['extract_type'], self::$extractType))
  51. return self::setErrorInfo('提现方式不存在');
  52. $userInfo = SystemStore::get($userInfo['id']);
  53. $extractPrice = $userInfo['money'];
  54. if ($extractPrice < 0) return self::setErrorInfo('提现余额不足' . $data['money']);
  55. if ($data['money'] > $extractPrice) return self::setErrorInfo('提现余额不足' . $data['money']);
  56. if ($data['money'] <= 0) return self::setErrorInfo('提现余额大于0');
  57. $balance = bcsub($userInfo['money'], $data['money'], 2);
  58. $commission = bcmul($data['money'], bcdiv($userInfo['commission'], 100, 3), 2);
  59. if ($balance < 0) $balance = 0;
  60. $insertData = [
  61. 'uid' => $userInfo['id'],
  62. 'extract_type' => $data['extract_type'],
  63. 'extract_price' => $data['money'],
  64. 'add_time' => time(),
  65. 'balance' => $balance,
  66. 'status' => self::AUDIT_STATUS,
  67. 'commission' => $commission,
  68. ];
  69. if (isset($data['name']) && strlen(trim($data['name']))) $insertData['real_name'] = $data['name'];
  70. else $insertData['real_name'] = $userInfo['nickname'];
  71. if (isset($data['cardnum'])) $insertData['bank_code'] = $data['cardnum'];
  72. else $insertData['bank_code'] = '';
  73. if (isset($data['bankname'])) $insertData['bank_address'] = $data['bankname'];
  74. else $insertData['bank_address'] = '';
  75. if (isset($data['weixin'])) $insertData['wechat'] = $data['weixin'];
  76. else $insertData['wechat'] = $userInfo['nickname'];
  77. if ($data['extract_type'] == 'alipay') {
  78. if (!$data['alipay_code']) return self::setErrorInfo('请输入支付宝账号');
  79. $insertData['alipay_code'] = $data['alipay_code'];
  80. $mark = '使用支付宝提现' . $insertData['extract_price'] . '元,手续费:' . $insertData['commission'] . ",实际到账:" . bcsub($insertData['extract_price'], $insertData['commission'], 2);
  81. } else if ($data['extract_type'] == 'bank') {
  82. if (!$data['cardnum']) return self::setErrorInfo('请输入银行卡账号');
  83. if (!$data['bankname']) return self::setErrorInfo('请输入开户行信息');
  84. $mark = '使用银联卡' . $insertData['bank_code'] . '提现' . $insertData['extract_price'] . '元,手续费:' . $insertData['commission'] . ",实际到账:" . bcsub($insertData['extract_price'], $insertData['commission'], 2);
  85. } else {
  86. if (!$data['weixin']) return self::setErrorInfo('请输入微信账号');
  87. $mark = '使用微信提现' . $insertData['extract_price'] . '元';
  88. }
  89. self::beginTrans();
  90. try {
  91. $res1 = self::create($insertData);
  92. if (!$res1) return self::setErrorInfo('提现失败');
  93. $res2 = SystemStore::edit(['money' => $balance], $userInfo['id'], 'id');
  94. $res3 = StoreBill::expend('提现', $userInfo['id'], 'extract', $data['money'], $res1['id'], $balance, $mark);
  95. $res = $res2 && $res3;
  96. if ($res) {
  97. self::commitTrans();
  98. //发送模板消息
  99. return true;
  100. } else return self::setErrorInfo('提现失败!');
  101. } catch (\Exception $e) {
  102. self::rollbackTrans();
  103. return self::setErrorInfo('提现失败!');
  104. }
  105. }
  106. /**
  107. * 获得用户提现总金额
  108. * @param $uid
  109. * @return mixed
  110. */
  111. public static function userExtractTotalPrice($uid, $status = 1, $where = [])
  112. {
  113. return self::getModelTime($where, self::where('uid', 'in', $uid)->where('status', $status))->sum('extract_price') ?: 0;
  114. }
  115. public static function extractStatistics()
  116. {
  117. //待提现金额
  118. $data['price'] = floatval(self::where('status', 0)->sum('extract_price'));
  119. //总获得
  120. $data['brokerage_count'] = StoreBill::getBrokerageCount();
  121. //已提现金额
  122. $data['priced'] = floatval(self::where('status', 1)->sum('extract_price'));
  123. //未提现金额
  124. $data['brokerage_not'] = bcsub(bcsub($data['brokerage_count'], $data['priced'], 2), $data['price'], 2);
  125. return compact('data');
  126. }
  127. /**
  128. * @param $where
  129. * @return array
  130. */
  131. public static function systemPage($where)
  132. {
  133. $model = new self;
  134. if ($where['date'] != '') {
  135. list($startTime, $endTime) = explode(' - ', $where['date']);
  136. $model = $model->where('a.add_time', '>', strtotime($startTime));
  137. $model = $model->where('a.add_time', '<', (int)bcadd(strtotime($endTime), 86400, 0));
  138. }
  139. if ($where['status'] != '') $model = $model->where('a.status', $where['status']);
  140. if ($where['extract_type'] != '') $model = $model->where('a.extract_type', $where['extract_type']);
  141. if ($where['nireid'] != '') $model = $model->where('a.real_name|a.id|b.name|a.bank_code|a.alipay_code', 'like', "%$where[nireid]%");
  142. $model = $model->alias('a');
  143. $model = $model->field('a.*,b.name as store_name');
  144. $model = $model->join('system_store b', 'b.id=a.store_id', 'LEFT');
  145. $model = $model->order('a.id desc');
  146. return self::page($model, $where);
  147. }
  148. public static function changeFail($id, $fail_msg)
  149. {
  150. $fail_time = time();
  151. $data = self::get($id);
  152. $extract_number = $data['extract_price'];
  153. $mark = '提现失败,退回' . $extract_number . '元';
  154. $uid = $data['store_id'];
  155. $status = -1;
  156. $User = SystemStore::where('id', $uid)->find()->toArray();
  157. StoreBill::income('提现失败', $uid, 'extract_fail', $extract_number, $id, bcadd($User['money'], $extract_number, 2), $mark);
  158. SystemStore::bcInc($uid, 'money', $extract_number, 'id');
  159. return self::edit(compact('fail_time', 'fail_msg', 'status'), $id);
  160. }
  161. public static function changeSuccess($id)
  162. {
  163. return self::edit(['status' => 1], $id);
  164. }
  165. }