Files
UNIT3D-Community-Edition/app/Console/Commands/AutoStatsClients.php
HDVinnie 3650900c97 update: lint
- not_operator_with_space to false
2023-02-03 16:01:29 -05:00

62 lines
1.6 KiB
PHP

<?php
/**
* NOTICE OF LICENSE.
*
* UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
* The details is bundled with this project in the file LICENSE.txt.
*
* @project UNIT3D Community Edition
*
* @author HDVinnie <hdinnovations@protonmail.com>
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
*/
namespace App\Console\Commands;
use App\Models\Peer;
use Illuminate\Console\Command;
use Illuminate\Support\Carbon;
class AutoStatsClients extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'auto:stats_clients';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Updates the Client Stats daily.';
/**
* Execute the console command.
*/
public function handle(): void
{
$clients = Peer::selectRaw('agent, count(*) as count')
->fromSub(
fn ($sub) => $sub
->select(['agent', 'user_id'])
->from('peers')
->groupBy('agent', 'user_id'),
'distinct_agent_user'
)
->groupBy('agent')
->orderBy('agent')
->get()
->mapWithKeys(fn ($item, $key) => [$item['agent'] => $item['count']])
->toArray();
if (! empty($clients)) {
cache()->put('stats:clients', $clients, Carbon::now()->addMinutes(1440));
}
$this->comment('Automated Client Stats Completed.');
}
}