Advertisement
oleghalin

Untitled

May 16th, 2017
60
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.04 KB | None | 0 0
  1. <?php
  2.  
  3. namespace App\Http\Controllers;
  4.  
  5. use App\Models\News;
  6. use Illuminate\Support\Facades\Validator;
  7. use Illuminate\Http\Request;
  8.  
  9. class NewsController extends Controller
  10. {
  11.  
  12. /**
  13. * Instantiate a new controller instance.
  14. *
  15. * @return void
  16. */
  17. public function __construct()
  18. {
  19. $this->middleware('admin')->except(['index','show']);
  20. }
  21.  
  22. /**
  23. * Display a listing of the resource.
  24. *
  25. * @return \Illuminate\Http\Response
  26. */
  27. public function index()
  28. {
  29. return dump(News::all());
  30. }
  31.  
  32. /**
  33. * Show the form for creating a new resource.
  34. *
  35. * @return \Illuminate\Http\Response
  36. */
  37. public function create()
  38. {
  39. return view('news.create');
  40. }
  41.  
  42. /**
  43. * Get a validator for an incoming registration request.
  44. *
  45. * @param array $data
  46. * @return \Illuminate\Contracts\Validation\Validator
  47. */
  48. protected function validator(array $data)
  49. {
  50. return Validator::make($data, [
  51. 'title' => 'required|string|min:6|max:30',
  52. 'short_story' => 'required|string|max:255',
  53. 'full_story' => 'required|string|max:1000',
  54. 'image' => 'required|string|url',
  55. ]);
  56. }
  57. /**
  58. * Store a newly created resource in storage.
  59. *
  60. * @param \Illuminate\Http\Request $request
  61. * @return \Illuminate\Http\Response
  62. */
  63. public function store(Request $request)
  64. {
  65. $this->validator($request->all())->validate();
  66.  
  67. $news = new News();
  68. $news->fill($request->except(['_token','_method']));
  69. $news->save();
  70. return redirect(route('news.show',['id'=>$news->id]));
  71. }
  72.  
  73. /**
  74. * Display the specified resource.
  75. *
  76. * @param \App\Models\News $news
  77. * @return \Illuminate\Http\Response
  78. */
  79. public function show(News $news)
  80. {
  81. return dump(News::find($news));
  82. }
  83.  
  84. /**
  85. * Show the form for editing the specified resource.
  86. *
  87. * @param \App\Models\News $news
  88. * @return \Illuminate\Http\Response
  89. */
  90. public function edit(News $news)
  91. {
  92. return view('news.edit',['News' => $news]);
  93. }
  94.  
  95. /**
  96. * Update the specified resource in storage.
  97. *
  98. * @param \Illuminate\Http\Request $request
  99. * @param \App\Models\News $news
  100. * @return \Illuminate\Http\Response
  101. */
  102. public function update(Request $request, News $news)
  103. {
  104. $this->validator($request->all())->validate();
  105.  
  106. $news->fill($request->except(['_token','_method']));
  107. $news->save();
  108. return redirect(route('news.show',['id'=>$news->id]));
  109. }
  110.  
  111. /**
  112. * Remove the specified resource from storage.
  113. *
  114. * @param \App\Models\News $news
  115. * @return \Illuminate\Http\Response
  116. */
  117. public function destroy(News $news)
  118. {
  119. $news->delete();
  120. return redirect(route('news.index'))->with('info','News post successful deleted');
  121. }
  122. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement