custom/plugins/SwagPlatformSecurity/src/SwagPlatformSecurity.php line 19

Open in your IDE?
  1. <?php declare(strict_types=1);
  2. namespace Swag\Security;
  3. use Shopware\Core\Framework\Plugin;
  4. use Shopware\Core\Framework\Plugin\Context\InstallContext;
  5. use Shopware\Core\Framework\Plugin\Context\UpdateContext;
  6. use Shopware\Core\Kernel;
  7. use Swag\Security\Components\RemoveDisabledServicesCompilerPass;
  8. use Swag\Security\Components\State;
  9. use Swag\Security\Components\UpdateHtaccess;
  10. use Symfony\Component\Config\FileLocator;
  11. use Symfony\Component\DependencyInjection\ContainerBuilder;
  12. use Symfony\Component\DependencyInjection\Loader\PhpFileLoader;
  13. require_once __DIR__ '/Fixes/NEXT15858/init.php';
  14. require_once __DIR__ '/Fixes/NEXT21077/init.php';
  15. class SwagPlatformSecurity extends Plugin
  16. {
  17.     public const PLUGIN_NAME 'SwagPlatformSecurity';
  18.     public function build(ContainerBuilder $container): void
  19.     {
  20.         $loader = new PhpFileLoader($container, new FileLocator([__DIR__ '/Resources/config']));
  21.         $loader->load('services.php');
  22.         $this->fetchPluginConfig($container);
  23.         $container->addCompilerPass(new RemoveDisabledServicesCompilerPass());
  24.     }
  25.     public function install(InstallContext $installContext): void
  26.     {
  27.         $this->copyHtaccess();
  28.     }
  29.     public function update(UpdateContext $updateContext): void
  30.     {
  31.         $this->copyHtaccess();
  32.     }
  33.     private function fetchPluginConfig(ContainerBuilder $container): void
  34.     {
  35.         try {
  36.             $qb Kernel::getConnection()->createQueryBuilder();
  37.             $config $qb
  38.                 ->select(['ticket''active'])
  39.                 ->from('swag_security_config''config')
  40.                 ->execute()
  41.                 ->fetchAll(\PDO::FETCH_KEY_PAIR);
  42.         } catch (\Throwable $e) {
  43.             $config = [];
  44.         }
  45.         foreach ($config as &$item) {
  46.             $item = (bool) $item;
  47.         }
  48.         unset($item);
  49.         $shopwareVersion $_SERVER['SHOPWARE_FAKE_VERSION'] ?? $container->getParameter('kernel.shopware_version');
  50.         $availableFixes = [];
  51.         $activeFixes = [];
  52.         foreach (State::KNOWN_ISSUES as $knownIssue) {
  53.             if (!$knownIssue::isValidForVersion($shopwareVersion)) {
  54.                 continue;
  55.             }
  56.             $availableFixes[] = $knownIssue;
  57.             if (array_key_exists($knownIssue::getTicket(), $config) && !$config[$knownIssue::getTicket()]) {
  58.                 continue;
  59.             }
  60.             $knownIssue::buildContainer($container);
  61.             $activeFixes[] = $knownIssue;
  62.         }
  63.         $container->setParameter('SwagPlatformSecurity.activeFixes'$activeFixes);
  64.         $container->setParameter('SwagPlatformSecurity.availableFixes'$availableFixes);
  65.     }
  66.     private function copyHtaccess(): void
  67.     {
  68.         $projectDirHtaccess $this->container->getParameter('kernel.project_dir'). '/.htaccess';
  69.         copy(__DIR__ '/../root_htaccess.dist'$projectDirHtaccess);
  70.         $knownFolders = [
  71.             $this->container->getParameter('kernel.project_dir'). '/bin',
  72.             $this->container->getParameter('kernel.project_dir'). '/config',
  73.             $this->container->getParameter('kernel.project_dir'). '/custom',
  74.             $this->container->getParameter('kernel.project_dir'). '/files',
  75.             $this->container->getParameter('kernel.project_dir'). '/src',
  76.             $this->container->getParameter('kernel.project_dir'). '/var',
  77.             $this->container->getParameter('kernel.project_dir'). '/vendor',
  78.         ];
  79.         foreach ($knownFolders as $knownFolder) {
  80.             if (file_exists($knownFolder)) {
  81.                 copy(__DIR__ '/../block_directory_access_htaccess.dist'$knownFolder '/.htaccess');
  82.             }
  83.         }
  84.         $shopwareVersion $_SERVER['SHOPWARE_FAKE_VERSION'] ?? $this->container->getParameter('kernel.shopware_version');
  85.         $updateService = new UpdateHtaccess();
  86.         // Only update the .htaccess if we are on a older shopware version
  87.         if (version_compare($shopwareVersion$updateService->getMaxVersion(), '<')) {
  88.             $publicHtaccess $this->container->getParameter('kernel.project_dir'). '/public/.htaccess';
  89.             $updateService->updateHtaccess($publicHtaccess__DIR__ '/../current_public_htaccess.dist');
  90.         }
  91.     }
  92. }