You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

194 lines
6.6 KiB

6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
  1. <?php
  2. namespace App\Http\Logic;
  3. use DB;
  4. use App\Common\ReturnData;
  5. use App\Http\Model\UserMoney;
  6. use App\Http\Model\UserWithdraw;
  7. use App\Http\Requests\UserWithdrawRequest;
  8. use Validator;
  9. class UserWithdrawLogic extends BaseLogic
  10. {
  11. public function __construct()
  12. {
  13. parent::__construct();
  14. }
  15. public function getModel()
  16. {
  17. return new UserWithdraw();
  18. }
  19. public function getValidate($data, $scene_name)
  20. {
  21. //数据验证
  22. $validate = new UserWithdrawRequest();
  23. return Validator::make($data, $validate->getSceneRules($scene_name), $validate->getSceneRulesMessages());
  24. }
  25. //列表
  26. public function getList($where = array(), $order = '', $field = '*', $offset = '', $limit = '')
  27. {
  28. $res = $this->getModel()->getList($where, $order, $field, $offset, $limit);
  29. if($res['count'] > 0)
  30. {
  31. foreach($res['list'] as $k=>$v)
  32. {
  33. $res['list'][$k] = $this->getDataView($v);
  34. }
  35. }
  36. return $res;
  37. }
  38. //分页html
  39. public function getPaginate($where = array(), $order = '', $field = '*', $limit = '')
  40. {
  41. $res = $this->getModel()->getPaginate($where, $order, $field, $limit);
  42. return $res;
  43. }
  44. //全部列表
  45. public function getAll($where = array(), $order = '', $field = '*', $limit = '')
  46. {
  47. $res = $this->getModel()->getAll($where, $order, $field, $limit);
  48. /* if($res)
  49. {
  50. foreach($res as $k=>$v)
  51. {
  52. $res[$k] = $this->getDataView($v);
  53. }
  54. } */
  55. return $res;
  56. }
  57. //详情
  58. public function getOne($where = array(), $field = '*')
  59. {
  60. $res = $this->getModel()->getOne($where, $field);
  61. if(!$res){return false;}
  62. $res = $this->getDataView($res);
  63. return $res;
  64. }
  65. //添加
  66. public function add($data = array(), $type=0)
  67. {
  68. if(empty($data)){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  69. $validator = $this->getValidate($data, 'add');
  70. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  71. if(isset($data['pay_password']) && !empty($data['pay_password'])){}else{return ReturnData::create(ReturnData::PARAMS_ERROR,null,'请输入支付密码');}
  72. $user = model('User')->getOne(array('id'=>$data['user_id'],'pay_password'=>$data['pay_password']));
  73. if(!$user){return ReturnData::create(ReturnData::PARAMS_ERROR,null,'支付密码错误');}
  74. unset($data['pay_password']);
  75. $min_withdraw_money = sysconfig('CMS_MIN_WITHDRAWAL_MONEY'); //最低可提现金额
  76. if($user->money<$data['money']){return ReturnData::create(ReturnData::PARAMS_ERROR,null,'余额不足');}
  77. if($user->money<$min_withdraw_money){return ReturnData::create(ReturnData::PARAMS_ERROR,null,'用户金额小于最小提现金额');}
  78. if($data['money']<$min_withdraw_money){return ReturnData::create(ReturnData::PARAMS_ERROR,null,'提现金额不得小于最小提现金额');}
  79. DB::beginTransaction();
  80. $data['add_time'] = time();
  81. $res = $this->getModel()->add($data,$type);
  82. if($res)
  83. {
  84. //添加用户余额记录并扣除用户余额
  85. $user_money_data['user_id'] = $data['user_id'];
  86. $user_money_data['type'] = UserMoney::USER_MONEY_DECREMENT;
  87. $user_money_data['money'] = $data['money'];
  88. $user_money_data['des'] = UserWithdraw::USER_WITHDRAW_DES;
  89. $user_money = logic('UserMoney')->add($user_money_data);
  90. if($user_money['code'] != ReturnData::SUCCESS){DB::rollBack();return false;}
  91. DB::commit();
  92. return ReturnData::create(ReturnData::SUCCESS,$res);
  93. }
  94. DB::rollBack();
  95. return ReturnData::create(ReturnData::FAIL);
  96. }
  97. //修改
  98. public function edit($data, $where = array())
  99. {
  100. if(empty($data)){return ReturnData::create(ReturnData::SUCCESS);}
  101. $validator = $this->getValidate($data, 'edit');
  102. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  103. $res = $this->getModel()->edit($data,$where);
  104. if($res){return ReturnData::create(ReturnData::SUCCESS,$res);}
  105. return ReturnData::create(ReturnData::FAIL);
  106. }
  107. //删除
  108. public function del($where)
  109. {
  110. if(empty($where)){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  111. $validator = $this->getValidate($where,'del');
  112. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  113. $res = $this->getModel()->edit(['delete_time'=>time()],$where);
  114. if($res){return ReturnData::create(ReturnData::SUCCESS,$res);}
  115. return ReturnData::create(ReturnData::FAIL);
  116. }
  117. /**
  118. * 数据获取器
  119. * @param array $data 要转化的数据
  120. * @return array
  121. */
  122. private function getDataView($data = array())
  123. {
  124. return getDataAttr($this->getModel(),$data);
  125. }
  126. /**
  127. * 取消/拒绝提现
  128. * @param int $where['id'] 提现id
  129. * @param int $data['status'] status=3取消或status=4拒绝
  130. * @param string $data['re_note'] 理由,选填
  131. * @return array
  132. */
  133. public function userWithdrawSuccessConfirm($data, $where)
  134. {
  135. if(empty($where) || empty($data)){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  136. if($data['status']!=3 || $data['status']!=4){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  137. $user_withdraw = $this->getModel()->getOne($where);
  138. if(!$user_withdraw){return false;}
  139. DB::beginTransaction();
  140. $data['updated_at'] = time();
  141. $res = $this->getModel()->edit($data,$where);
  142. if($res)
  143. {
  144. //添加用户余额记录并增加用户余额
  145. $user_money_data['user_id'] = $user_withdraw->user_id;
  146. $user_money_data['type'] = UserMoney::USER_MONEY_INCREMENT;
  147. $user_money_data['money'] = $user_withdraw->money;
  148. $user_money_data['des'] = '提现退回';
  149. $user_money = logic('UserMoney')->add($user_money_data);
  150. if($user_money['code'] != ReturnData::SUCCESS){DB::rollBack();return false;}
  151. DB::commit();
  152. return true;
  153. }
  154. DB::rollBack();
  155. return false;
  156. }
  157. }