1
0
Fork 1
mirror of https://github.com/pixelfed/pixelfed.git synced 2025-01-22 23:09:41 +00:00
pixelfed/app/Http/Controllers/AdminController.php

110 lines
3.2 KiB
PHP
Raw Normal View History

2018-04-29 16:25:57 +00:00
<?php
namespace App\Http\Controllers;
2018-08-28 03:07:36 +00:00
use App\Media;
2018-12-21 06:14:22 +00:00
use App\Like;
2018-09-03 01:25:08 +00:00
use App\Profile;
2018-09-01 02:26:56 +00:00
use App\Report;
2018-08-28 03:07:36 +00:00
use App\Status;
use App\User;
2018-09-03 01:25:08 +00:00
use Carbon\Carbon;
2018-04-29 16:25:57 +00:00
use Illuminate\Http\Request;
2018-12-21 06:14:22 +00:00
use Jackiedo\DotenvEditor\DotenvEditor;
2018-12-24 00:48:41 +00:00
use App\Http\Controllers\Admin\AdminReportController;
2018-12-21 06:14:22 +00:00
use App\Util\Lexer\PrettyNumber;
2018-04-29 16:25:57 +00:00
class AdminController extends Controller
{
2018-12-24 00:48:41 +00:00
use AdminReportController;
2018-09-01 02:26:56 +00:00
public function __construct()
{
2018-09-16 05:15:45 +00:00
$this->middleware('admin');
$this->middleware('twofactor');
}
public function home()
{
2018-08-28 03:07:36 +00:00
return view('admin.home');
}
public function users(Request $request)
{
2018-12-21 06:14:22 +00:00
$col = $request->query('col') ?? 'id';
$dir = $request->query('dir') ?? 'desc';
$stats = $this->collectUserStats($request);
$users = User::withCount('statuses')->orderBy($col, $dir)->paginate(10);
2018-09-03 01:25:08 +00:00
return view('admin.users.home', compact('users', 'stats'));
}
public function editUser(Request $request, $id)
{
2018-12-21 06:14:22 +00:00
$user = User::findOrFail($id);
2018-09-03 01:25:08 +00:00
$profile = $user->profile;
return view('admin.users.edit', compact('user', 'profile'));
2018-08-28 03:07:36 +00:00
}
public function statuses(Request $request)
{
2018-08-28 03:07:36 +00:00
$statuses = Status::orderBy('id', 'desc')->paginate(10);
return view('admin.statuses.home', compact('statuses'));
}
public function showStatus(Request $request, $id)
{
2018-08-28 03:07:36 +00:00
$status = Status::findOrFail($id);
return view('admin.statuses.show', compact('status'));
}
public function media(Request $request)
{
2018-08-28 03:07:36 +00:00
$media = Status::whereHas('media')->orderby('id', 'desc')->paginate(12);
return view('admin.media.home', compact('media'));
}
2018-09-01 02:26:56 +00:00
public function reports(Request $request)
{
$reports = Report::orderBy('created_at','desc')->paginate(12);
return view('admin.reports.home', compact('reports'));
}
public function showReport(Request $request, $id)
{
$report = Report::findOrFail($id);
return view('admin.reports.show', compact('report'));
}
2018-09-03 01:25:08 +00:00
protected function collectUserStats($request)
{
2018-09-03 01:25:08 +00:00
$total_duration = $request->query('total_duration') ?? '30';
$new_duration = $request->query('new_duration') ?? '7';
$stats = [];
$stats['total'] = [
'count' => User::where('created_at', '>', Carbon::now()->subDays($total_duration))->count(),
2018-09-03 01:57:27 +00:00
'points' => 0//User::selectRaw('day(created_at) day, count(*) as count')->where('created_at','>', Carbon::now()->subDays($total_duration))->groupBy('day')->pluck('count')
2018-09-03 01:25:08 +00:00
];
$stats['new'] = [
'count' => User::where('created_at', '>', Carbon::now()->subDays($new_duration))->count(),
2018-09-03 01:57:27 +00:00
'points' => 0//User::selectRaw('day(created_at) day, count(*) as count')->where('created_at','>', Carbon::now()->subDays($new_duration))->groupBy('day')->pluck('count')
2018-09-03 01:25:08 +00:00
];
$stats['active'] = [
'count' => Status::groupBy('profile_id')->count()
];
$stats['profile'] = [
'local' => Profile::whereNull('remote_url')->count(),
'remote' => Profile::whereNotNull('remote_url')->count()
];
$stats['avg'] = [
2018-12-21 06:14:22 +00:00
'likes' => floor(Like::average('profile_id')),
2018-09-03 01:25:08 +00:00
'posts' => floor(Status::avg('profile_id'))
];
return $stats;
}
2018-04-29 16:25:57 +00:00
}