ArticleController.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\Article;
  4. use Illuminate\Http\Request;
  5. use Illuminate\Support\Str;
  6. class ArticleController 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. $indexCol = ['uid','title','subtitle','summary','owner','lang','status','updated_at','created_at'];
  17. switch ($request->get('view')) {
  18. case 'studio':
  19. # 获取studio内所有channel
  20. $user = \App\Http\Api\AuthApi::current($request);
  21. if($user){
  22. //判断当前用户是否有指定的studio的权限
  23. if($user['user_uid'] === \App\Http\Api\StudioApi::getIdByName($request->get('name'))){
  24. $table = Article::select($indexCol)->where('owner', $user["user_uid"]);
  25. }else{
  26. return $this->error(__('auth.failed'));
  27. }
  28. }else{
  29. return $this->error(__('auth.failed'));
  30. }
  31. break;
  32. }
  33. //处理搜索
  34. if(isset($_GET["search"])){
  35. $table = $table->where('title', 'like', $_GET["search"]."%");
  36. }
  37. //获取记录总条数
  38. $count = $table->count();
  39. //处理排序
  40. if(isset($_GET["order"]) && isset($_GET["dir"])){
  41. $table = $table->orderBy($_GET["order"],$_GET["dir"]);
  42. }else{
  43. //默认排序
  44. $table = $table->orderBy('updated_at','desc');
  45. }
  46. //处理分页
  47. if($request->has("limit")){
  48. if($request->has("offset")){
  49. $offset = $request->get("offset");
  50. }else{
  51. $offset = 0;
  52. }
  53. $table = $table->skip($offset)->take($request->get("limit"));
  54. }
  55. //获取数据
  56. $result = $table->get();
  57. if($result){
  58. /*
  59. foreach ($result as $key => $value) {
  60. # 获取studio信息
  61. $studio = $userinfo->getName($value->owner_uid);
  62. $value->studio = [
  63. 'id'=>$value->owner_uid,
  64. 'nickName'=>$studio['nickname'],
  65. 'studioName'=>$studio['username'],
  66. 'avastar'=>'',
  67. 'owner' => [
  68. 'id'=>$value->owner_uid,
  69. 'nickName'=>$studio['nickname'],
  70. 'userName'=>$studio['username'],
  71. 'avastar'=>'',
  72. ]
  73. ];
  74. }*/
  75. return $this->ok(["rows"=>$result,"count"=>$count]);
  76. }else{
  77. return $this->error("没有查询到数据");
  78. }
  79. }
  80. /**
  81. * Store a newly created resource in storage.
  82. *
  83. * @param \Illuminate\Http\Request $request
  84. * @return \Illuminate\Http\Response
  85. */
  86. public function store(Request $request)
  87. {
  88. //
  89. $user = \App\Http\Api\AuthApi::current($request);
  90. if($user){
  91. //判断当前用户是否有指定的studio的权限
  92. if($user['user_uid'] === \App\Http\Api\StudioApi::getIdByName($request->get('studio'))){
  93. //查询是否重复
  94. if(Article::where('title',$request->get('title'))->where('owner',$user['user_uid'])->exists()){
  95. return $this->error(__('validation.exists'));
  96. }else{
  97. $newOne = new Article;
  98. $newOne->id = app('snowflake')->id();
  99. $newOne->uid = Str::uuid();
  100. $newOne->title = $request->get('title');
  101. $newOne->lang = $request->get('lang');
  102. $newOne->owner = $user['user_uid'];
  103. $newOne->owner_id = $user['user_id'];
  104. $newOne->editor_id = $user['user_id'];
  105. $newOne->create_time = time()*1000;
  106. $newOne->modify_time = time()*1000;
  107. $newOne->save();
  108. return $this->ok($newOne);
  109. }
  110. }else{
  111. return $this->error(__('auth.failed'));
  112. }
  113. }else{
  114. return $this->error(__('auth.failed'));
  115. }
  116. }
  117. /**
  118. * Display the specified resource.
  119. * @param \Illuminate\Http\Request $request
  120. * @param \App\Models\Article $article
  121. * @return \Illuminate\Http\Response
  122. */
  123. public function show(Request $request,Article $article)
  124. {
  125. //
  126. if($article){
  127. if($article->status<30){
  128. //私有文章,判断权限
  129. $user = \App\Http\Api\AuthApi::current($request);
  130. if($user){
  131. //判断当前用户是否有指定的studio的权限
  132. if($user['user_uid'] !== $article->owner){
  133. //非所有者
  134. //TODO 判断是否协作
  135. return $this->error(__('auth.failed'));
  136. }
  137. }else{
  138. return $this->error(__('auth.failed'));
  139. }
  140. }
  141. return $this->ok($article);
  142. }else{
  143. return $this->error("no recorder");
  144. }
  145. }
  146. /**
  147. * Update the specified resource in storage.
  148. *
  149. * @param \Illuminate\Http\Request $request
  150. * @param \App\Models\Article $article
  151. * @return \Illuminate\Http\Response
  152. */
  153. public function update(Request $request, Article $article)
  154. {
  155. //
  156. if($article){
  157. //鉴权
  158. $user = \App\Http\Api\AuthApi::current($request);
  159. if($user && $article->owner === $user["user_uid"]){
  160. $article->title = $request->get('title');
  161. $article->subtitle = $request->get('subtitle');
  162. $article->summary = $request->get('summary');
  163. $article->content = $request->get('content');
  164. $article->lang = $request->get('lang');
  165. $article->status = $request->get('status');
  166. $article->modify_time = time()*1000;
  167. $article->save();
  168. return $this->ok($article);
  169. }else{
  170. //鉴权失败
  171. //TODO 判断是否为协作
  172. return $this->error(__('auth.failed'));
  173. }
  174. }else{
  175. return $this->error("no recorder");
  176. }
  177. }
  178. /**
  179. * Remove the specified resource from storage.
  180. *
  181. * @param \App\Models\Article $article
  182. * @return \Illuminate\Http\Response
  183. */
  184. public function destroy(Article $article)
  185. {
  186. //
  187. }
  188. }