admin-templates
1 year ago
base
4 months ago
controls
4 months ago
editor-templates
2 months ago
elements
4 months ago
interfaces
1 year ago
libraries
1 year ago
managers
2 months ago
settings
2 months ago
template-library
2 months ago
widgets
2 months ago
api.php
8 months ago
autoloader.php
7 months ago
beta-testers.php
3 years ago
compatibility.php
1 year ago
conditions.php
3 years ago
db.php
4 months ago
editor-assets-api.php
2 months ago
embed.php
1 year ago
fonts.php
1 year ago
frontend.php
2 months ago
heartbeat.php
3 years ago
maintenance-mode.php
7 months ago
maintenance.php
1 year ago
plugin.php
3 months ago
preview.php
7 months ago
rollback.php
4 months ago
shapes.php
9 months ago
stylesheet.php
8 months ago
tracker.php
6 months ago
user-data.php
7 months ago
user.php
5 months ago
utils.php
2 months ago
autoloader.php
346 lines
| 1 | <?php |
| 2 | namespace Elementor; |
| 3 | |
| 4 | if ( ! defined( 'ABSPATH' ) ) { |
| 5 | exit; // Exit if accessed directly. |
| 6 | } |
| 7 | |
| 8 | /** |
| 9 | * Elementor autoloader. |
| 10 | * |
| 11 | * Elementor autoloader handler class is responsible for loading the different |
| 12 | * classes needed to run the plugin. |
| 13 | * |
| 14 | * @since 1.6.0 |
| 15 | */ |
| 16 | class Autoloader { |
| 17 | |
| 18 | /** |
| 19 | * Classes map. |
| 20 | * |
| 21 | * Maps Elementor classes to file names. |
| 22 | * |
| 23 | * @since 1.6.0 |
| 24 | * @access private |
| 25 | * @static |
| 26 | * |
| 27 | * @var array Classes used by elementor. |
| 28 | */ |
| 29 | private static $classes_map; |
| 30 | |
| 31 | /** |
| 32 | * Classes aliases. |
| 33 | * |
| 34 | * Maps Elementor classes to aliases. |
| 35 | * |
| 36 | * @since 1.6.0 |
| 37 | * @access private |
| 38 | * @static |
| 39 | * |
| 40 | * @var array Classes aliases. |
| 41 | */ |
| 42 | private static $classes_aliases; |
| 43 | |
| 44 | /** |
| 45 | * Default path for autoloader. |
| 46 | * |
| 47 | * @var string |
| 48 | */ |
| 49 | private static $default_path; |
| 50 | |
| 51 | /** |
| 52 | * Default namespace for autoloader. |
| 53 | * |
| 54 | * @var string |
| 55 | */ |
| 56 | private static $default_namespace; |
| 57 | |
| 58 | /** |
| 59 | * Run autoloader. |
| 60 | * |
| 61 | * Register a function as `__autoload()` implementation. |
| 62 | * |
| 63 | * @param string $default_path |
| 64 | * @param string $default_namespace |
| 65 | * |
| 66 | * @since 1.6.0 |
| 67 | * @access public |
| 68 | * @static |
| 69 | */ |
| 70 | public static function run( $default_path = '', $default_namespace = '' ) { |
| 71 | if ( '' === $default_path ) { |
| 72 | $default_path = ELEMENTOR_PATH; |
| 73 | } |
| 74 | |
| 75 | if ( '' === $default_namespace ) { |
| 76 | $default_namespace = __NAMESPACE__; |
| 77 | } |
| 78 | |
| 79 | self::$default_path = $default_path; |
| 80 | self::$default_namespace = $default_namespace; |
| 81 | |
| 82 | spl_autoload_register( [ __CLASS__, 'autoload' ] ); |
| 83 | } |
| 84 | |
| 85 | /** |
| 86 | * Get classes aliases. |
| 87 | * |
| 88 | * Retrieve the classes aliases names. |
| 89 | * |
| 90 | * @since 1.6.0 |
| 91 | * @access public |
| 92 | * @static |
| 93 | * |
| 94 | * @return array Classes aliases. |
| 95 | */ |
| 96 | public static function get_classes_aliases() { |
| 97 | if ( ! self::$classes_aliases ) { |
| 98 | self::init_classes_aliases(); |
| 99 | } |
| 100 | |
| 101 | return self::$classes_aliases; |
| 102 | } |
| 103 | |
| 104 | public static function get_classes_map() { |
| 105 | if ( ! self::$classes_map ) { |
| 106 | self::init_classes_map(); |
| 107 | } |
| 108 | |
| 109 | return self::$classes_map; |
| 110 | } |
| 111 | |
| 112 | private static function init_classes_map() { |
| 113 | self::$classes_map = [ |
| 114 | 'Api' => 'includes/api.php', |
| 115 | 'Base_Control' => 'includes/controls/base.php', |
| 116 | 'Base_Data_Control' => 'includes/controls/base-data.php', |
| 117 | 'Base_UI_Control' => 'includes/controls/base-ui.php', |
| 118 | 'Beta_Testers' => 'includes/beta-testers.php', |
| 119 | 'Compatibility' => 'includes/compatibility.php', |
| 120 | 'Conditions' => 'includes/conditions.php', |
| 121 | 'Controls_Manager' => 'includes/managers/controls.php', |
| 122 | 'Controls_Stack' => 'includes/base/controls-stack.php', |
| 123 | 'Sub_Controls_Stack' => 'includes/base/sub-controls-stack.php', |
| 124 | 'DB' => 'includes/db.php', |
| 125 | 'Elements_Manager' => 'includes/managers/elements.php', |
| 126 | 'Embed' => 'includes/embed.php', |
| 127 | 'Fonts' => 'includes/fonts.php', |
| 128 | 'Frontend' => 'includes/frontend.php', |
| 129 | 'Group_Control_Base' => 'includes/controls/groups/base.php', |
| 130 | 'Group_Control_Interface' => 'includes/interfaces/group-control.php', |
| 131 | 'Has_Validation' => 'includes/interfaces/has-validation.php', |
| 132 | 'Heartbeat' => 'includes/heartbeat.php', |
| 133 | 'Images_Manager' => 'includes/managers/image.php', |
| 134 | 'Maintenance' => 'includes/maintenance.php', |
| 135 | 'Maintenance_Mode' => 'includes/maintenance-mode.php', |
| 136 | 'Preview' => 'includes/preview.php', |
| 137 | 'Rollback' => 'includes/rollback.php', |
| 138 | 'Settings' => 'includes/settings/settings.php', |
| 139 | 'Settings_Controls' => 'includes/settings/controls.php', |
| 140 | 'Settings_Validations' => 'includes/settings/validations.php', |
| 141 | 'Settings_Page' => 'includes/settings/settings-page.php', |
| 142 | 'Shapes' => 'includes/shapes.php', |
| 143 | 'Skins_Manager' => 'includes/managers/skins.php', |
| 144 | 'Icons_Manager' => 'includes/managers/icons.php', |
| 145 | 'Stylesheet' => 'includes/stylesheet.php', |
| 146 | 'System_Info\Main' => 'includes/settings/system-info/main.php', |
| 147 | 'TemplateLibrary\Classes\Import_Images' => 'includes/template-library/classes/class-import-images.php', |
| 148 | 'TemplateLibrary\Classes\Media_Collector' => 'includes/template-library/classes/class-media-collector.php', |
| 149 | 'TemplateLibrary\Classes\Media_Mapper' => 'includes/template-library/classes/class-media-mapper.php', |
| 150 | 'TemplateLibrary\Forms\New_Template_Form' => 'includes/template-library/forms/new-template-form.php', |
| 151 | 'TemplateLibrary\Manager' => 'includes/template-library/manager.php', |
| 152 | 'TemplateLibrary\Source_Base' => 'includes/template-library/sources/base.php', |
| 153 | 'TemplateLibrary\Source_Local' => 'includes/template-library/sources/local.php', |
| 154 | 'TemplateLibrary\Source_Remote' => 'includes/template-library/sources/remote.php', |
| 155 | 'TemplateLibrary\Source_Cloud' => 'includes/template-library/sources/cloud.php', |
| 156 | 'Tools' => 'includes/settings/tools.php', |
| 157 | 'Container\Container' => 'includes/container/container.php', |
| 158 | 'Tracker' => 'includes/tracker.php', |
| 159 | 'User' => 'includes/user.php', |
| 160 | 'User_Data' => 'includes/user-data.php', |
| 161 | 'Utils' => 'includes/utils.php', |
| 162 | 'Widget_WordPress' => 'includes/widgets/wordpress.php', |
| 163 | 'Widgets_Manager' => 'includes/managers/widgets.php', |
| 164 | 'WordPress_Widgets_Manager' => 'includes/managers/wordpress-widgets.php', |
| 165 | ]; |
| 166 | |
| 167 | $controls_names = Controls_Manager::get_controls_names(); |
| 168 | |
| 169 | $controls_names = array_merge( $controls_names, [ |
| 170 | 'base_multiple', |
| 171 | 'base_units', |
| 172 | ] ); |
| 173 | |
| 174 | foreach ( $controls_names as $control_name ) { |
| 175 | $class_name = 'Control_' . self::normalize_class_name( $control_name, '_' ); |
| 176 | |
| 177 | self::$classes_map[ $class_name ] = 'includes/controls/' . str_replace( '_', '-', $control_name ) . '.php'; |
| 178 | } |
| 179 | |
| 180 | $controls_groups_names = Controls_Manager::get_groups_names(); |
| 181 | |
| 182 | foreach ( $controls_groups_names as $group_name ) { |
| 183 | $class_name = 'Group_Control_' . self::normalize_class_name( $group_name, '_' ); |
| 184 | |
| 185 | self::$classes_map[ $class_name ] = 'includes/controls/groups/' . $group_name . '.php'; |
| 186 | } |
| 187 | } |
| 188 | |
| 189 | /** |
| 190 | * Normalize Class Name |
| 191 | * |
| 192 | * Used to convert control names to class names. |
| 193 | * |
| 194 | * @param string $class_name |
| 195 | * @param string $delimiter |
| 196 | * |
| 197 | * @return mixed |
| 198 | */ |
| 199 | private static function normalize_class_name( $class_name, $delimiter = ' ' ) { |
| 200 | return ucwords( str_replace( '-', '_', $class_name ), $delimiter ); |
| 201 | } |
| 202 | |
| 203 | /** |
| 204 | * Init classes aliases. |
| 205 | * |
| 206 | * When Elementor classes renamed or moved to different folders, developers |
| 207 | * can still use the old names by setting an alias. |
| 208 | * |
| 209 | * While in deprecation period both classes will work. When the deprecation |
| 210 | * period ends, the alies should be removed from the list of aliases. |
| 211 | * |
| 212 | * Usage: |
| 213 | * |
| 214 | * self::$classes_aliases = [ |
| 215 | * 'Namespace\OldClassName' => [ |
| 216 | * 'replacement' => 'Namespace\NewClassName', |
| 217 | * 'version' => '3.0.0', |
| 218 | * ], |
| 219 | * 'Namespace\OldModule\ClassName' => [ |
| 220 | * 'replacement' => 'Namespace\NewModule\ClassName', |
| 221 | * 'version' => '3.5.0', |
| 222 | * ], |
| 223 | * ]; |
| 224 | * |
| 225 | * @access private |
| 226 | * @static |
| 227 | * |
| 228 | * @return void |
| 229 | */ |
| 230 | private static function init_classes_aliases() { |
| 231 | self::$classes_aliases = [ |
| 232 | 'System_Info\Main' => [ |
| 233 | 'replacement' => 'Modules\System_Info\Module', |
| 234 | 'version' => '2.9.0', |
| 235 | ], |
| 236 | 'System_Info\Classes\Abstracts\Base_Reporter' => [ |
| 237 | 'replacement' => 'Modules\System_Info\Reporters\Base', |
| 238 | 'version' => '2.9.0', |
| 239 | ], |
| 240 | 'System_Info\Classes\Server_Reporter' => [ |
| 241 | 'replacement' => 'Modules\System_Info\Reporters\Server', |
| 242 | 'version' => '2.9.0', |
| 243 | ], |
| 244 | 'System_Info\Classes\MU_Plugins_Reporter' => [ |
| 245 | 'replacement' => 'Modules\System_Info\Reporters\MU_Plugins', |
| 246 | 'version' => '2.9.0', |
| 247 | ], |
| 248 | 'System_Info\Classes\Network_Plugins_Reporter' => [ |
| 249 | 'replacement' => 'Modules\System_Info\Reporters\Network_Plugins', |
| 250 | 'version' => '2.9.0', |
| 251 | ], |
| 252 | 'System_Info\Classes\Plugins_Reporter' => [ |
| 253 | 'replacement' => 'Modules\System_Info\Reporters\Plugins', |
| 254 | 'version' => '2.9.0', |
| 255 | ], |
| 256 | 'System_Info\Classes\Theme_Reporter' => [ |
| 257 | 'replacement' => 'Modules\System_Info\Reporters\Theme', |
| 258 | 'version' => '2.9.0', |
| 259 | ], |
| 260 | 'System_Info\Classes\User_Reporter' => [ |
| 261 | 'replacement' => 'Modules\System_Info\Reporters\User', |
| 262 | 'version' => '2.9.0', |
| 263 | ], |
| 264 | 'System_Info\Helpers\Model_Helper' => [ |
| 265 | 'replacement' => 'Modules\System_Info\Helpers\Model_Helper', |
| 266 | 'version' => '2.9.0', |
| 267 | ], |
| 268 | ]; |
| 269 | } |
| 270 | |
| 271 | /** |
| 272 | * Load class. |
| 273 | * |
| 274 | * For a given class name, require the class file. |
| 275 | * |
| 276 | * @since 1.6.0 |
| 277 | * @access private |
| 278 | * @static |
| 279 | * |
| 280 | * @param string $relative_class_name Class name. |
| 281 | */ |
| 282 | private static function load_class( $relative_class_name ) { |
| 283 | $classes_map = self::get_classes_map(); |
| 284 | |
| 285 | if ( isset( $classes_map[ $relative_class_name ] ) ) { |
| 286 | $filename = self::$default_path . '/' . $classes_map[ $relative_class_name ]; |
| 287 | } else { |
| 288 | $filename = strtolower( |
| 289 | preg_replace( |
| 290 | [ '/([a-z])([A-Z])/', '/_/', '/\\\/' ], |
| 291 | [ '$1-$2', '-', DIRECTORY_SEPARATOR ], |
| 292 | $relative_class_name |
| 293 | ) |
| 294 | ); |
| 295 | |
| 296 | $filename = self::$default_path . $filename . '.php'; |
| 297 | } |
| 298 | |
| 299 | if ( is_readable( $filename ) ) { |
| 300 | require $filename; |
| 301 | } |
| 302 | } |
| 303 | |
| 304 | /** |
| 305 | * Autoload. |
| 306 | * |
| 307 | * For a given class, check if it exist and load it. |
| 308 | * |
| 309 | * @since 1.6.0 |
| 310 | * @access private |
| 311 | * @static |
| 312 | * |
| 313 | * @param string $class_name Class name. |
| 314 | */ |
| 315 | private static function autoload( $class_name ) { |
| 316 | if ( 0 !== strpos( $class_name, self::$default_namespace . '\\' ) ) { |
| 317 | return; |
| 318 | } |
| 319 | |
| 320 | $relative_class_name = preg_replace( '/^' . self::$default_namespace . '\\\/', '', $class_name ); |
| 321 | |
| 322 | $classes_aliases = self::get_classes_aliases(); |
| 323 | |
| 324 | $has_class_alias = isset( $classes_aliases[ $relative_class_name ] ); |
| 325 | |
| 326 | // Backward Compatibility: Save old class name for set an alias after the new class is loaded. |
| 327 | if ( $has_class_alias ) { |
| 328 | $alias_data = $classes_aliases[ $relative_class_name ]; |
| 329 | |
| 330 | $relative_class_name = $alias_data['replacement']; |
| 331 | } |
| 332 | |
| 333 | $final_class_name = self::$default_namespace . '\\' . $relative_class_name; |
| 334 | |
| 335 | if ( ! class_exists( $final_class_name ) ) { |
| 336 | self::load_class( $relative_class_name ); |
| 337 | } |
| 338 | |
| 339 | if ( $has_class_alias ) { |
| 340 | class_alias( $final_class_name, $class_name ); |
| 341 | |
| 342 | Utils::handle_deprecation( $class_name, $alias_data['version'], $final_class_name ); |
| 343 | } |
| 344 | } |
| 345 | } |
| 346 |