Current File : //var/www/prestashop/modules/ps_facebook/classes/Handler/ErrorHandler/ErrorHandler.php |
<?php
/**
* Copyright since 2007 PrestaShop SA and Contributors
* PrestaShop is an International Registered Trademark & Property of PrestaShop SA
*
* NOTICE OF LICENSE
*
* This source file is subject to the Academic Free License version 3.0
* that is bundled with this package in the file LICENSE.md.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/AFL-3.0
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@prestashop.com so we can send you a copy immediately.
*
* @author PrestaShop SA and Contributors <contact@prestashop.com>
* @copyright Since 2007 PrestaShop SA and Contributors
* @license https://opensource.org/licenses/AFL-3.0 Academic Free License version 3.0
*/
namespace PrestaShop\Module\PrestashopFacebook\Handler\ErrorHandler;
use Context;
use Exception;
use Module;
use PrestaShop\Module\PrestashopFacebook\Config\Config;
use PrestaShop\Module\PrestashopFacebook\Config\Env;
use PrestaShop\PsAccountsInstaller\Installer\Facade\PsAccounts;
use Ps_facebook;
/**
* Handle Error.
*/
class ErrorHandler
{
/**
* @var ModuleFilteredRavenClient
*/
protected $client;
/**
* @param Ps_facebook $module
*/
public function __construct(Module $module, Env $env, Context $context = null)
{
$this->client = new ModuleFilteredRavenClient(
$env->get('PSX_FACEBOOK_SENTRY_CREDENTIALS'),
[
'level' => 'warning',
'tags' => [
'php_version' => phpversion(),
'ps_facebook_version' => $module->version,
'prestashop_version' => _PS_VERSION_,
'ps_facebook_is_enabled' => Module::isEnabled($module->name),
'ps_facebook_is_installed' => Module::isInstalled($module->name),
'facebook_app_id' => Config::PSX_FACEBOOK_APP_ID,
],
'release' => "v{$module->version}",
'error_types' => E_ALL & ~E_STRICT & ~E_DEPRECATED & ~E_USER_DEPRECATED & ~E_NOTICE & ~E_USER_NOTICE,
'sample_rate' => $this->isContextInFrontOffice($context) ? 0.2 : 1,
]
);
try {
$psAccountsService = $module->getService(PsAccounts::class)->getPsAccountsService();
$this->client->user_context([
'id' => $psAccountsService->getShopUuidV4(),
]);
} catch (Exception $e) {
// Do nothing
}
// We use realpath to get errors even if module is behind a symbolic link
$this->client->setAppPath(realpath(_PS_MODULE_DIR_ . $module->name . '/'));
// - Do no not add the shop root folder, it will exclude everything even if specified in the app path.
// - Excluding vendor/ avoids errors comming from one of your libraries library when called by another module.
$this->client->setExcludedAppPaths([
realpath(_PS_MODULE_DIR_ . $module->name . '/vendor/'),
]);
$this->client->setExcludedDomains(['127.0.0.1', 'localhost', '.local']);
// Other conditions can be done here to prevent the full installation of the client:
// - PHP versions,
// - PS versions,
// - Integration environment,
// - ...
if ($env->get('PSX_FACEBOOK_APP_ID') !== Config::PSX_FACEBOOK_APP_ID) {
return;
}
if (version_compare(phpversion(), '7.4.0', '>=') && version_compare(_PS_VERSION_, '1.7.8.0', '<')) {
return;
}
$this->client->install();
}
/**
* @param \Exception $error
* @param mixed $code
* @param bool|null $throw
* @param array|null $data
*
* @return void
*
* @throws \Exception
*/
public function handle($error, $code = null, $throw = true, $data = null)
{
$this->client->captureException($error, $data);
if ($code && true === $throw) {
http_response_code($code);
throw $error;
}
}
/**
* @return void
*/
private function __clone()
{
}
/**
* @return bool
*/
private function isContextInFrontOffice(Context $context = null)
{
/*
Some shops have trouble to refresh the cache of the service container.
To avoid issues on production after an upgrade, context has been made optional.
ToDo: Remove the nullable later.
*/
if (!$context) {
return false;
}
/** @var \Controller|null $controller */
$controller = $context->controller;
if (!$controller) {
return false;
}
return in_array($controller->controller_type, ['front', 'modulefront']);
}
}