TopicRepository.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: Administrator
  5. * Date: 2019-06-10
  6. * Time: 18:12
  7. */
  8. namespace App\Repositories;
  9. use App\Models\Category;
  10. use App\Models\CategoryTopic;
  11. use App\Models\Topic;
  12. use Dingo\Api\Http\Response;
  13. use Illuminate\Support\Facades\DB;
  14. use Illuminate\Database\QueryException;
  15. use Illuminate\Support\Facades\Log;
  16. use Illuminate\Support\Facades\Redis;
  17. class TopicRepository {
  18. public function __construct(Topic $topic,CategoryTopic $categoryTopic){
  19. $this->topic = $topic;
  20. $this->categoryTopic = $categoryTopic;
  21. }
  22. //列表
  23. public function index($request){
  24. $perPage = isset($request['per_page']) ? $request['per_page'] : 20;
  25. $where = [];
  26. if(isset($request['name'])){
  27. $where[] = ['name', 'like', "%{$request['name']}%"];
  28. }
  29. if(isset($request['topic_status'])){
  30. if($request['topic_status'] == 'is_suggest'){
  31. $where[] = ['is_suggest', 1];
  32. }
  33. if( $request['topic_status'] == 'is_hot'){
  34. $where[] = ['is_hot', 1];
  35. }
  36. if($request['topic_status'] == 'is_open'){
  37. $where[] = ['is_open', 1];
  38. }
  39. if($request['topic_status'] == 'is_close'){
  40. $where[] = ['is_open', 0];
  41. }
  42. }
  43. return $this->topic
  44. ->where($where)
  45. ->orderBy('is_hot','desc')
  46. ->orderBy('is_suggest','desc')
  47. ->orderBy('is_open','desc')
  48. ->orderBy('id','desc')
  49. ->paginate($perPage);
  50. }
  51. //新增
  52. public function create($request){
  53. $topic = $this->topic->where(['name'=>$request['name']])->first();
  54. if($topic){
  55. return Response::create([
  56. 'message' => '该话题已存在',
  57. 'status_code' => 500
  58. ]);
  59. }
  60. $data = [
  61. 'name' => $request['name'],
  62. 'img' => $request['img'],
  63. 'desc' => $request['desc'],
  64. ];
  65. if(!empty($request['base_count'])){
  66. $data['base_count'] = $request['base_count'];
  67. }
  68. if(isset($request['category_ids'])){
  69. $category_ids = explode(',', $request['category_ids']);
  70. }
  71. DB::beginTransaction();
  72. try{
  73. $topicInfo = $this->topic->create($data);
  74. if($topicInfo){
  75. if($category_ids){
  76. $category_topic_data = [];
  77. foreach($category_ids as $value){
  78. $category_topic_data[] = [
  79. 'category_id' => $value,
  80. 'topic_id' => $topicInfo->id,
  81. ];
  82. }
  83. $this->categoryTopic->insert($category_topic_data);
  84. }
  85. }
  86. DB::commit();
  87. Redis::zadd('topic.name', $topicInfo->id, $topicInfo->name);
  88. return Response::create();
  89. }catch (QueryException $exception){
  90. DB::rollBack();
  91. Log::debug('新增话题:'.$exception->getMessage());
  92. return Response::create([
  93. 'message' => '新增话题,请重试',
  94. 'error' => $exception->getMessage(),
  95. 'status_code' => 500
  96. ]);
  97. }
  98. }
  99. public function edit($request){
  100. $topic = $this->topic->where(['id'=>$request['id']])->first();
  101. if(!$topic){
  102. return Response::create([
  103. 'message' => '该话题不存在',
  104. 'status_code' => 500
  105. ]);
  106. }
  107. $oldName = $topic->name;
  108. $_topic = $this->topic->where(['name'=>$request['name']])->where('id','<>',$topic->id)->first();
  109. if($_topic){
  110. return Response::create([
  111. 'message' => '该话题已存在',
  112. 'status_code' => 500
  113. ]);
  114. }
  115. $topic->name = $request['name'];
  116. $topic->img = $request['img'];
  117. $topic->desc = $request['desc'];
  118. if(!empty($request['base_count'])){
  119. $topic->base_count = $request['base_count'];
  120. }
  121. $category_ids = [];
  122. if(!empty($request['category_ids'])){
  123. $category_ids = explode(',', $request['category_ids']);
  124. }
  125. DB::beginTransaction();
  126. try{
  127. //保存
  128. $topicInfo = $topic->save();
  129. //删除原来关联关系
  130. $this->categoryTopic->where(['topic_id'=>$topic->id])->delete();
  131. if($topicInfo){
  132. if($category_ids){
  133. $category_topic_data = [];
  134. foreach($category_ids as $value){
  135. $category_topic_data[] = [
  136. 'category_id' => $value,
  137. 'topic_id' => $topic->id,
  138. ];
  139. }
  140. $this->categoryTopic->insert($category_topic_data);
  141. }
  142. }
  143. DB::commit();
  144. if($oldName != $topic->name){
  145. Redis::zrem('topic.name', $oldName);
  146. Redis::zadd('topic.name', $topic->id, $topic->name);
  147. }
  148. return Response::create();
  149. }catch (QueryException $exception){
  150. DB::rollBack();
  151. Log::debug('编辑话题:'.$exception->getMessage());
  152. return Response::create([
  153. 'message' => '编辑话题,请重试',
  154. 'error' => $exception->getMessage(),
  155. 'status_code' => 500
  156. ]);
  157. }
  158. }
  159. //修改
  160. public function update($request){
  161. $topic = $this->topic->where('id', $request['id'])->first();
  162. if(!$topic){
  163. return Response::create([
  164. 'message' => '该话题不存在',
  165. 'status_code' => 500
  166. ]);
  167. }
  168. if(isset($request['is_open']) && $request['is_open'] !== null){
  169. $topic->is_open = $request['is_open'];
  170. }
  171. if(!empty($request['type'])){
  172. if($topic->is_open == 0){
  173. return Response::create([
  174. 'message' => '该话题未开启',
  175. 'status_code' => 500
  176. ]);
  177. }
  178. if(isset($request['type']) && $request['type'] == 1){
  179. $topic->is_suggest = $request['status'];
  180. }
  181. if(isset($request['type']) && $request['type'] == 2){
  182. $topic->is_hot = $request['status'];
  183. }
  184. }
  185. $res = $topic->save();
  186. if($res){
  187. return Response::create();
  188. }
  189. }
  190. //详情
  191. public function view($request){
  192. return $this->topic->where('id', $request['id'])->first();
  193. }
  194. //获取多个话题
  195. public function getTopics($ids = []){
  196. return $this->topic->whereIn('id', $ids)->select('id','name')->get();
  197. }
  198. /**
  199. * 重置话题redis
  200. */
  201. public function resetRedis()
  202. {
  203. $TopicName = $this->topic->pluck('id', 'name')->toArray();
  204. $res = Redis::zadd('topic.name', $TopicName);
  205. if($res){
  206. return Response::create([
  207. 'message' => '重置话题成功',
  208. 'status_code' => 500
  209. ]);
  210. }else{
  211. return Response::create([
  212. 'message' => '重置话题失败',
  213. 'status_code' => 500
  214. ]);
  215. }
  216. }
  217. }