|
@@ -0,0 +1,284 @@
|
|
|
|
+<?php
|
|
|
|
+
|
|
|
|
+namespace App\Http\Controllers\Admin;
|
|
|
|
+
|
|
|
|
+use Cache, DB;
|
|
|
|
+use Illuminate\Http\Request;
|
|
|
|
+use App\ModLog;
|
|
|
|
+use App\Profile;
|
|
|
|
+use App\User;
|
|
|
|
+use App\Mail\AdminMessage;
|
|
|
|
+use Illuminate\Support\Facades\Mail;
|
|
|
|
+use App\Services\ModLogService;
|
|
|
|
+use App\Jobs\DeletePipeline\DeleteAccountPipeline;
|
|
|
|
+
|
|
|
|
+trait AdminUserController
|
|
|
|
+{
|
|
|
|
+ public function users(Request $request)
|
|
|
|
+ {
|
|
|
|
+ $col = $request->query('col') ?? 'id';
|
|
|
|
+ $dir = $request->query('dir') ?? 'desc';
|
|
|
|
+ $users = User::select('id', 'username', 'status')
|
|
|
|
+ ->withCount('statuses')
|
|
|
|
+ ->orderBy($col, $dir)
|
|
|
|
+ ->simplePaginate(10);
|
|
|
|
+
|
|
|
|
+ return view('admin.users.home', compact('users'));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userShow(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ return view('admin.users.show', compact('user', 'profile'));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userEdit(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ return view('admin.users.edit', compact('user', 'profile'));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userEditSubmit(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ $changed = false;
|
|
|
|
+ $fields = [];
|
|
|
|
+
|
|
|
|
+ if($request->filled('name') && $request->input('name') != $user->name) {
|
|
|
|
+ $fields['name'] = ['old' => $user->name, 'new' => $request->input('name')];
|
|
|
|
+ $user->name = $profile->name = $request->input('name');
|
|
|
|
+ $changed = true;
|
|
|
|
+ }
|
|
|
|
+ if($request->filled('username') && $request->input('username') != $user->username) {
|
|
|
|
+ $fields['username'] = ['old' => $user->username, 'new' => $request->input('username')];
|
|
|
|
+ $user->username = $profile->username = $request->input('username');
|
|
|
|
+ $changed = true;
|
|
|
|
+ }
|
|
|
|
+ if($request->filled('email') && $request->input('email') != $user->email) {
|
|
|
|
+ if(filter_var($request->input('email'), FILTER_VALIDATE_EMAIL) == false) {
|
|
|
|
+ abort(500, 'Invalid email address');
|
|
|
|
+ }
|
|
|
|
+ $fields['email'] = ['old' => $user->email, 'new' => $request->input('email')];
|
|
|
|
+ $user->email = $request->input('email');
|
|
|
|
+ $changed = true;
|
|
|
|
+ }
|
|
|
|
+ if($request->input('bio') != $profile->bio) {
|
|
|
|
+ $fields['bio'] = ['old' => $user->bio, 'new' => $request->input('bio')];
|
|
|
|
+ $profile->bio = $request->input('bio');
|
|
|
|
+ $changed = true;
|
|
|
|
+ }
|
|
|
|
+ if($request->input('website') != $profile->website) {
|
|
|
|
+ $fields['website'] = ['old' => $user->website, 'new' => $request->input('website')];
|
|
|
|
+ $profile->website = $request->input('website');
|
|
|
|
+ $changed = true;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if($changed == true) {
|
|
|
|
+ ModLogService::boot()
|
|
|
|
+ ->objectUid($user->id)
|
|
|
|
+ ->objectId($user->id)
|
|
|
|
+ ->objectType('App\User::class')
|
|
|
|
+ ->user($request->user())
|
|
|
|
+ ->action('admin.user.edit')
|
|
|
|
+ ->metadata([
|
|
|
|
+ 'fields' => $fields
|
|
|
|
+ ])
|
|
|
|
+ ->accessLevel('admin')
|
|
|
|
+ ->save();
|
|
|
|
+ $profile->save();
|
|
|
|
+ $user->save();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ return redirect('/i/admin/users/show/' . $user->id);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userActivity(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ $logs = $user->accountLog()->orderByDesc('created_at')->paginate(10);
|
|
|
|
+ return view('admin.users.activity', compact('user', 'profile', 'logs'));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userMessage(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ return view('admin.users.message', compact('user', 'profile'));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userMessageSend(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $this->validate($request, [
|
|
|
|
+ 'message' => 'required|string|min:5|max:500'
|
|
|
|
+ ]);
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ $message = $request->input('message');
|
|
|
|
+ Mail::to($user->email)->send(new AdminMessage($message));
|
|
|
|
+ ModLogService::boot()
|
|
|
|
+ ->objectUid($user->id)
|
|
|
|
+ ->objectId($user->id)
|
|
|
|
+ ->objectType('App\User::class')
|
|
|
|
+ ->user($request->user())
|
|
|
|
+ ->action('admin.user.mail')
|
|
|
|
+ ->metadata([
|
|
|
|
+ 'message' => $message
|
|
|
|
+ ])
|
|
|
|
+ ->accessLevel('admin')
|
|
|
|
+ ->save();
|
|
|
|
+ return redirect('/i/admin/users/show/' . $user->id);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userModTools(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ return view('admin.users.modtools', compact('user', 'profile'));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userModLogs(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ $logs = ModLog::whereObjectUid($user->id)
|
|
|
|
+ ->orderByDesc('created_at')
|
|
|
|
+ ->simplePaginate(10);
|
|
|
|
+ return view('admin.users.modlogs', compact('user', 'profile', 'logs'));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userModLogsMessage(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $this->validate($request, [
|
|
|
|
+ 'message' => 'required|string|min:5|max:500'
|
|
|
|
+ ]);
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ $msg = $request->input('message');
|
|
|
|
+ ModLogService::boot()
|
|
|
|
+ ->objectUid($user->id)
|
|
|
|
+ ->objectId($user->id)
|
|
|
|
+ ->objectType('App\User::class')
|
|
|
|
+ ->user($request->user())
|
|
|
|
+ ->message($msg)
|
|
|
|
+ ->accessLevel('admin')
|
|
|
|
+ ->save();
|
|
|
|
+ return redirect('/i/admin/users/modlogs/' . $user->id);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userDelete(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+ return view('admin.users.delete', compact('user', 'profile'));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userDeleteProcess(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $profile = $user->profile;
|
|
|
|
+
|
|
|
|
+ if(config('pixelfed.account_deletion') == false) {
|
|
|
|
+ abort(404);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if($user->is_admin == true) {
|
|
|
|
+ $mid = $request->user()->id;
|
|
|
|
+ abort_if($user->id < $mid, 403);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ $ts = now()->addMonth();
|
|
|
|
+ $user->status = 'delete';
|
|
|
|
+ $profile->status = 'delete';
|
|
|
|
+ $user->delete_after = $ts;
|
|
|
|
+ $profile->delete_after = $ts;
|
|
|
|
+ $user->save();
|
|
|
|
+ $profile->save();
|
|
|
|
+
|
|
|
|
+ ModLogService::boot()
|
|
|
|
+ ->objectUid($user->id)
|
|
|
|
+ ->objectId($user->id)
|
|
|
|
+ ->objectType('App\User::class')
|
|
|
|
+ ->user($request->user())
|
|
|
|
+ ->action('admin.user.delete')
|
|
|
|
+ ->accessLevel('admin')
|
|
|
|
+ ->save();
|
|
|
|
+
|
|
|
|
+ Cache::forget('profiles:private');
|
|
|
|
+ DeleteAccountPipeline::dispatch($user)->onQueue('high');
|
|
|
|
+
|
|
|
|
+ $msg = "Successfully deleted {$user->username}!";
|
|
|
|
+ $request->session()->flash('status', $msg);
|
|
|
|
+ return redirect('/i/admin/users/list');
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userModerate(Request $request)
|
|
|
|
+ {
|
|
|
|
+ $this->validate($request, [
|
|
|
|
+ 'profile_id' => 'required|exists:profiles,id',
|
|
|
|
+ 'action' => 'required|in:cw,no_autolink,unlisted'
|
|
|
|
+ ]);
|
|
|
|
+
|
|
|
|
+ $pid = $request->input('profile_id');
|
|
|
|
+ $action = $request->input('action');
|
|
|
|
+ $profile = Profile::findOrFail($pid);
|
|
|
|
+
|
|
|
|
+ if($profile->user->is_admin == true) {
|
|
|
|
+ $mid = $request->user()->id;
|
|
|
|
+ abort_if($profile->user_id < $mid, 403);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ switch ($action) {
|
|
|
|
+ case 'cw':
|
|
|
|
+ $profile->cw = !$profile->cw;
|
|
|
|
+ $msg = "Success!";
|
|
|
|
+ break;
|
|
|
|
+
|
|
|
|
+ case 'no_autolink':
|
|
|
|
+ $profile->no_autolink = !$profile->no_autolink;
|
|
|
|
+ $msg = "Success!";
|
|
|
|
+ break;
|
|
|
|
+
|
|
|
|
+ case 'unlisted':
|
|
|
|
+ $profile->unlisted = !$profile->unlisted;
|
|
|
|
+ $msg = "Success!";
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ $profile->save();
|
|
|
|
+
|
|
|
|
+ ModLogService::boot()
|
|
|
|
+ ->objectUid($profile->user_id)
|
|
|
|
+ ->objectId($profile->user_id)
|
|
|
|
+ ->objectType('App\User::class')
|
|
|
|
+ ->user($request->user())
|
|
|
|
+ ->action('admin.user.moderate')
|
|
|
|
+ ->metadata([
|
|
|
|
+ 'action' => $action,
|
|
|
|
+ 'message' => $msg
|
|
|
|
+ ])
|
|
|
|
+ ->accessLevel('admin')
|
|
|
|
+ ->save();
|
|
|
|
+
|
|
|
|
+ $request->session()->flash('status', $msg);
|
|
|
|
+ return redirect('/i/admin/users/modtools/' . $profile->user_id);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public function userModLogDelete(Request $request, $id)
|
|
|
|
+ {
|
|
|
|
+ $this->validate($request, [
|
|
|
|
+ 'mid' => 'required|integer|exists:mod_logs,id'
|
|
|
|
+ ]);
|
|
|
|
+ $user = User::findOrFail($id);
|
|
|
|
+ $uid = $request->user()->id;
|
|
|
|
+ $mid = $request->input('mid');
|
|
|
|
+ $ml = ModLog::whereUserId($uid)->findOrFail($mid)->delete();
|
|
|
|
+ $msg = "Successfully deleted modlog comment!";
|
|
|
|
+ $request->session()->flash('status', $msg);
|
|
|
|
+ return redirect('/i/admin/users/modlogs/' . $user->id);
|
|
|
|
+ }
|
|
|
|
+}
|