From e147d25dbfc834910620af763585e40038878ce0 Mon Sep 17 00:00:00 2001 From: Yuri Kuznetsov Date: Tue, 9 Sep 2025 14:43:14 +0300 Subject: [PATCH] before upgrade check --- upgrades/9.2/data.json | 3 + upgrades/9.2/scripts/BeforeUpgrade.php | 96 ++++++++++++++++++++++++++ 2 files changed, 99 insertions(+) create mode 100644 upgrades/9.2/data.json create mode 100644 upgrades/9.2/scripts/BeforeUpgrade.php diff --git a/upgrades/9.2/data.json b/upgrades/9.2/data.json new file mode 100644 index 0000000000..3d74c7fbee --- /dev/null +++ b/upgrades/9.2/data.json @@ -0,0 +1,3 @@ +{ + "manifest": {} +} diff --git a/upgrades/9.2/scripts/BeforeUpgrade.php b/upgrades/9.2/scripts/BeforeUpgrade.php new file mode 100644 index 0000000000..79d91482c6 --- /dev/null +++ b/upgrades/9.2/scripts/BeforeUpgrade.php @@ -0,0 +1,96 @@ +. + * + * The interactive user interfaces in modified source and object code versions + * of this program must display Appropriate Legal Notices, as required under + * Section 5 of the GNU Affero General Public License version 3. + * + * In accordance with Section 7(b) of the GNU Affero General Public License version 3, + * these Appropriate Legal Notices must retain the display of the "EspoCRM" word. + ************************************************************************/ + +use Espo\Core\Container; +use Espo\Entities\Extension; +use Espo\ORM\EntityManager; + +/** @noinspection PhpMultipleClassDeclarationsInspection */ +class BeforeUpgrade +{ + private ?Container $container = null; + + /** + * @throws Exception + */ + public function run(Container $container): void + { + $this->container = $container; + + $this->processCheckExtensions(); + } + + + /** + * @throws Error + */ + private function processCheckExtensions(): void + { + $errorMessageList = []; + + $this->processCheckExtension('Google Integration', '1.8.2', $errorMessageList); + $this->processCheckExtension('Outlook Integration', '1.6.7', $errorMessageList); + + if (!count($errorMessageList)) { + return; + } + + $message = implode("\n\n", $errorMessageList); + + throw new Error($message); + } + + private function processCheckExtension(string $name, string $minVersion, array &$errorMessageList): void + { + $em = $this->container->getByClass(EntityManager::class); + + $extension = $em->getRDBRepository(Extension::ENTITY_TYPE) + ->where([ + 'name' => $name, + 'isInstalled' => true, + ]) + ->findOne(); + + if (!$extension) { + return; + } + + $version = $extension->get('version'); + + if (version_compare($version, $minVersion, '>=')) { + return; + } + + $message = + "EspoCRM 9.2 is not compatible with '$name' extension of versions lower than $minVersion. " . + "Please upgrade the extension or uninstall it."; + + $errorMessageList[] = $message; + } +}