![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/magento/module-product-alert/Setup/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ namespace Magento\ProductAlert\Setup; use Magento\Framework\Setup\ExternalFKSetup; use Magento\Framework\Setup\InstallSchemaInterface; use Magento\Framework\Setup\ModuleContextInterface; use Magento\Framework\Setup\SchemaSetupInterface; use Magento\Framework\EntityManager\MetadataPool; use Magento\Catalog\Api\Data\ProductInterface; /** * @codeCoverageIgnore */ class Recurring implements InstallSchemaInterface { /** * @var MetadataPool */ protected $metadataPool; /** * @var ExternalFKSetup */ protected $externalFKSetup; /** * @param MetadataPool $metadataPool * @param ExternalFKSetup $externalFKSetup */ public function __construct( MetadataPool $metadataPool, ExternalFKSetup $externalFKSetup ) { $this->metadataPool = $metadataPool; $this->externalFKSetup = $externalFKSetup; } /** * {@inheritdoc} */ public function install(SchemaSetupInterface $setup, ModuleContextInterface $context) { $installer = $setup; $installer->startSetup(); $listTables = [ ['product_alert_price', 'product_id'], ['product_alert_stock', 'product_id'], ]; foreach ($listTables as $tableData) { $this->addExternalForeignKeys($installer, $tableData[0], $tableData[1]); } $installer->endSetup(); } /** * Add external foreign keys * * @param SchemaSetupInterface $installer * @param string $tableName * @param string $columnName * @return void * @throws \Exception */ protected function addExternalForeignKeys(SchemaSetupInterface $installer, $tableName, $columnName) { $metadata = $this->metadataPool->getMetadata(ProductInterface::class); $this->externalFKSetup->install( $installer, $metadata->getEntityTable(), $metadata->getIdentifierField(), $tableName, $columnName ); } }