AdminUserController.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use Cache, DB;
  4. use Illuminate\Http\Request;
  5. use App\ModLog;
  6. use App\Profile;
  7. use App\User;
  8. use App\Mail\AdminMessage;
  9. use Illuminate\Support\Facades\Mail;
  10. use App\Services\ModLogService;
  11. use App\Jobs\DeletePipeline\DeleteAccountPipeline;
  12. trait AdminUserController
  13. {
  14. public function users(Request $request)
  15. {
  16. $col = $request->query('col') ?? 'id';
  17. $dir = $request->query('dir') ?? 'desc';
  18. $users = User::select('id', 'username', 'status')
  19. ->withCount('statuses')
  20. ->orderBy($col, $dir)
  21. ->simplePaginate(10);
  22. return view('admin.users.home', compact('users'));
  23. }
  24. public function userShow(Request $request, $id)
  25. {
  26. $user = User::findOrFail($id);
  27. $profile = $user->profile;
  28. return view('admin.users.show', compact('user', 'profile'));
  29. }
  30. public function userEdit(Request $request, $id)
  31. {
  32. $user = User::findOrFail($id);
  33. $profile = $user->profile;
  34. return view('admin.users.edit', compact('user', 'profile'));
  35. }
  36. public function userEditSubmit(Request $request, $id)
  37. {
  38. $user = User::findOrFail($id);
  39. $profile = $user->profile;
  40. $changed = false;
  41. if($request->filled('name') && $request->input('name') != $user->name) {
  42. $user->name = $profile->name = $request->input('name');
  43. $changed = true;
  44. }
  45. if($request->filled('username') && $request->input('username') != $user->username) {
  46. $user->username = $profile->username = $request->input('username');
  47. $changed = true;
  48. }
  49. if($request->filled('email') && $request->input('email') != $user->email) {
  50. if(filter_var($request->input('email'), FILTER_VALIDATE_EMAIL) == false) {
  51. abort(500, 'Invalid email address');
  52. }
  53. $user->email = $request->input('email');
  54. $changed = true;
  55. }
  56. if($request->input('bio') != $profile->bio) {
  57. $profile->bio = $request->input('bio');
  58. $changed = true;
  59. }
  60. if($request->input('website') != $profile->website) {
  61. $profile->website = $request->input('website');
  62. $changed = true;
  63. }
  64. if($changed == true) {
  65. $profile->save();
  66. $user->save();
  67. }
  68. return redirect('/i/admin/users/show/' . $user->id);
  69. }
  70. public function userActivity(Request $request, $id)
  71. {
  72. $user = User::findOrFail($id);
  73. $profile = $user->profile;
  74. $logs = $user->accountLog()->orderByDesc('created_at')->paginate(10);
  75. return view('admin.users.activity', compact('user', 'profile', 'logs'));
  76. }
  77. public function userMessage(Request $request, $id)
  78. {
  79. $user = User::findOrFail($id);
  80. $profile = $user->profile;
  81. return view('admin.users.message', compact('user', 'profile'));
  82. }
  83. public function userMessageSend(Request $request, $id)
  84. {
  85. $this->validate($request, [
  86. 'message' => 'required|string|min:5|max:500'
  87. ]);
  88. $user = User::findOrFail($id);
  89. $profile = $user->profile;
  90. $message = $request->input('message');
  91. Mail::to($user->email)->send(new AdminMessage($message));
  92. ModLogService::boot()
  93. ->objectUid($user->id)
  94. ->objectId($user->id)
  95. ->objectType('App\User::class')
  96. ->user($request->user())
  97. ->action('admin.user.mail')
  98. ->metadata([
  99. 'message' => $message
  100. ])
  101. ->accessLevel('admin')
  102. ->save();
  103. return redirect('/i/admin/users/show/' . $user->id);
  104. }
  105. public function userModTools(Request $request, $id)
  106. {
  107. $user = User::findOrFail($id);
  108. $profile = $user->profile;
  109. return view('admin.users.modtools', compact('user', 'profile'));
  110. }
  111. public function userModLogs(Request $request, $id)
  112. {
  113. $user = User::findOrFail($id);
  114. $profile = $user->profile;
  115. $logs = ModLog::whereObjectUid($user->id)
  116. ->orderByDesc('created_at')
  117. ->simplePaginate(10);
  118. return view('admin.users.modlogs', compact('user', 'profile', 'logs'));
  119. }
  120. public function userModLogsMessage(Request $request, $id)
  121. {
  122. $this->validate($request, [
  123. 'message' => 'required|string|min:5|max:500'
  124. ]);
  125. $user = User::findOrFail($id);
  126. $profile = $user->profile;
  127. $msg = $request->input('message');
  128. ModLogService::boot()
  129. ->objectUid($user->id)
  130. ->objectId($user->id)
  131. ->objectType('App\User::class')
  132. ->user($request->user())
  133. ->message($msg)
  134. ->accessLevel('admin')
  135. ->save();
  136. return redirect('/i/admin/users/modlogs/' . $user->id);
  137. }
  138. public function userDelete(Request $request, $id)
  139. {
  140. $user = User::findOrFail($id);
  141. $profile = $user->profile;
  142. return view('admin.users.delete', compact('user', 'profile'));
  143. }
  144. public function userDeleteProcess(Request $request, $id)
  145. {
  146. $user = User::findOrFail($id);
  147. $profile = $user->profile;
  148. if(config('pixelfed.account_deletion') == false) {
  149. abort(404);
  150. }
  151. if($user->is_admin == true) {
  152. $mid = $request->user()->id;
  153. abort_if($user->id < $mid, 403);
  154. }
  155. $ts = now()->addMonth();
  156. $user->status = 'delete';
  157. $profile->status = 'delete';
  158. $user->delete_after = $ts;
  159. $profile->delete_after = $ts;
  160. $user->save();
  161. $profile->save();
  162. Cache::forget('profiles:private');
  163. DeleteAccountPipeline::dispatch($user)->onQueue('high');
  164. $msg = "Successfully deleted {$user->username}!";
  165. $request->session()->flash('status', $msg);
  166. return redirect('/i/admin/users/list');
  167. }
  168. public function userModerate(Request $request)
  169. {
  170. $this->validate($request, [
  171. 'profile_id' => 'required|exists:profiles,id',
  172. 'action' => 'required|in:cw,no_autolink,unlisted'
  173. ]);
  174. $pid = $request->input('profile_id');
  175. $action = $request->input('action');
  176. $profile = Profile::findOrFail($pid);
  177. if($profile->user->is_admin == true) {
  178. $mid = $request->user()->id;
  179. abort_if($profile->user_id < $mid, 403);
  180. }
  181. switch ($action) {
  182. case 'cw':
  183. $profile->cw = !$profile->cw;
  184. $msg = "Success!";
  185. break;
  186. case 'no_autolink':
  187. $profile->no_autolink = !$profile->no_autolink;
  188. $msg = "Success!";
  189. break;
  190. case 'unlisted':
  191. $profile->unlisted = !$profile->unlisted;
  192. $msg = "Success!";
  193. break;
  194. }
  195. $profile->save();
  196. ModLogService::boot()
  197. ->objectUid($profile->user_id)
  198. ->objectId($profile->user_id)
  199. ->objectType('App\User::class')
  200. ->user($request->user())
  201. ->action('admin.user.moderate')
  202. ->metadata([
  203. 'action' => $action,
  204. 'message' => $msg
  205. ])
  206. ->accessLevel('admin')
  207. ->save();
  208. $request->session()->flash('status', $msg);
  209. return redirect('/i/admin/users/modtools/' . $profile->user_id);
  210. }
  211. }