Skip to content

Commit

Permalink
feat(shopware/core): update kernel creation
Browse files Browse the repository at this point in the history
  • Loading branch information
shyim committed Nov 22, 2023
1 parent 7f2978b commit 6c44a06
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 53 deletions.
5 changes: 1 addition & 4 deletions shopware/core/6.6/bin/ci
Original file line number Diff line number Diff line change
Expand Up @@ -35,10 +35,7 @@ return static function (array &$context) {
$context['INSTALL'] = true;
}

if (trim($context['DATABASE_URL'] ?? '') === '') {
// fake DATABASE_URL
$_SERVER['DATABASE_URL'] = 'mysql://_placeholder.test';
}
$_SERVER['DATABASE_URL'] = 'mysql://_placeholder.test';

$kernel = new HttpKernel($env, $debug, $classLoader);
$kernel->setPluginLoader($pluginLoader);
Expand Down
22 changes: 13 additions & 9 deletions shopware/core/6.6/bin/console
Original file line number Diff line number Diff line change
@@ -1,13 +1,16 @@
#!/usr/bin/env php
<?php

use Shopware\Core\Framework\Adapter\Kernel\KernelFactory;
use Shopware\Core\Framework\Plugin\KernelPluginLoader\DbalKernelPluginLoader;
use Shopware\Core\Framework\Plugin\KernelPluginLoader\StaticKernelPluginLoader;
use Shopware\Core\HttpKernel;
use Shopware\Core\Kernel;
use Symfony\Bundle\FrameworkBundle\Console\Application;
use Symfony\Component\Console\Input\ArgvInput;

$envFile = __DIR__ . '/../.env';

if (!file_exists(__DIR__ . '/../.env') && !file_exists(__DIR__ . '/../.env.dist') && !file_exists(__DIR__ . '/../.env.local.php')) {
$_SERVER['APP_RUNTIME_OPTIONS']['disable_dotenv'] = true;
}
Expand Down Expand Up @@ -37,21 +40,22 @@ return static function (array &$context) {
$context['INSTALL'] = true;
}

if (trim($context['DATABASE_URL'] ?? '') === '') {
// fake DATABASE_URL
$_SERVER['DATABASE_URL'] = 'mysql://_placeholder.test';
} else if (!isset($context['INSTALL'])) {
if (trim($context['DATABASE_URL'] ?? '') !== '' && !isset($context['INSTALL'])) {
$pluginLoader = new DbalKernelPluginLoader($classLoader, null, \Shopware\Core\Kernel::getConnection());
}

$kernel = new HttpKernel($env, $debug, $classLoader);
$kernel->setPluginLoader($pluginLoader);
$kernel = KernelFactory::create(
environment: $env,
debug: $debug,
classLoader: $classLoader,
pluginLoader: $pluginLoader
);

$application = new Application($kernel->getKernel());
$kernel->getKernel()->boot();
$application = new Application($kernel);
$kernel->boot();

$application->setName('Shopware');
$application->setVersion($kernel->getKernel()->getContainer()->getParameter('kernel.shopware_version'));
$application->setVersion($kernel->getContainer()->getParameter('kernel.shopware_version'));

return $application;
};
49 changes: 9 additions & 40 deletions shopware/core/6.6/public/index.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,9 @@

use Shopware\Core\DevOps\Environment\EnvironmentHelper;
use Shopware\Core\Framework\Plugin\KernelPluginLoader\ComposerPluginLoader;
use Shopware\Core\HttpKernel;
use Shopware\Core\Installer\InstallerKernel;
use Symfony\Component\HttpFoundation\Request;
use Shopware\Core\Framework\Adapter\Kernel\KernelFactory;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpKernel\HttpKernelInterface;
use Symfony\Component\HttpKernel\TerminableInterface;

$_SERVER['SCRIPT_FILENAME'] = __FILE__;

Expand All @@ -33,48 +30,20 @@
$appEnv = $context['APP_ENV'] ?? 'dev';
$debug = (bool) ($context['APP_DEBUG'] ?? ($appEnv !== 'prod'));

$trustedProxies = $context['TRUSTED_PROXIES'] ?? false;
if ($trustedProxies) {
Request::setTrustedProxies(
explode(',', $trustedProxies),
Request::HEADER_X_FORWARDED_FOR | Request::HEADER_X_FORWARDED_PORT | Request::HEADER_X_FORWARDED_PROTO
);
}

$trustedHosts = $context['TRUSTED_HOSTS'] ?? false;
if ($trustedHosts) {
Request::setTrustedHosts(explode(',', $trustedHosts));
}

if (!EnvironmentHelper::getVariable('SHOPWARE_SKIP_WEBINSTALLER', false) && !file_exists(dirname(__DIR__) . '/install.lock')) {
return new InstallerKernel($appEnv, $debug);
}

$shopwareHttpKernel = new HttpKernel($appEnv, $debug, $classLoader);
$pluginLoader = null;

if (EnvironmentHelper::getVariable('COMPOSER_PLUGIN_LOADER', false)) {
$shopwareHttpKernel->setPluginLoader(
new ComposerPluginLoader($classLoader, null)
);
$pluginLoader = new ComposerPluginLoader($classLoader, null);
}

return new class($shopwareHttpKernel) implements HttpKernelInterface, TerminableInterface {
private HttpKernel $httpKernel;

public function __construct(HttpKernel $httpKernel)
{
$this->httpKernel = $httpKernel;
}

public function handle(Request $request, int $type = self::MAIN_REQUEST, bool $catch = true): Response
{
return $this->httpKernel->handle($request, $type, $catch)->getResponse();
}

public function terminate(Request $request, Response $response): void
{
$this->httpKernel->terminate($request, $response);
}
};
return KernelFactory::create(
environment: $appEnv,
debug: $debug,
classLoader: $classLoader,
pluginLoader: $pluginLoader
);
};

0 comments on commit 6c44a06

Please sign in to comment.