mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-05 18:23:48 +00:00
110 lines
4.0 KiB
PHP
110 lines
4.0 KiB
PHP
<?php
|
|
namespace Domain\Admin\Controllers\Dashboard;
|
|
|
|
use ByteUnits\Metric;
|
|
use App\Users\Models\User;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Support\Facades\DB;
|
|
use App\Http\Controllers\Controller;
|
|
use VueFileManager\Subscription\Domain\Subscriptions\Models\Subscription;
|
|
|
|
class GetDashboardDataController extends Controller
|
|
{
|
|
public function __invoke(): JsonResponse
|
|
{
|
|
// Get bandwidth data
|
|
[$upload, $download, $uploadTotal, $downloadTotal, $storageUsage] = $this->getDiskData();
|
|
|
|
// Get total earnings from transactions
|
|
$totalEarnings = DB::table('transactions')
|
|
->where('status', 'completed')
|
|
->where('type', 'charge')
|
|
->sum('amount');
|
|
|
|
// TODO: PHP_BINDIR constant if PHP_BINARY is not available
|
|
return response()->json([
|
|
'users' => [
|
|
'total' => User::count(),
|
|
'usersPremiumTotal' => Subscription::count(),
|
|
],
|
|
'disk' => [
|
|
'used' => $storageUsage,
|
|
'download' => [
|
|
'total' => $downloadTotal,
|
|
'records' => $download,
|
|
],
|
|
'upload' => [
|
|
'total' => $uploadTotal,
|
|
'records' => $upload,
|
|
],
|
|
],
|
|
'app' => [
|
|
'cron' => [
|
|
'isRunning' => isRunningCron(),
|
|
'command' => [
|
|
'shared' => PHP_BINARY . ' ' . base_path() . '/artisan schedule:run >> /dev/null 2>&1',
|
|
'vps' => '* * * * * cd ' . base_path() . ' && ' . PHP_BINARY . ' artisan schedule:run >> /dev/null 2>&1',
|
|
],
|
|
],
|
|
'license' => get_settings('license'),
|
|
'version' => config('vuefilemanager.version'),
|
|
'earnings' => format_currency($totalEarnings, 'USD'), // todo: refactor currency to global setup or plan currency
|
|
],
|
|
]);
|
|
}
|
|
|
|
private function getDiskData(): array
|
|
{
|
|
// Set period range for data retrieval
|
|
$period = now()
|
|
->subDays(45)
|
|
->endOfDay();
|
|
|
|
// Get bandwidth data
|
|
$trafficRecords = DB::table('traffic')
|
|
->where('created_at', '>', $period)
|
|
->groupBy('date')
|
|
->get([
|
|
DB::raw('Date(created_at) as date'),
|
|
DB::raw('sum(download) as download'),
|
|
DB::raw('sum(upload) as upload'),
|
|
])
|
|
->each(fn ($record) => $record->date = format_date($record->date, 'd. M. Y'))
|
|
->keyBy('date');
|
|
|
|
$mappedTrafficRecords = mapTrafficRecords($trafficRecords);
|
|
|
|
$upload = $mappedTrafficRecords->map(fn ($record) => [
|
|
'created_at' => $record->date,
|
|
'percentage' => intval($trafficRecords->max('upload')) !== 0 ? round(($record->upload / $trafficRecords->max('upload')) * 100, 2) : 0,
|
|
'amount' => Metric::bytes($record->upload)->format(),
|
|
]);
|
|
|
|
$download = $mappedTrafficRecords->map(fn ($record) => [
|
|
'created_at' => $record->date,
|
|
'percentage' => intval($trafficRecords->max('download')) !== 0 ? round(($record->download / $trafficRecords->max('download')) * 100, 2) : 0,
|
|
'amount' => Metric::bytes($record->download)->format(),
|
|
]);
|
|
|
|
// Get total download/upload
|
|
$downloadTotal = Metric::bytes(
|
|
DB::table('traffic')
|
|
->where('created_at', '>', $period)
|
|
->sum('download')
|
|
)->format();
|
|
|
|
$uploadTotal = Metric::bytes(
|
|
DB::table('traffic')
|
|
->where('created_at', '>', $period)
|
|
->sum('upload')
|
|
)->format();
|
|
|
|
// Get total storage usage
|
|
$storageUsage = Metric::bytes(
|
|
DB::table('files')->sum('filesize')
|
|
)->format();
|
|
|
|
return [$upload, $download, $uploadTotal, $downloadTotal, $storageUsage];
|
|
}
|
|
}
|