| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263 | <?phpnamespace catchAdmin\report\model;use catcher\base\CatchModel;use catcher\exceptions\FailedException;use catcher\Utils;use catchAdmin\permissions\model\DataRangScopeTrait;use catchAdmin\stations\model\Station as StationModel;use catchAdmin\device\model\Device as DeviceModel;use catchAdmin\school\model\KqBuilding as BuildingModel;use catchAdmin\permissions\model\Users as UsersModel;use catchAdmin\permissions\model\Department as DepartmentModel;use catchAdmin\permissions\model\Roles;use catchAdmin\system\model\SysDictData as SysDictDataModel;use catchAdmin\system\model\SysDictType as SysDictTypeModel;use catchAdmin\permissions\model\SysConfig;class Report extends CatchModel{    //权限过滤    use DataRangScopeTrait;    protected $name = 'report';    protected $field = [];    /**     * 获取所有基站类型     */    public function getStationType()    {        return (new SysDictDataModel())->getTypesByCode('StationType');    }    /**     * 获取所有用户设备类型     */    public function getDeviceType()    {        return (new SysDictDataModel())->getTypesByCode('DeviceType');    }    /**     * 基站数量数据     */    public function getStationCountData()    {        $station_type_arr = []; // 基站类型数组        $total_count = 0; // 基站总数量        $online_count = 0; // 基站总在线数量        $yesterday_add_count = 0; // 基站昨日新增总数        $today_add_count = 0; // 基站今日新增总数        $station_type_data = [];        $time = time();        $today_time = strtotime(date('Y-m-d'));        // 获取基站类型        $station_types = $this->getStationType();        foreach ($station_types as $type) {            $station_type_arr[$type['value']] = $type;        }        // 基站离线时间间隔        $offline_interval = SysConfig::getConfigValueBy('station_offline_interval', 'station_config') ?? 86400;        // 基站总数据        $cursor = (new StationModel)->dataRange()->field('station_mac, station_type, online_time, created_at')->cursor();        foreach ($cursor as $station) {            $total_count++;            // 按基站类型分类            if (isset($station_type_arr[$station['station_type']])) {                $key = $station_type_arr[$station['station_type']]['text'];            } else {                $key = '未知类型';            }            if (!isset($station_type_data[$key])) {                $station_type_data[$key] = isset($station_type_arr[$station['station_type']]) ? $station_type_arr[$station['station_type']] : [];            }            // 总数量            $station_type_data[$key]['total'] = isset($station_type_data[$key]['total']) ? ($station_type_data[$key]['total'] + 1) : 1;            // 昨日新增            $create_time = $station->getData('created_at');            if ($today_time - $create_time > 0 && $today_time - $create_time < 86400) {                $yesterday_add_count++;                $station_type_data[$key]['yesterday_add'] = isset($station_type_data[$key]['yesterday_add']) ? ($station_type_data[$key]['yesterday_add'] + 1) : 1;            }             // 今日新增            if ($today_time - $create_time <= 0) {                $today_add_count++;                $station_type_data[$key]['today_add'] = isset($station_type_data[$key]['today_add']) ? ($station_type_data[$key]['today_add'] + 1) : 1;            }            // 在线数            if ($time - intval(strtotime($station['online_time'])) > $offline_interval) { // 离线时间,秒                $online_count++;                $station_type_data[$key]['online'] = isset($station_type_data[$key]['online']) ? ($station_type_data[$key]['online'] + 1) : 1;            }        }        // 转化为输出数据        $type_data = [];        foreach ($station_type_data as $data) {            $data['yesterday_add'] = isset($data['yesterday_add']) ? $data['yesterday_add'] : 0;            $data['today_add'] = isset($data['today_add']) ? $data['today_add'] : 0;            $data['online'] = isset($data['online']) ? $data['online'] : 0;            $data['offline'] = $data['total'] - $data['online'];            $type_data[] = $data;        }        return [            'station_total_count' => $total_count,            'station_online_count' => $online_count,            'station_offline_count' => $total_count - $online_count,            'station_yesterday_add_count' => $yesterday_add_count,            'station_today_add_count' => $today_add_count,            'station_type_data' => $type_data,        ];    }        /**     * 基站设备增长趋势数据     */    public function getStationGrowthTrendData($start_time = '', $end_time = '')    {        // 默认最近1周        if (!$start_time) {            $start_time = date('Y-m-d', strtotime('-6 day'));        }        if (!$end_time) {            $end_time = date('Y-m-d');        }        // 获取基站类型        $station_types = $this->getStationType();        $data = [];        $station_model = new StationModel();        while ($start_time <= $end_time) {            foreach($station_types as $type) {                if (!isset($data[$type['text']]['name'])) {                    $data[$type['text']]['name'] = $type['text'];                }                                $count = $station_model->dataRange()                                    ->where('station_type', $type['value'])                                    ->whereBetweenTime('created_at', 0, date('Y-m-d 23:59:59', strtotime($start_time)))                                    ->count();                // var_dump($station_model->getLastSql());                $data[$type['text']]['data'][$start_time] = $count;            }            $start_time = date('Y-m-d', strtotime($start_time . ' +1 day'));        }        return array_values($data);    }    /**     * 用户设备增长趋势数据     */    public function getDeviceGrowthTrendData($start_time = '', $end_time = '')    {        // 默认最近1周        if (!$start_time) {            $start_time = date('Y-m-d', strtotime('-6 day'));        }        if (!$end_time) {            $end_time = date('Y-m-d');        }        // 获取设备类型        $device_types = array(            array('text'=>'法兰'),            array('text'=>'液压泵'),            array('text'=>'液压扳手'),        );        // var_dump($device_types);        $data = [];        $device_model = new DeviceModel();        while ($start_time <= $end_time) {            foreach($device_types as $type) {                if (!isset($data[$type['text']]['name'])) {                    $data[$type['text']]['name'] = $type['text'];                }                                // $count = $device_model->dataRange()                //                     ->where('device_type', $type['value'])                //                     ->whereBetweenTime('created_at', 0, date('Y-m-d 23:59:59', strtotime($start_time)))                //                     ->count();                $count=mt_rand(1,10);                // var_dump($device_model->getLastSql());                $data[$type['text']]['data'][$start_time] = $count;            }            $start_time = date('Y-m-d', strtotime($start_time . ' +1 day'));        }                return array_values($data);    }    /**     * 部门数量数据:统计含本部门、及子部门数量     */    public function getDepartmentCountData()    {        $depart_ids = DepartmentModel::getChildrenDepartmentIds(request()->user()->department_id);        // 去掉部门为0的        $depart_ids = array_filter($depart_ids);        return [            'department_count' => count($depart_ids),        ];    }    /**     * 设备用户数量统计     */    public function getDeviceUserCountData()    {        // 当前时间        $now_time = time();        // 离线时间间隔        $offline_interval = SysConfig::getConfigValueBy('card_offline_interval', 'basic_config') ?: 86400;        $offline_time = date('Y-m-d H:i:s', $now_time - $offline_interval); // 离线时间        // 设备类型        $device_types = $this->getDeviceType();        $deviceModel = (new \catchAdmin\device\model\Device());        $devices = $deviceModel->dataRange()                    ->field('id,device_type,alarm_state,online_time,wifi_online_time')                    ->append(['last_online_time'])                    ->select();        // 总设备数        $totle = 0;        // 总在线设备数         $totle_online = 0;        // 按设备类型分组        $device_type_data = [];        foreach ($device_types as $type) {            // 数量            $type_count = $devices->where('device_type', $type['value'])->count();            // 在线数量            $type_online_count = $devices->where('device_type', $type['value'])->where('last_online_time', '>', $offline_time)->count();            // 告警数量            $type_alarm_count = $devices->where('device_type', $type['value'])->where('alarm_state', '>', 0)->count();            $device_type_data[] = [                'text' => $type['text'],   // 设备类型文本                'value' => $type['value'], // 设备类型值                'total' => $type_count,                'online' => $type_online_count,                'alarm' => $type_alarm_count,            ];            // 计算总数            $totle += $type_count;            // 计算总在线数            $totle_online += $type_online_count;        }        return [            'device_total_count' => $totle,            'device_online_count' => $totle_online,            'device_type_data' => $device_type_data,        ];    }}
 |