From 2e0b8ad1eba42fcfc74341c13718794445432f5e Mon Sep 17 00:00:00 2001 From: Frederik Rommel <15031079+rommelfreddy@users.noreply.github.com> Date: Fri, 9 Aug 2024 11:11:05 +0200 Subject: [PATCH] Add option to exclude default-integrations (#146) --- Helper/Data.php | 6 ++++++ Plugin/GlobalExceptionCatcher.php | 9 +++++++++ README.md | 14 +++++++++----- 3 files changed, 24 insertions(+), 5 deletions(-) diff --git a/Helper/Data.php b/Helper/Data.php index 01d2e58..a28c4ac 100644 --- a/Helper/Data.php +++ b/Helper/Data.php @@ -49,6 +49,7 @@ class Data extends AbstractHelper 'tracing_enabled', 'tracing_sample_rate', 'ignore_js_errors', + 'disable_default_integrations', ]; /** @@ -93,6 +94,11 @@ public function getTracingSampleRate(): float return (float) $this->config['tracing_sample_rate'] ?? 0.2; } + public function getDisabledDefaultIntegrations(): array + { + return $this->config['disable_default_integrations'] ?? []; + } + /** * @return array|null */ diff --git a/Plugin/GlobalExceptionCatcher.php b/Plugin/GlobalExceptionCatcher.php index fc236a5..c2b3cc4 100755 --- a/Plugin/GlobalExceptionCatcher.php +++ b/Plugin/GlobalExceptionCatcher.php @@ -8,8 +8,10 @@ use JustBetter\Sentry\Model\ReleaseIdentifier; use JustBetter\Sentry\Model\SentryInteraction; use Magento\Framework\AppInterface; +use Magento\Framework\DataObject; use Magento\Framework\DataObjectFactory; use Magento\Framework\Event\ManagerInterface as EventManagerInterface; +use Sentry\Integration\IntegrationInterface; class GlobalExceptionCatcher { @@ -37,6 +39,7 @@ public function aroundLaunch(AppInterface $subject, callable $proceed) return $proceed(); } + /** @var DataObject $config */ $config = $this->dataObjectFactory->create(); $config->setDsn($this->sentryHelper->getDSN()); @@ -59,6 +62,12 @@ public function aroundLaunch(AppInterface $subject, callable $proceed) return $data->getEvent(); }); + $disabledDefaultIntegrations = $this->sentryHelper->getDisabledDefaultIntegrations(); + $config->setData('integrations', static fn (array $integrations) => array_filter( + $integrations, + static fn (IntegrationInterface $integration) => !in_array(get_class($integration), $disabledDefaultIntegrations) + )); + $this->eventManager->dispatch('sentry_before_init', [ 'config' => $config, ]); diff --git a/README.md b/README.md index eece21b..ca0f661 100644 --- a/README.md +++ b/README.md @@ -24,9 +24,12 @@ This module uses the [Magento Deployment Configuration](https://devdocs.magento. 'ignore_exceptions' => [], 'mage_mode_development' => false, 'js_sdk_version' => \JustBetter\Sentry\Block\SentryScript::CURRENT_VERSION, - 'tracing_enabled' => true, + 'tracing_enabled' => true, 'tracing_sample_rate' => 0.5, - 'ignore_js_errors' => [] + 'ignore_js_errors' => [], + 'disable_default_integrations' => [ + \Sentry\Integration\ModulesIntegration::class, + ] ] ``` @@ -39,13 +42,14 @@ Next to that there are some configuration options under Stores > Configuration > * `errorexception_reporting`: If the Exception being thrown is an instance of [ErrorException](https://www.php.net/manual/en/class.errorexception.php) send the error to sentry if it matches the error reporting. This uses the same syntax as [Error Reporting](https://www.php.net/manual/en/function.error-reporting.php) eg. `E_ERROR | E_WARNING` to only log Errors and Warnings. * `ignore_exceptions`: If the class being thrown matches any in this list do not send it to Sentry e.g. `[\Magento\Framework\Exception\NoSuchEntityException::class]` * `mage_mode_development`: If this option is set to true you will receive issues in Sentry even if you're Magento is running in develop mode. -* `js_sdk_version`: if this option is set, it will load the explicit version of the javascript SDK of Sentry. +* `js_sdk_version`: if this option is set, it will load the explicit version of the javascript SDK of Sentry. * `tracing_enabled` if this option is set to true, tracing got enabled (bundle file got loaded automatically). Default: `false` * `tracing_sample_rate` if tracing is enabled, you should also set the sample rate. Default: `0.2` * `ignore_js_errors` array of javascript error messages, which should be not send to Sentry. (see also `ignoreErrors` in [Sentry documentation](https://docs.sentry.io/clients/javascript/config/)) +* `disable_default_integrations` provide a list of FQCN of default integrations, which you do not want to use. [List of default integrations](https://github.com/getsentry/sentry-php/tree/master/src/Integration). Default: `[]` ### Configuration for Adobe Cloud -Since Adobe Cloud doesn't allow you to add manually add content to the `env.php` file, the configuration can be done +Since Adobe Cloud doesn't allow you to add manually add content to the `env.php` file, the configuration can be done using the "Variables" in Adobe Commerce using the following variables: * `CONFIG__SENTRY__ENVIRONMENT__ENABLED`: boolean @@ -61,7 +65,7 @@ using the "Variables" in Adobe Commerce using the following variables: * `CONFIG__SENTRY__ENVIRONMENT__TRACING_SAMPLE_RATE`: float * `CONFIG__SENTRY__ENVIRONMENT__IGNORE_JS_ERRORS`: A JSON encoded array of error messages -The following configuration settings can be overridden in the Magento admin. This is limited to ensure that changes to +The following configuration settings can be overridden in the Magento admin. This is limited to ensure that changes to particular config settings can only be done on server level and can't be broken by changes in the admin. ## Optional error page configuration