AnonSec Shell
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/www/cj79373/components/com_engage/Model/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     

Current File : /home/coopiak/www/cj79373/components/com_engage/Model/Comments.php
<?php
/**
 * @package   AkeebaEngage
 * @copyright Copyright (c)2020-2022 Nicholas K. Dionysopoulos / Akeeba Ltd
 * @license   GNU General Public License version 3, or later
 */

namespace Akeeba\Engage\Site\Model;

defined('_JEXEC') or die();

use Akeeba\Engage\Admin\Model\Comments as AdminCommentsModel;
use Exception;
use FOF40\Model\Mixin\Assertions;
use FOF40\IP\IPHelper as Ip;
use Joomla\CMS\Application\SiteApplication;
use Joomla\CMS\Captcha\Captcha;
use Joomla\CMS\Factory;
use RuntimeException;

/**
 * @inheritDoc
 *
 * @method $this useCaptcha(bool $useCaptcha) Should I use the CAPTCHA when saving a record? DEFAULTS TO FALSE.
 */
class Comments extends AdminCommentsModel
{
	use Assertions;

	/** @inheritDoc */
	public function check()
	{
		// Check the CAPTCHA
		$this->assertCaptchaSolved();

		// Add an IP address if none has been provided yet
		if (empty($this->getFieldValue('ip')))
		{
			$this->ip = Ip::getIp();
		}

		// Log the User Agent string if none was provided
		if (empty($this->getFieldValue('user_agent')))
		{
			$this->user_agent = $this->container->platform->isCli()
				? ''
				: trim($this->input->server->getString('HTTP_USER_AGENT', ''));
		}

		parent::check();
	}

	/**
	 * Get the Joomla! CAPTCHA object
	 *
	 * @param   string  $namespace
	 *
	 * @return  Captcha|null
	 */
	public function getCaptcha($namespace = 'akeeba_engage'): ?Captcha
	{
		// Get the default CAPTCHA set up in Joomla's Global Configuration
		try
		{
			/** @var SiteApplication $app */
			$app     = Factory::getApplication();
			$default = $app->getParams()->get('captcha', $app->get('captcha'));
		}
		catch (Exception $e)
		{
			$default = null;
		}

		// Get the name of the CAPTCHA plugin the admin chose to use, falling back to Joomla's default.
		$captchaPlugin = $this->container->params->get('captcha', $default);

		if (empty($captchaPlugin) || ($captchaPlugin == 'none'))
		{
			return null;
		}

		// Return the CAPTCHA object. If the captcha plugin name is invalid (e.g. unpublished) this will return null.
		try
		{
			return Captcha::getInstance($captchaPlugin, ['namespace' => $namespace]);
		}
		catch (Exception $e)
		{
			return null;
		}
	}

	/**
	 * Checks that a CAPTCHA was meant to be provided and was solved correctly.
	 *
	 * @throws  RuntimeException
	 */
	private function assertCaptchaSolved(): void
	{
		// Should I use a CAPTCHA at all? This is a setting defined per Model instance
		$useCaptcha = (bool) $this->getState('useCaptcha', false);

		if (!$useCaptcha)
		{
			return;
		}

		// Am I only using the CAPTCHA for certain users?
		$useCaptchaFor = $this->container->params->get('captcha_for', 'guests');
		$useCaptchaFor = in_array($useCaptchaFor, ['guests', 'all', 'nonmanager']) ? $useCaptchaFor : 'guests';

		if (($useCaptchaFor === 'guests') && ($this->getUser()->guest !== 1))
		{
			return;
		}

		if (($useCaptchaFor === 'nonmanager') && $this->getUser()->authorise('core.manage', 'com_engage'))
		{
			return;
		}

		/**
		 * Make sure I can actually get a Joomla CAPTCHA object.
		 *
		 * Note that the administrator may have chose no CAPTCHA in our component configuration or Joomla's Global
		 * Configuration.
		 */
		$captcha = $this->getCaptcha();

		if (is_null($captcha))
		{
			return;
		}

		// Finally, check the CAPTCHA solution.
		$captchaValue = $this->getState('captcha', '');

		$this->assert($captcha->checkAnswer($captchaValue), 'COM_ENGAGE_COMMENTS_ERR_CAPTCHA');
	}

}

Anon7 - 2022
AnonSec Team