
| Current Path : /var/www/html1/bbp/web/modules/contrib/visitors/src/Controller/Report/ |
Linux ift1.ift-informatik.de 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64 |
| Current File : /var/www/html1/bbp/web/modules/contrib/visitors/src/Controller/Report/Hits.php |
<?php
/**
* @file
* Contains Drupal\visitors\Controller\Report\Hits.
*/
namespace Drupal\visitors\Controller\Report;
use Drupal\Component\Utility\Html;
use Drupal\Core\Controller\ControllerBase;
use Drupal\Core\Datetime\Date;
use Drupal\Core\Datetime\DateFormatterInterface;
use Drupal\Core\Form\FormBuilderInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Drupal\Core\Url;
use Drupal\Core\Link;
class Hits extends ControllerBase {
/**
* The date service.
*
* @var \Drupal\Core\Datetime\DateFormatterInterface
*/
protected $date;
/**
* The form builder service.
*
* @var \Drupal\Core\Form\FormBuilderInterface
*/
protected $formBuilder;
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static(
$container->get('date.formatter'),
$container->get('form_builder')
);
}
/**
* Constructs a Hits object.
*
* @param \Drupal\Core\Datetime\DateFormatterInterface $date
* The date service.
*
* @param \Drupal\Core\Form\FormBuilderInterface $form_builder
* The form builder service.
*/
public function __construct(DateFormatterInterface $date_formatter, FormBuilderInterface $form_builder) {
$this->date = $date_formatter;
$this->formBuilder = $form_builder;
}
/**
* Returns a hits page.
*
* @return array
* A render array representing the hits page content.
*/
public function display($host) {
$form = $this->formBuilder->getForm('Drupal\visitors\Form\DateFilter');
$header = $this->_getHeader();
return array(
'#title' => Html::escape(t('Hits from') . ' ' . $host),
'visitors_date_filter_form' => $form,
'visitors_table' => array(
'#type' => 'table',
'#header' => $header,
'#rows' => $this->_getData($header, $host),
),
'visitors_pager' => array('#type' => 'pager')
);
}
/**
* Returns a table header configuration.
*
* @return array
* A render array representing the table header info.
*/
protected function _getHeader() {
return array(
'#' => array(
'data' => t('#'),
),
'visitors_id' => array(
'data' => t('ID'),
'field' => 'visitors_id',
'specifier' => 'visitors_id',
'class' => array(RESPONSIVE_PRIORITY_LOW),
'sort' => 'desc',
),
'visitors_date_time' => array(
'data' => t('Date'),
'field' => 'visitors_date_time',
'specifier' => 'visitors_date_time',
'class' => array(RESPONSIVE_PRIORITY_LOW),
),
'visitors_url' => array(
'data' => t('URL'),
'field' => 'visitors_url',
'specifier' => 'visitors_url',
'class' => array(RESPONSIVE_PRIORITY_LOW),
),
'u.name' => array(
'data' => t('User'),
'field' => 'u.name',
'specifier' => 'u.name',
'class' => array(RESPONSIVE_PRIORITY_LOW),
),
'' => array(
'data' => t('Operations'),
),
);
}
/**
* Returns a table content.
*
* @param array $header
* Table header configuration.
*
* @return array
* Array representing the table content.
*/
protected function _getData($header, $host) {
if (@inet_pton($host) === FALSE) {
return;
}
$items_per_page = \Drupal::config('visitors.config')->get('items_per_page');
$query = \Drupal::database()->select('visitors', 'v')
->extend('Drupal\Core\Database\Query\PagerSelectExtender')
->extend('Drupal\Core\Database\Query\TableSortExtender');
$query->leftJoin('users_field_data', 'u', 'u.uid=v.visitors_uid');
$query->fields(
'v',
array(
'visitors_id',
'visitors_ip',
'visitors_uid',
'visitors_date_time',
'visitors_title',
'visitors_path',
'visitors_url'
)
);
$query->fields('u', array('name', 'uid'));
$query->condition('v.visitors_ip', sprintf('%u', ip2long($host)), '=');
visitors_date_filter_sql_condition($query);
$query->orderByHeader($header);
$query->limit($items_per_page);
$count_query = \Drupal::database()->select('visitors', 'v');
$count_query->addExpression('COUNT(*)');
$count_query->condition('visitors_ip', sprintf('%u', ip2long($host)));
visitors_date_filter_sql_condition($count_query);
$query->setCountQuery($count_query);
$results = $query->execute();
$count = $count_query->execute()->fetchField();
if ($count == 0) {
return;
}
$rows = array();
$page = isset($_GET['page']) ? $_GET['page'] : 0;
$i = 0 + $page * $items_per_page;
foreach ($results as $data) {
$user = \Drupal::entityTypeManager()->getStorage('user')->load($data->visitors_uid);
$username = array('#type' => 'username', '#account' => $user);
$visitors_host_url = Url::fromRoute('visitors.hit_details',array("hit_id"=>$data->visitors_id));
$visitors_host_link = Link::fromTextAndUrl($this->t('Details'),$visitors_host_url);
$visitors_host_link = $visitors_host_link->toRenderable();
$user_profile_url = Url::fromRoute('entity.user.canonical',array("user"=>$user->id()));
$user_profile_link = Link::fromTextAndUrl($user->getAccountName(),$user_profile_url);
$user_profile_link = $user_profile_link->toRenderable();
$rows[] = array(
++$i,
$data->visitors_id,
$this->date->format($data->visitors_date_time, 'short'),
Html::escape($data->visitors_title) . " - ". $data->visitors_url,
render($user_profile_link),
render($visitors_host_link)
);
}
return $rows;
}
}