custom/plugins/CogiGreetingCard/src/CogiGreetingCard.php line 20

Open in your IDE?
  1. <?php declare(strict_types=1);
  2. namespace Cogi\CogiGreetingCard;
  3. use Doctrine\DBAL\Connection;
  4. use Shopware\Core\Checkout\Document\Aggregate\DocumentType\DocumentTypeEntity;
  5. use Shopware\Core\Framework\Context;
  6. use Shopware\Core\Framework\DataAbstractionLayer\Search\Criteria;
  7. use Shopware\Core\Framework\DataAbstractionLayer\Search\Filter\EqualsFilter;
  8. use Shopware\Core\Framework\Plugin;
  9. use Shopware\Core\Framework\Plugin\Context\InstallContext;
  10. use Shopware\Core\Framework\Plugin\Context\UninstallContext;
  11. use Shopware\Core\Framework\Uuid\Uuid;
  12. use Shopware\Core\System\NumberRange\Aggregate\NumberRangeType\NumberRangeTypeEntity;
  13. use Shopware\Core\System\NumberRange\NumberRangeEntity;
  14. use Symfony\Component\Config\FileLocator;
  15. use Symfony\Component\DependencyInjection\ContainerBuilder;
  16. use Symfony\Component\DependencyInjection\Loader\XmlFileLoader;
  17. class CogiGreetingCard extends Plugin {
  18.     public function install(InstallContext $context): void {
  19.         parent::install($context);
  20.     }
  21.     public function uninstall(UninstallContext $context): void {
  22.         parent::uninstall($context);
  23.         if ($context->keepUserData()) {
  24.             return;
  25.         }
  26.         $documentTypeRepository $this->container->get('document_type.repository');
  27.         $numberRangeTypeRepository $this->container->get('number_range_type.repository');
  28.         $numberRangeRepository $this->container->get('number_range.repository');
  29.         $criteria = new Criteria();
  30.         $criteria->addFilter(new EqualsFilter('technicalName''cogi_greeting_card'));
  31.         /** @var DocumentTypeEntity $documentType */
  32.         $documentType $documentTypeRepository->search($criteriaContext::createDefaultContext())->getEntities()->first();
  33.         $documentTypeId $documentType->getId();
  34.         $criteria->resetFilters();
  35.         $criteria->addFilter(new EqualsFilter('technicalName''document_cogi_greeting_card'));
  36.         /** @var NumberRangeTypeEntity $numberRangeType */
  37.         $numberRangeType $numberRangeTypeRepository->search($criteriaContext::createDefaultContext())->getEntities()->first();
  38.         $numberRangeTypeId $numberRangeType->getId();
  39.         $criteria->resetFilters();
  40.         $criteria->addFilter(new EqualsFilter('typeId'$numberRangeTypeId));
  41.         /** @var NumberRangeEntity $numberRange */
  42.         $numberRange $numberRangeRepository->search($criteriaContext::createDefaultContext())->getEntities()->first();
  43.         $numberRangeId $numberRange->getId();
  44.         $connection $this->container->get(Connection::class);
  45.         $connection->exec("DELETE FROM `number_range_state` WHERE `number_range_id` = UNHEX('" $numberRangeId "');");
  46.         $connection->exec("DELETE FROM `number_range` WHERE `type_id` = UNHEX('" $numberRangeTypeId "');");
  47.         $connection->exec("DELETE FROM `document` WHERE `document_type_id` = UNHEX('" $documentTypeId "');");
  48.         $connection->exec("DELETE FROM `number_range_type` WHERE `technical_name` LIKE '%document_cogi_greeting_card%';");
  49.         $connection->exec("DELETE FROM `document_type` WHERE `technical_name` LIKE '%cogi_cogi_greeting_card%';");
  50.     }
  51.     public function build(ContainerBuilder $containerBuilder): void {
  52.         parent::build($containerBuilder);
  53.         $loader = new XmlFileLoader($containerBuilder, new FileLocator(__DIR__));
  54.         $loader->load('CogiGreetingCard/DependencyInjection/service.xml');
  55.     }
  56. }