DiscussionController.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\Discussion;
  4. use Illuminate\Http\Request;
  5. use App\Http\Resources\DiscussionResource;
  6. class DiscussionController extends Controller
  7. {
  8. /**
  9. * Display a listing of the resource.
  10. *
  11. * @return \Illuminate\Http\Response
  12. */
  13. public function index(Request $request)
  14. {
  15. //
  16. switch ($request->get('view')) {
  17. case 'res_id':
  18. $table = Discussion::where('res_id',$request->get('id'));
  19. break;
  20. case 'parent':
  21. $table = Discussion::where('parent',$request->get('id'));
  22. break;
  23. }
  24. if(!empty($search)){
  25. $table->where('title', 'like', $search."%");
  26. }
  27. if(!empty($request->get('order')) && !empty($request->get('dir'))){
  28. $table->orderBy($request->get('order'),$request->get('dir'));
  29. }else{
  30. $table->orderBy('updated_at','desc');
  31. }
  32. $count = $table->count();
  33. if(!empty($request->get('limit'))){
  34. $offset = 0;
  35. if(!empty($request->get("offset"))){
  36. $offset = $request->get("offset");
  37. }
  38. $table->skip($offset)->take($request->get('limit'));
  39. }
  40. $result = $table->get();
  41. if($result){
  42. return $this->ok(["rows"=>DiscussionResource::collection($result),"count"=>$count]);
  43. }else{
  44. return $this->error("没有查询到数据");
  45. }
  46. }
  47. /**
  48. * Store a newly created resource in storage.
  49. *
  50. * @param \Illuminate\Http\Request $request
  51. * @return \Illuminate\Http\Response
  52. */
  53. public function store(Request $request)
  54. {
  55. $user = \App\Http\Api\AuthApi::current($request);
  56. if(!$user){
  57. return $this->error(__('auth.failed'));
  58. }
  59. //
  60. // validate
  61. // read more on validation at http://laravel.com/docs/validation
  62. $rules = array(
  63. 'res_id' => 'required',
  64. 'res_type' => 'required',
  65. );
  66. if(!$request->has('parent')){
  67. $rules['title'] = 'required';
  68. }
  69. $validated = $request->validate($rules);
  70. $discussion = new Discussion;
  71. $discussion->res_id = $request->get('res_id');
  72. $discussion->res_type = $request->get('res_type');
  73. $discussion->title = $request->get('title',null);
  74. $discussion->content = $request->get('content',null);
  75. $discussion->parent = $request->get('parent',null);
  76. $discussion->editor_uid = $user['user_uid'];
  77. $discussion->save();
  78. return $this->ok(new DiscussionResource($discussion));
  79. }
  80. /**
  81. * Display the specified resource.
  82. *
  83. * @param \App\Models\Discussion $discussion
  84. * @return \Illuminate\Http\Response
  85. */
  86. public function show(Discussion $discussion)
  87. {
  88. //
  89. return $this->ok(new DiscussionResource($discussion));
  90. }
  91. /**
  92. * Update the specified resource in storage.
  93. *
  94. * @param \Illuminate\Http\Request $request
  95. * @param \App\Models\Discussion $discussion
  96. * @return \Illuminate\Http\Response
  97. */
  98. public function update(Request $request, Discussion $discussion)
  99. {
  100. //
  101. $user = \App\Http\Api\AuthApi::current($request);
  102. if(!$user){
  103. return $this->error(__('auth.failed'));
  104. }
  105. //
  106. if($discussion->editor !== $user['user_uid']){
  107. return $this->error(__('auth.failed'));
  108. }
  109. $discussion->title = $request->get('title',null);
  110. $discussion->content = $request->get('content',null);
  111. $discussion->editor_uid = $user['user_uid'];
  112. $discussion->save();
  113. return $this->ok($discussion);
  114. }
  115. /**
  116. * Remove the specified resource from storage.
  117. *
  118. * @param \App\Models\Discussion $discussion
  119. * @return \Illuminate\Http\Response
  120. */
  121. public function destroy(Discussion $discussion)
  122. {
  123. //
  124. $user = \App\Http\Api\AuthApi::current($request);
  125. if(!$user){
  126. return $this->error(__('auth.failed'));
  127. }
  128. //TODO 其他有权限的人也可以删除
  129. if($discussion->editor !== $user['user_uid']){
  130. return $this->error(__('auth.failed'));
  131. }
  132. $delete = $discussion->delete();
  133. return $this->ok($delete);
  134. }
  135. }