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.

171 lines
5.3 KiB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 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\Requests\UserMoneyRequest;
  7. use Validator;
  8. class UserMoneyLogic extends BaseLogic
  9. {
  10. public function __construct()
  11. {
  12. parent::__construct();
  13. }
  14. public function getModel()
  15. {
  16. return new UserMoney();
  17. }
  18. public function getValidate($data, $scene_name)
  19. {
  20. //数据验证
  21. $validate = new UserMoneyRequest();
  22. return Validator::make($data, $validate->getSceneRules($scene_name), $validate->getSceneRulesMessages());
  23. }
  24. //列表
  25. public function getList($where = array(), $order = '', $field = '*', $offset = '', $limit = '')
  26. {
  27. $res = $this->getModel()->getList($where, $order, $field, $offset, $limit);
  28. if($res['count'] > 0)
  29. {
  30. foreach($res['list'] as $k=>$v)
  31. {
  32. $res['list'][$k] = $this->getDataView($v);
  33. }
  34. }
  35. return $res;
  36. }
  37. //分页html
  38. public function getPaginate($where = array(), $order = '', $field = '*', $limit = '')
  39. {
  40. $res = $this->getModel()->getPaginate($where, $order, $field, $limit);
  41. return $res;
  42. }
  43. //全部列表
  44. public function getAll($where = array(), $order = '', $field = '*', $limit = '')
  45. {
  46. $res = $this->getModel()->getAll($where, $order, $field, $limit);
  47. /* if($res)
  48. {
  49. foreach($res as $k=>$v)
  50. {
  51. $res[$k] = $this->getDataView($v);
  52. }
  53. } */
  54. return $res;
  55. }
  56. //详情
  57. public function getOne($where = array(), $field = '*')
  58. {
  59. $res = $this->getModel()->getOne($where, $field);
  60. if(!$res){return false;}
  61. $res = $this->getDataView($res);
  62. return $res;
  63. }
  64. /**
  65. * 添加一条记录,并增加或减少用户余额,会操作用户余额表,谨慎使用
  66. * @param int $data['user_id'] 用户id
  67. * @param int $data['type'] 0增加,1减少
  68. * @param float $data['money'] 金额
  69. * @param string $data['des'] 描述
  70. * @return array
  71. */
  72. public function add($data = array(), $type=0)
  73. {
  74. if(empty($data)){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  75. $validator = $this->getValidate($data, 'add');
  76. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  77. if($data['money']<=0){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  78. $user = model('User')->getOne(['id'=>$data['user_id']]);
  79. if(!$user){return ReturnData::create(ReturnData::PARAMS_ERROR,null,'用户不存在');}
  80. $data['add_time'] = time();
  81. DB::beginTransaction(); //启动事务
  82. if($data['type'] == UserMoney::USER_MONEY_INCREMENT)
  83. {
  84. //增加用户余额
  85. model('User')->getDb()->where(array('id'=>$data['user_id']))->increment('money', $data['money']);
  86. }
  87. elseif($data['type'] == UserMoney::USER_MONEY_DECREMENT)
  88. {
  89. //判断用户余额是否足够
  90. if($data['money']>$user->money){return ReturnData::create(ReturnData::FAIL,null,'余额不足');}
  91. //减少用户余额
  92. model('User')->getDb()->where(array('id'=>$data['user_id']))->decrement('money', $data['money']);
  93. }
  94. else
  95. {
  96. DB::rollBack(); //事务回滚
  97. return ReturnData::create(ReturnData::FAIL);
  98. }
  99. $user_money = model('User')->getDb()->where(array('id'=>$data['user_id']))->value('money'); //用户余额
  100. $data['user_money'] = $user_money;
  101. $res = $this->getModel()->add($data,$type);
  102. if($res)
  103. {
  104. DB::commit(); //事务提交
  105. return ReturnData::create(ReturnData::SUCCESS,$res);
  106. }
  107. return ReturnData::create(ReturnData::FAIL);
  108. }
  109. //修改
  110. public function edit($data, $where = array())
  111. {
  112. if(empty($data)){return ReturnData::create(ReturnData::SUCCESS);}
  113. $validator = $this->getValidate($data, 'edit');
  114. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  115. $res = $this->getModel()->edit($data,$where);
  116. if($res){return ReturnData::create(ReturnData::SUCCESS,$res);}
  117. return ReturnData::create(ReturnData::FAIL);
  118. }
  119. //删除
  120. public function del($where)
  121. {
  122. if(empty($where)){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  123. $validator = $this->getValidate($where,'del');
  124. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  125. $res = $this->getModel()->del($where);
  126. if($res){return ReturnData::create(ReturnData::SUCCESS,$res);}
  127. return ReturnData::create(ReturnData::FAIL);
  128. }
  129. /**
  130. * 数据获取器
  131. * @param array $data 要转化的数据
  132. * @return array
  133. */
  134. private function getDataView($data = array())
  135. {
  136. return getDataAttr($this->getModel(),$data);
  137. }
  138. }