123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 |
- <?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);
- }
- }
|