HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/heifetz/heifetz-app/models/OnlineStat.php
<?php

declare(strict_types=1);

namespace Models;

use Core\DbLib\DbModel;
use Core\Models\CoreHelper;
use Traits\ModelGetQuery;

/**
 * @property int $id
 * @property string $created_at
 * @property int $count
 * @property int $company_id
 */
class OnlineStat extends DbModel
{

    use ModelGetQuery;

    static string $tableName = 'online_stat';

    public static bool $hasCompanyRelation = true;

    public static function add(int $count): void
    {
        self::create(['count' => $count, 'created_at' => date('Y-m-d H:i:00'), 'company_id' => CoreHelper::$companyId]);
    }

    public static function getData(): array
    {
        $records = self::getQuery()
            ->order('created_at', 'DESC')
            ->limit(12 * 24)
            ->fetchAll();

        $data = [];
        $categories = [];
        $byRecord = [];
        foreach ($records as $record) {
            $key = date('ymdH', strtotime($record->created_at));
            $categories[$key] = date('H', strtotime($record->created_at));

            $byRecord[] = $record->count;

            if (isset($data[$key])) {
                $data[$key] = $record->count > $data[$key] ? $record->count : $data[$key];
            } else {
                $data[$key] = $record->count;
            }
        }

        ksort($categories);
        ksort($data);
        $data = array_values($data);
        $categories = array_values($categories);

        return [
            'data' => $data,
            'categories' => $categories,
            'maxMinute' => !empty($byRecord) ? max($byRecord) : 0,
            'avgMinute' => !empty($byRecord) ? array_sum($byRecord) / count($byRecord) : 0,
        ];
    }

}