plugins/logs/admin_modules/yf_log_user_auth.class.php
<?php
/**
* Users "log in" info analyser.
*/
class yf_log_user_auth
{
public function show()
{
$filter_name = $_GET['object'] . '__' . $_GET['action'];
$default_filter = [
'order_by' => 'date',
'order_direction' => 'desc',
];
$sql = 'SELECT * FROM ' . db('log_auth');
return table($sql, [
'filter' => (array) $_SESSION[$filter_name] + $default_filter,
'filter_params' => [
'name' => 'like',
],
])
->user('user_id')
->text('login')
->link('group', './?object=user_groups&action=edit&id=%d', main()->get_data('user_groups'))
->link('ip', './?object=' . $_GET['object'] . '&action=show_for_ip&id=%d')
->date('date', ['format' => 'full', 'nowrap' => 1])
->text('user_agent')
->text('referer');
}
/**
* Show log logins for selected user.
*/
public function show_for_user()
{
$_GET['page'] = 'clear';
$_GET['filter'] = 'user_id:' . (int) ($_GET['id']);
return $this->filter_save();
}
/**
* Show log logins for selected IP address.
*/
public function show_for_ip()
{
$_GET['page'] = 'clear';
$_GET['filter'] = 'ip:' . preg_replace('~[^0-9\.]+~ims', '', $_GET['id']);
return $this->filter_save();
}
public function filter_save()
{
return _class('admin_methods')->filter_save();
}
public function _show_filter()
{
if ( ! in_array($_GET['action'], ['show'])) {
return false;
}
$order_fields = [];
foreach (explode('|', 'user_id|login|group|date|ip|user_agent|referer') as $f) {
$order_fields[$f] = $f;
}
return form($r, [
'filter' => true,
])
->number('user_id')
->text('login')
->text('ip')
->select_box('group', main()->get_data('user_groups'), ['show_text' => 1])
->select_box('order_by', $order_fields, ['show_text' => 1])
->order_box()
->save_and_clear();
}
/**
* @param mixed $params
*/
public function _hook_widget__user_auth_log($params = [])
{
// TODO
}
}