From 9ce7963efa279d053c019a8dff4b1550b29521e7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andre=CC=81=20R?= Date: Wed, 10 Jan 2018 17:00:37 +0100 Subject: [PATCH 1/4] [Feature] Add support for autloading via Composer --- autoload.php | 6 ++++++ composer.json | 14 ++++++++++++++ 2 files changed, 20 insertions(+) diff --git a/autoload.php b/autoload.php index 798870feb28..3647bb80ca8 100644 --- a/autoload.php +++ b/autoload.php @@ -19,6 +19,12 @@ require_once __DIR__ . '/config.php'; } +// If composer autoloaded context such as eZ Platform & legacy bridge, skip trying to autoload Zeta Components and such +if ( class_exists( 'Composer\Autoload\ClassLoader', false ) ) +{ + define( 'EZCBASE_ENABLED', false ); +} + if ( !defined( 'EZCBASE_ENABLED' ) ) { $defaultAppName = "app"; diff --git a/composer.json b/composer.json index 48d3f75d8ac..95d7f5df43c 100644 --- a/composer.json +++ b/composer.json @@ -63,6 +63,20 @@ "phpunit/phpunit": "3.7.*", "zetacomponents/php-generator": "~1.1" }, + "autoload": { + "files": ["autoload.php"] + }, + "scripts": { + "legacy-scripts": [ + "@php bin/php/ezpgenerateautoloads.php" + ], + "post-install-cmd": [ + "@legacy-scripts" + ], + "post-update-cmd": [ + "@legacy-scripts" + ] + }, "conflict": { "ezsystems/ezpublish-kernel": "<6.12 || >=2014.11 <2017.10" }, From 6b7f7f19f6703da9fae651038ee3657a448e8aff Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andre=CC=81=20R?= Date: Thu, 11 Jan 2018 10:27:32 +0100 Subject: [PATCH 2/4] Cleanup all pear and bundeld ezc code, not relevant anymore --- autoload.php | 51 +++++++------------------------- bin/php/ezpgenerateautoloads.php | 42 ++++---------------------- 2 files changed, 16 insertions(+), 77 deletions(-) diff --git a/autoload.php b/autoload.php index 3647bb80ca8..e3a429f5158 100644 --- a/autoload.php +++ b/autoload.php @@ -19,58 +19,27 @@ require_once __DIR__ . '/config.php'; } -// If composer autoloaded context such as eZ Platform & legacy bridge, skip trying to autoload Zeta Components and such -if ( class_exists( 'Composer\Autoload\ClassLoader', false ) ) -{ - define( 'EZCBASE_ENABLED', false ); -} - +// Check for EZCBASE_ENABLED, if set we can skip autoloading Zeta Components if ( !defined( 'EZCBASE_ENABLED' ) ) { - $defaultAppName = "app"; - if ( !file_exists( __DIR__ . "/../$defaultAppName" ) ) - { - $defaultAppName = "ezpublish"; - } - - $appName = defined( 'EZP_APP_FOLDER_NAME' ) ? EZP_APP_FOLDER_NAME : $defaultAppName; - $appFolder = __DIR__ . "/../$appName"; - $legacyVendorDir = __DIR__ . "/vendor"; - - // Bundled - if ( defined( 'EZP_USE_BUNDLED_COMPONENTS' ) ? EZP_USE_BUNDLED_COMPONENTS === true : file_exists( __DIR__ . "/lib/ezc" ) ) + // If composer autloader is already present we can skip trying to load it + if ( class_exists( 'Composer\Autoload\ClassLoader', false ) ) { - set_include_path( __DIR__ . PATH_SEPARATOR . __DIR__ . "/lib/ezc" . PATH_SEPARATOR . get_include_path() ); - require 'Base/src/base.php'; - $baseEnabled = true; - } - // Custom config.php defined - else if ( defined( 'EZC_BASE_PATH' ) ) - { - require EZC_BASE_PATH; - $baseEnabled = true; + $baseEnabled = false; } - // Composer if in eZ Publish5 context - else if ( strpos( $appFolder, "{$appName}/../{$appName}" ) === false && file_exists( "{$appFolder}/autoload.php" ) ) + // Composer if in eZ Platform context + else if ( file_exists( __DIR__ . "/../vendor/autoload.php" ) ) { - require_once "{$appFolder}/autoload.php"; + + require_once __DIR__ . "/../vendor/autoload.php"; $baseEnabled = false; } // Composer if in eZ Publish legacy context - else if ( file_exists( "{$legacyVendorDir}/autoload.php" ) ) + else if ( file_exists( __DIR__ . "/vendor/autoload.php" ) ) { - require_once "{$legacyVendorDir}/autoload.php"; + require_once __DIR__ . "/vendor/autoload.php"; $baseEnabled = false; } - // PEAR install - else - { - $baseEnabled = @include 'ezc/Base/base.php'; - if ( !$baseEnabled ) - { - $baseEnabled = @include 'Base/src/base.php'; - } - } define( 'EZCBASE_ENABLED', $baseEnabled ); } diff --git a/bin/php/ezpgenerateautoloads.php b/bin/php/ezpgenerateautoloads.php index 875c3038270..daf5c4858a9 100755 --- a/bin/php/ezpgenerateautoloads.php +++ b/bin/php/ezpgenerateautoloads.php @@ -16,52 +16,22 @@ // Setup, includes //{ -$defaultAppName = "app"; -if ( !file_exists( __DIR__ . "/../../../$defaultAppName" ) ) -{ - $defaultAppName = "ezpublish"; -} -$appName = defined( 'EZP_APP_FOLDER_NAME' ) ? EZP_APP_FOLDER_NAME : $defaultAppName; -$appFolder = getcwd() . "/../$appName"; +$platformVendorDir = getcwd() . "/../vendor"; $legacyVendorDir = getcwd() . "/vendor"; - -$baseEnabled = true; -// Bundled -if ( defined( 'EZP_USE_BUNDLED_COMPONENTS' ) ? EZP_USE_BUNDLED_COMPONENTS === true : file_exists( 'lib/ezc' ) ) +if ( class_exists( 'Composer\Autoload\ClassLoader', false ) ) { - set_include_path( './lib/ezc' . PATH_SEPARATOR . get_include_path() ); - require 'Base/src/base.php'; + // Do nothing, composer autoload already loaded } -// Custom config.php defined -else if ( defined( 'EZC_BASE_PATH' ) ) +// Composer if in eZ Platform context +else if ( file_exists( "{$platformVendorDir}/autoload.php" ) ) { - require EZC_BASE_PATH; -} -// Composer if in eZ Publish5 context -else if ( strpos( $appFolder, "{$appName}/../{$appName}" ) === false && file_exists( "{$appFolder}/autoload.php" ) ) -{ - require_once "{$appFolder}/autoload.php"; - $baseEnabled = false; + require_once "{$platformVendorDir}/autoload.php"; } // Composer if in eZ Publish legacy context else if ( file_exists( "{$legacyVendorDir}/autoload.php" ) ) { require_once "{$legacyVendorDir}/autoload.php"; - $baseEnabled = false; -} -// PEAR -else -{ - if ( !@include 'ezc/Base/base.php' ) - { - require 'Base/src/base.php'; - } -} - -if ( $baseEnabled ) -{ - spl_autoload_register( array( 'ezcBase', 'autoload' ) ); } require 'kernel/private/classes/ezautoloadgenerator.php'; From 58ca3050a2cff5a943ffcadc9908346829e55b40 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9=20R?= Date: Fri, 12 Jan 2018 17:40:10 +0100 Subject: [PATCH 3/4] Update autoload.php --- autoload.php | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/autoload.php b/autoload.php index e3a429f5158..b387b271bc8 100644 --- a/autoload.php +++ b/autoload.php @@ -22,26 +22,24 @@ // Check for EZCBASE_ENABLED, if set we can skip autoloading Zeta Components if ( !defined( 'EZCBASE_ENABLED' ) ) { - // If composer autloader is already present we can skip trying to load it + // Start by setting EZCBASE_ENABLED to avoid recursion + define( 'EZCBASE_ENABLED', false ); + + // If composer autoloader is already present we can skip trying to load it if ( class_exists( 'Composer\Autoload\ClassLoader', false ) ) { - $baseEnabled = false; + // do nothing } // Composer if in eZ Platform context else if ( file_exists( __DIR__ . "/../vendor/autoload.php" ) ) { - require_once __DIR__ . "/../vendor/autoload.php"; - $baseEnabled = false; } // Composer if in eZ Publish legacy context else if ( file_exists( __DIR__ . "/vendor/autoload.php" ) ) { require_once __DIR__ . "/vendor/autoload.php"; - $baseEnabled = false; } - - define( 'EZCBASE_ENABLED', $baseEnabled ); } // Check if ezpAutoloader exists because it can be already declared if running in the Symfony context (e.g. CLI scripts) From ae734e95635353862f2fa98bc5e10c05eb281c21 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9=20R?= Date: Fri, 12 Jan 2018 17:44:57 +0100 Subject: [PATCH 4/4] Update config.php-RECOMMENDED --- config.php-RECOMMENDED | 40 ---------------------------------------- 1 file changed, 40 deletions(-) diff --git a/config.php-RECOMMENDED b/config.php-RECOMMENDED index d4070d20c04..3ec36cc1450 100644 --- a/config.php-RECOMMENDED +++ b/config.php-RECOMMENDED @@ -12,46 +12,6 @@ *uncomment* the proposed settings. */ - -/* - PATH TO THE EZCOMPONENTS - ------------------------ - config.php can set the components path like: -*/ -//ini_set( 'include_path', ini_get( 'include_path' ). PATH_SEPARATOR . '../ezcomponents/trunk' ); - -/* - USING COMPONENTS VIA COMPOSER - ----------------------------- - If installation is in a eZ Publish 5/Symfony context, composer will be attempted to be used - if the following file is found: '../EZP_APP_FOLDER_NAME/autoload.php' - Default EZP_APP_FOLDER_NAME value is "app" and this constant gives you possibility to change it. - In eZ Publish 5.x, default value of EZP_APP_FOLDER_NAME was "ezpublish". -*/ -//define( 'EZP_APP_FOLDER_NAME', 'my_app' ); - -/* - USING BUNDLED COMPONENTS - ------------------------ - If you are using a distribution of eZ Publish with which the necessary - eZ Components are bundled (in lib/ezc), then you can use this setting to - control if the bundled eZ Components should be used (true) or not (false). - By default, when this setting is not present and the bundled eZ Components are - present, they will be used. If you're using the bundled eZ Components it's recommended - to define EZP_USE_BUNDLED_COMPONENTS as a boolean true anyway, for optimal speed. -*/ -//define( 'EZP_USE_BUNDLED_COMPONENTS', true ); - - -/* - If you are not using the bundled eZ Components, then for optimal speed it is - recommended to set EZC_BASE_PATH to either ezc/Base/base.php or Base/src/base.php, - depending on how you installed the eZ Components. By default, if this setting - is not present, eZ Publish first tries to include ezc/Base/base.php in the standard - php include path. If that fails Base/src/base.php is included. -*/ -//define( 'EZC_BASE_PATH', '/usr/lib/ezc/Base/base.php' ); - /* TIMEZONES ---------