Your IP : 18.116.88.123


Current Path : /var/www/www-root/data/webdav/www/www.monolith-realty.ru/bitrix/modules/main/admin/
Upload File :
Current File : /var/www/www-root/data/webdav/www/www.monolith-realty.ru/bitrix/modules/main/admin/user_devices.php

<?php

/**
 * Bitrix Framework
 * @package bitrix
 * @subpackage main
 * @copyright 2001-2022 Bitrix
 */

use Bitrix\Main\Context;
use Bitrix\Main\Authentication\Internal\UserDeviceTable;
use Bitrix\Main\Web\UserAgent\DeviceType;
use Bitrix\Main\UI\Filter;
use Bitrix\Main\Localization\Loc;

/**
 * @global CUser $USER
 * @global CMain $APPLICATION
 */

require_once __DIR__ . '/../include/prolog_admin_before.php';
require_once __DIR__ . '/../prolog.php';

define('HELP_FILE', 'users/user_devices.php');

if (!$USER->CanDoOperation('edit_all_users'))
{
	$APPLICATION->AuthForm(GetMessage('ACCESS_DENIED'));
}

$request = Context::getCurrent()->getRequest();

$excelMode = ($request['mode'] == 'excel');

$tableId = 'tbl_user_devices';
$sort = new CAdminUiSorting($tableId, 'ID', 'desc');
$list = new CAdminUiList($tableId, $sort);

$deviceTypes = DeviceType::getDescription();

$filterFields = [
	['id' => 'USER_ID', 'name' => Loc::getMessage('main_user_devices_user_id'), 'default' => true],
	['id' => 'DEVICE_UID', 'name' => Loc::getMessage('main_user_devices_device_uid'), 'default' => false],
	['id' => 'DEVICE_TYPE', 'name' => Loc::getMessage('main_user_devices_device_type'), 'type' => 'list', 'items' => ['' => Loc::getMessage('main_user_devices_not_selected')] + $deviceTypes,	'default' => true],
	['id' => 'BROWSER', 'name' => Loc::getMessage('main_user_devices_browser'), 'default' => true],
	['id' => 'PLATFORM', 'name' => Loc::getMessage('main_user_devices_platform'), 'default' => true],
	['id' => 'USER_AGENT', 'name' => Loc::getMessage('main_user_devices_agent'), 'default' => true],
];

$headers = [
	['id' => 'ID', 'content' => 'ID', 'sort' => 'ID', 'default' => true],
	['id' => 'USER_ID', 'content' => Loc::getMessage('main_user_devices_user_id'), 'sort' => 'USER_ID', 'default' => true],
	['id' => 'DEVICE_UID', 'content' => Loc::getMessage('main_user_devices_device_uid'), 'sort' => 'DEVICE_UID', 'default' => false],
	['id' => 'DEVICE_TYPE', 'content' => Loc::getMessage('main_user_devices_device_type'), 'sort' => 'DEVICE_TYPE', 'default' => true],
	['id' => 'BROWSER', 'content' => Loc::getMessage('main_user_devices_browser'), 'sort' => 'BROWSER', 'default' => true],
	['id' => 'PLATFORM', 'content' => Loc::getMessage('main_user_devices_platform'), 'sort' => 'PLATFORM', 'default' => true],
	['id' => 'USER_AGENT', 'content' => Loc::getMessage('main_user_devices_agent'), 'sort' => 'USER_AGENT', 'default' => true],
];

$list->addHeaders($headers);

$query = UserDeviceTable::query();

$query->setSelect(['*']);

// TODO: do something about globals
global $by, $order;

$sortBy = strtoupper($by);
if (!UserDeviceTable::getEntity()->hasField($sortBy))
{
	$sortBy = 'ID';
}

$sortOrder = strtoupper($order);
if ($sortOrder != 'ASC')
{
	$sortOrder = 'DESC';
}
$query->setOrder([$sortBy => $sortOrder]);

if ($list->isTotalCountRequest())
{
	$query->countTotal(true);
}

$nav = $list->getPageNavigation('pages-user-devices');
$query->setOffset($nav->getOffset());
if (!$excelMode)
{
	$query->setLimit($nav->getLimit() + 1);
}

$filterOption = new Filter\Options($tableId);
$filter = $filterOption->getFilter($filterFields);

if (!empty($filter['FIND']))
{
	$query->whereLike('USER_AGENT', '%' . $filter['FIND'] . '%');
}
if (isset($filter['USER_ID']))
{
	$query->where('USER_ID', $filter['USER_ID']);
}
if (isset($filter['DEVICE_UID']))
{
	$query->where('DEVICE_UID', $filter['DEVICE_UID']);
}
if (isset($filter['DEVICE_TYPE']))
{
	$query->where('DEVICE_TYPE', $filter['DEVICE_TYPE']);
}
if (isset($filter['BROWSER']))
{
	$query->whereLike('BROWSER', '%' . $filter['BROWSER'] . '%');
}
if (isset($filter['PLATFORM']))
{
	$query->whereLike('PLATFORM', '%' . $filter['PLATFORM'] . '%');
}
if (isset($filter['USER_AGENT']))
{
	$query->whereLike('USER_AGENT', '%' . $filter['USER_AGENT'] . '%');
}

$result = $query->exec();

if ($list->isTotalCountRequest())
{
	$list->sendTotalCountResponse($result->getCount());
}

$n = 0;
$pageSize = $list->getNavSize();

while ($device = $result->fetch())
{
	$n++;
	if ($n > $pageSize && !$excelMode)
	{
		break;
	}

	$loginsUrl = 'user_devices_history.php?lang=' . LANGUAGE_ID . '&DEVICE_ID=' . $device['ID'] . '&apply_filter=Y';

	$row = $list->addRow($device['ID'], $device, $loginsUrl, Loc::getMessage('main_user_devices_row_title'));

	$row->addViewField('DEVICE_TYPE', $deviceTypes[$device['DEVICE_TYPE']]);

	$actions = [
		[
			'ICON' => 'view',
			'TEXT' => Loc::getMessage('main_user_devices_menu_history'),
			'LINK' => $loginsUrl,
			'DEFAULT' => true,
		]
	];

	$row->addActions($actions);
}

$nav->setRecordCount($nav->getOffset() + $n);
$list->setNavigation($nav, Loc::getMessage('main_user_devices_page'), false);

$list->AddAdminContextMenu();

$list->CheckListMode();

$APPLICATION->SetTitle(Loc::getMessage('main_user_devices_title'));

require __DIR__ . '/../include/prolog_admin_after.php';

$list->DisplayFilter($filterFields);
$list->DisplayList(['SHOW_COUNT_HTML' => true, 'ACTION_PANEL' => false]);

require __DIR__ . '/../include/epilog_admin.php';