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.

165 lines
5.0 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
  1. <?php
  2. namespace App\Http\Logic;
  3. use DB;
  4. use App\Common\ReturnData;
  5. use App\Http\Model\UserPoint;
  6. use App\Http\Requests\UserPointRequest;
  7. use Validator;
  8. class UserPointLogic extends BaseLogic
  9. {
  10. public function __construct()
  11. {
  12. parent::__construct();
  13. }
  14. public function getModel()
  15. {
  16. return new UserPoint();
  17. }
  18. public function getValidate($data, $scene_name)
  19. {
  20. //数据验证
  21. $validate = new UserPointRequest();
  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'] 排序
  67. * @param int $data['type'] 0增加,1减少
  68. * @param float $data['point'] 积分
  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['point']<=0){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  78. $data['add_time'] = time();
  79. DB::beginTransaction(); //启动事务
  80. if($data['type'] == UserPoint::USER_POINT_INCREMENT)
  81. {
  82. //增加用户余额
  83. model('User')->getDb()->where(array('id'=>$data['user_id']))->increment('point', $data['point']);
  84. }
  85. elseif($data['type'] == UserPoint::USER_POINT_DECREMENT)
  86. {
  87. //减少用户余额
  88. model('User')->getDb()->where(array('id'=>$data['user_id']))->decrement('point', $data['point']);
  89. }
  90. else
  91. {
  92. DB::rollBack(); //事务回滚
  93. return ReturnData::create(ReturnData::FAIL);
  94. }
  95. $user_point = model('User')->getDb()->where(array('id'=>$data['user_id']))->value('point'); //用户余额
  96. $data['user_point'] = $user_point;
  97. $res = $this->getModel()->add($data,$type);
  98. if($res)
  99. {
  100. DB::commit(); //事务提交
  101. return ReturnData::create(ReturnData::SUCCESS,$res);
  102. }
  103. return ReturnData::create(ReturnData::FAIL);
  104. }
  105. //修改
  106. public function edit($data, $where = array())
  107. {
  108. if(empty($data)){return ReturnData::create(ReturnData::SUCCESS);}
  109. $validator = $this->getValidate($data, 'edit');
  110. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  111. $res = $this->getModel()->edit($data,$where);
  112. if($res){return ReturnData::create(ReturnData::SUCCESS,$res);}
  113. return ReturnData::create(ReturnData::FAIL);
  114. }
  115. //删除
  116. public function del($where)
  117. {
  118. if(empty($where)){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  119. $validator = $this->getValidate($where,'del');
  120. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  121. $res = $this->getModel()->del($where);
  122. if($res){return ReturnData::create(ReturnData::SUCCESS,$res);}
  123. return ReturnData::create(ReturnData::FAIL);
  124. }
  125. /**
  126. * 数据获取器
  127. * @param array $data 要转化的数据
  128. * @return array
  129. */
  130. private function getDataView($data = array())
  131. {
  132. return getDataAttr($this->getModel(),$data);
  133. }
  134. }