| Server IP : 54.36.91.62 / Your IP : 216.73.217.112 Web Server : Apache System : Linux webm013.cluster127.gra.hosting.ovh.net 5.15.206-ovh-vps-grsec-zfs-classid #1 SMP Fri May 15 02:41:25 UTC 2026 x86_64 User : coopiak ( 151928) PHP Version : 8.3.23 Disable Function : _dyuweyrj4,_dyuweyrj4r,dl MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/coopiak/amisdesseniors-fr/nice/libraries/kunena/src/Tables/ |
Upload File : |
<?php
/**
* Kunena Component
*
* @package Kunena.Framework
* @subpackage Tables
*
* @copyright Copyright (C) 2008 - @currentyear@ Kunena Team. All rights reserved.
* @license https://www.gnu.org/copyleft/gpl.html GNU/GPL
* @link https://www.kunena.org
**/
namespace Kunena\Forum\Libraries\Tables;
\defined('_JEXEC') or die();
use Exception;
use Joomla\CMS\Date\Date;
use Joomla\CMS\Language\Text;
use Joomla\Database\DatabaseDriver;
use Joomla\Database\Exception\ExecutionFailureException;
use Kunena\Forum\Libraries\Error\KunenaError;
use Kunena\Forum\Libraries\User\KunenaUserHelper;
use RuntimeException;
/**
* Kunena User Bans
* Provides access to the #__kunena_users_banned table
*
* @since Kunena 6.0
*/
class KunenaUserBans extends KunenaTable
{
/**
* @since Kunena 6.0
*/
const ANY = 0;
/**
* @since Kunena 6.0
*/
const ACTIVE = 1;
/**
* @var null
* @since Kunena 6.0
*/
public $id = null;
/**
* @var null
* @since Kunena 6.0
*/
public $userid = null;
/**
* @var null
* @since Kunena 6.0
*/
public $ip = null;
/**
* @var null
* @since Kunena 6.0
*/
public $blocked = null;
/**
* @var null
* @since Kunena 6.0
*/
public $expiration = null;
/**
* @var null
* @since Kunena 6.0
*/
public $created_by = null;
/**
* @var null
* @since Kunena 6.0
*/
public $created_time = null;
/**
* @var null
* @since Kunena 6.0
*/
public $reason_private = null;
/**
* @var null
* @since Kunena 6.0
*/
public $reason_public = null;
/**
* @var null
* @since Kunena 6.0
*/
public $modified_by = null;
/**
* @var null
* @since Kunena 6.0
*/
public $modified_time = null;
/**
* @var null
* @since Kunena 6.0
*/
public $comments = null;
/**
* @var null
* @since Kunena 6.0
*/
public $params = null;
/**
* @param DatabaseDriver $db Database driver
*
* @since Kunena 6.0
*/
public function __construct(DatabaseDriver $db)
{
parent::__construct('#__kunena_users_banned', 'id', $db);
}
/**
* @param integer $userid userid
* @param int $mode mode
*
* @return boolean
*
* @since Kunena 6.0
*
* @throws Exception
*/
public function loadByUserid(int $userid, $mode = self::ACTIVE): bool
{
// Reset the table.
$k = $this->_tbl_key;
$this->$k = 0;
$this->reset();
// Check for a valid id to load.
if ($userid === null || \intval($userid) < 1) {
return false;
}
$now = new Date();
$nullDate = $this->_db->getNullDate() ? $this->_db->quote($this->_db->getNullDate()) : 'NULL';
// Load the user data.
if ($mode == self::ACTIVE) {
$where = ' AND (expiration = ' . $nullDate . ' OR expiration > ' . $this->_db->quote($now->toSql()) . ')';
} else {
$where = '';
}
$query = $this->_db->createQuery();
$query->select('*')
->from($this->_db->quoteName($this->_tbl))
->where($this->_db->quoteName('userid') . ' = ' . $this->_db->quote($userid) . ' ' . $where)
->order($this->_db->quoteName('id') . ' DESC');
$query->setLimit(1);
$this->_db->setQuery($query);
try {
$data = $this->_db->loadAssoc();
} catch (ExecutionFailureException $e) {
KunenaError::displayDatabaseError($e);
return false;
}
if (empty($data)) {
$this->userid = $userid;
return false;
}
// Bind the data to the table.
$this->bind($data);
return true;
}
/**
* @param mixed $data data
* @param array $ignore ignore
*
* @return void
*
* @since Kunena 6.0
*/
public function bind($data, $ignore = [])
{
if (isset($data['comments'])) {
$data['comments'] = !\is_string($data['comments']) ? json_encode($data['comments']) : $data['comments'];
}
if (isset($data['params'])) {
$data['params'] = !\is_string($data['params']) ? json_encode($data['params']) : $data['params'];
}
parent::bind($data, $ignore);
}
/**
* @param integer $ip ip
* @param int $mode mode
*
* @return boolean
*
* @since Kunena 6.0
*
* @throws Exception
*/
public function loadByIP(int $ip, $mode = self::ACTIVE): bool
{
// Reset the table.
$k = $this->_tbl_key;
$this->$k = 0;
$this->reset();
// Check for a valid id to load.
if ($ip === null || !\is_string($ip)) {
return false;
}
$now = new Date();
$nullDate = $this->_db->getNullDate() ? $this->_db->quote($this->_db->getNullDate()) : 'NULL';
// Load the user data.
if ($mode == self::ACTIVE) {
$where = 'AND (expiration = ' . $nullDate . ' OR expiration > ' . $this->_db->quote($now->toSql()) . ')';
} else {
$where = '';
}
$query = $this->_db->createQuery();
$query->select('*')
->from($this->_db->quoteName($this->_tbl))
->where($this->_db->quoteName('ip') . ' = ' . $this->_db->quote($ip) . ' ' . $where)
->order($this->_db->quoteName('id') . ' DESC');
$query->setLimit(1);
$this->_db->setQuery($query);
try {
$data = $this->_db->loadAssoc();
} catch (ExecutionFailureException $e) {
KunenaError::displayDatabaseError($e);
return false;
}
if (empty($data)) {
$this->ip = $ip;
return false;
}
// Bind the data to the table.
$this->bind($data);
return true;
}
/**
* @return boolean
*
* @since Kunena 6.0
*
* @throws Exception
*/
public function check(): bool
{
if (!$this->ip) {
$user = KunenaUserHelper::get($this->userid);
if (!$user->exists()) {
throw new RuntimeException(Text::sprintf('COM_KUNENA_LIB_TABLE_USERBANS_ERROR_USER_INVALID', (int) $user->userid));
}
}
return true;
}
}