ReportController.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Profile;
  4. use App\Report;
  5. use App\Status;
  6. use App\User;
  7. use Auth;
  8. use Illuminate\Http\Request;
  9. class ReportController extends Controller
  10. {
  11. protected $profile;
  12. public function __construct()
  13. {
  14. $this->middleware('auth');
  15. }
  16. public function showForm(Request $request)
  17. {
  18. $this->validate($request, [
  19. 'type' => 'required|alpha_dash',
  20. 'id' => 'required|integer|min:1',
  21. ]);
  22. return view('report.form');
  23. }
  24. public function notInterestedForm(Request $request)
  25. {
  26. return view('report.not-interested');
  27. }
  28. public function spamForm(Request $request)
  29. {
  30. return view('report.spam');
  31. }
  32. public function spamCommentForm(Request $request)
  33. {
  34. return view('report.spam.comment');
  35. }
  36. public function spamPostForm(Request $request)
  37. {
  38. return view('report.spam.post');
  39. }
  40. public function spamProfileForm(Request $request)
  41. {
  42. return view('report.spam.profile');
  43. }
  44. public function sensitiveCommentForm(Request $request)
  45. {
  46. return view('report.sensitive.comment');
  47. }
  48. public function sensitivePostForm(Request $request)
  49. {
  50. return view('report.sensitive.post');
  51. }
  52. public function sensitiveProfileForm(Request $request)
  53. {
  54. return view('report.sensitive.profile');
  55. }
  56. public function abusiveCommentForm(Request $request)
  57. {
  58. return view('report.abusive.comment');
  59. }
  60. public function abusivePostForm(Request $request)
  61. {
  62. return view('report.abusive.post');
  63. }
  64. public function abusiveProfileForm(Request $request)
  65. {
  66. return view('report.abusive.profile');
  67. }
  68. public function formStore(Request $request)
  69. {
  70. $this->validate($request, [
  71. 'report' => 'required|alpha_dash',
  72. 'type' => 'required|alpha_dash',
  73. 'id' => 'required|integer|min:1',
  74. 'msg' => 'nullable|string|max:150',
  75. ]);
  76. $profile = Auth::user()->profile;
  77. $reportType = $request->input('report');
  78. $object_id = $request->input('id');
  79. $object_type = $request->input('type');
  80. $msg = $request->input('msg');
  81. $object = null;
  82. $types = [
  83. // original 3
  84. 'spam',
  85. 'sensitive',
  86. 'abusive',
  87. // new
  88. 'underage',
  89. 'copyright',
  90. 'impersonation',
  91. 'scam',
  92. 'terrorism'
  93. ];
  94. if (!in_array($reportType, $types)) {
  95. return redirect('/timeline')->with('error', 'Invalid report type');
  96. }
  97. switch ($object_type) {
  98. case 'post':
  99. $object = Status::findOrFail($object_id);
  100. $object_type = 'App\Status';
  101. $exists = Report::whereUserId(Auth::id())
  102. ->whereObjectId($object->id)
  103. ->whereObjectType('App\Status')
  104. ->count();
  105. break;
  106. default:
  107. return redirect('/timeline')->with('error', 'Invalid report type');
  108. break;
  109. }
  110. if ($exists !== 0) {
  111. return redirect('/timeline')->with('error', 'You have already reported this!');
  112. }
  113. if ($object->profile_id == $profile->id) {
  114. return redirect('/timeline')->with('error', 'You cannot report your own content!');
  115. }
  116. $report = new Report();
  117. $report->profile_id = $profile->id;
  118. $report->user_id = Auth::id();
  119. $report->object_id = $object->id;
  120. $report->object_type = $object_type;
  121. $report->reported_profile_id = $object->profile_id;
  122. $report->type = $request->input('report');
  123. $report->message = e($request->input('msg'));
  124. $report->save();
  125. return redirect('/timeline')->with('status', 'Report successfully sent!');
  126. }
  127. }