Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
trouvaille
/
wp-content
/
plugins
/
extendify
:
bootstrap.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php /** * Bootstrap the application */ defined('ABSPATH') || die('No direct access.'); use Extendify\AdminPageRouter; use Extendify\Assist\Admin as AssistAdmin; use Extendify\Agent\Admin as AgentAdmin; use Extendify\Config; use Extendify\Draft\Admin as DraftAdmin; use Extendify\HelpCenter\Admin as HelpCenterAdmin; use Extendify\Insights; use Extendify\Launch\Admin as LaunchAdmin; use Extendify\Library\Admin as LibraryAdmin; use Extendify\Library\Frontend as LibraryFrontend; use Extendify\PageCreator\Admin as PageCreatorAdmin; use Extendify\PartnerData; use Extendify\Recommendations\Admin as RecommendationsAdmin; use Extendify\Shared\Admin as SharedAdmin; use Extendify\Shared\DataProvider\ResourceData; use Extendify\Shared\Services\Import\ImagesImporter; use Extendify\Shared\Services\VersionMigrator; if (!defined('EXTENDIFY_REQUIRED_CAPABILITY')) { define('EXTENDIFY_REQUIRED_CAPABILITY', 'manage_options'); } if (!defined('EXTENDIFY_PATH')) { define('EXTENDIFY_PATH', \plugin_dir_path(__FILE__)); } if (!defined('EXTENDIFY_URL')) { define('EXTENDIFY_URL', \plugin_dir_url(__FILE__)); } if (!defined('EXTENDIFY_PLUGIN_BASENAME')) { define('EXTENDIFY_PLUGIN_BASENAME', \plugin_basename(__DIR__ . '/extendify.php')); } if (is_readable(EXTENDIFY_PATH . 'vendor/autoload.php')) { require EXTENDIFY_PATH . 'vendor/autoload.php'; } if (!defined('EXTENDIFY_IS_THEME_EXTENDABLE')) { define('EXTENDIFY_IS_THEME_EXTENDABLE', get_option('stylesheet') === 'extendable'); } // This file should have no dependencies and always load. new LibraryFrontend(); // This file hooks into an external task and should always load. new Insights(); // This class set up the image import check scheduler. new ImagesImporter(); // Run various database updates depending on the plugin version. new VersionMigrator(); // This class will fetch and cache partner data to be used // throughout every class below. If opt in. new PartnerData(); // Set up scheduled cache (if opt-in and active). if (!PartnerData::setting('deactivated')) { ResourceData::scheduleCache(); } if (current_user_can(EXTENDIFY_REQUIRED_CAPABILITY)) { // The config class will collect information about the // partner and plugin, so it's easier to access. new Config(); if (!defined('EXTENDIFY_DEVMODE')) { define('EXTENDIFY_DEVMODE', Config::$environment === 'DEVELOPMENT'); } // This is a global "loader" class that loads in any assets that are shared everywhere. new SharedAdmin(); // This class will handle loading library assets. new LibraryAdmin(); // Only load these if the partner ID is set. These are all opt-in features. if ((Config::$partnerId || constant('EXTENDIFY_DEVMODE')) && !PartnerData::setting('deactivated')) { // This class handles the admin pages required for the plugin. new AdminPageRouter(); // This class will handle loading page creator assets. if (PartnerData::setting('showAIPageCreation') || constant('EXTENDIFY_DEVMODE')) { new PageCreatorAdmin(); } // The remaining classes handle loading assets for each individual products. // They are essentially asset loading classes. // phpcs:ignore WordPress.Security.NonceVerification.Recommended if (isset($_GET['page']) && $_GET['page'] === 'extendify-assist') { // Load only on Assist. new AssistAdmin(); } // Don't load on Launch. // phpcs:ignore WordPress.Security.NonceVerification.Recommended if (!isset($_GET['page']) || $_GET['page'] !== 'extendify-launch') { $extendifyShowAgent = constant('EXTENDIFY_IS_THEME_EXTENDABLE') && Config::$launchCompleted && (PartnerData::setting('showAIAgents') || Config::preview('ai-agent')); if (!$extendifyShowAgent) { new HelpCenterAdmin(); } if (PartnerData::setting('showProductRecommendations') || constant('EXTENDIFY_DEVMODE')) { new RecommendationsAdmin(); } if (PartnerData::setting('showDraft') || constant('EXTENDIFY_DEVMODE')) { new DraftAdmin(); } if ($extendifyShowAgent || constant('EXTENDIFY_DEVMODE')) { new AgentAdmin(); } } else { new LaunchAdmin(); } }//end if // This loads in all the REST API routes used by the plugin. require EXTENDIFY_PATH . 'routes/api.php'; }//end if // This file is used to update the plugin and removed before w.org release. if (is_readable(EXTENDIFY_PATH . '/updater.php')) { require EXTENDIFY_PATH . 'updater.php'; } add_action('init', function () { load_plugin_textdomain('extendify-local', false, dirname(plugin_basename(__FILE__)) . '/languages/php'); }); // phpcs:ignore Generic.CodeAnalysis.UnusedFunctionParameter add_filter('load_script_translation_file', function ($file, $handle, $domain) { if ($domain !== 'extendify-local') { return $file; } return extendifyResolveFallbackLocaleFile($file); }, 10, 3); add_filter('load_textdomain_mofile', function ($mofile, $domain) { if ($domain !== 'extendify-local') { return $mofile; } return extendifyResolveFallbackLocaleFile($mofile); }, 10, 2); /** * Resolves a fallback translation file path if the requested locale is unsupported. * * This function checks if the current file path includes an unsupported locale * and replaces it with a supported fallback (e.g. es_AR → es_ES), * as long as the fallback file exists on disk. * * @param string $filepath The original .mo or .json translation file path. * @return string The fallback file path if it exists, or the original one. */ function extendifyResolveFallbackLocaleFile($filepath) { if (str_contains($filepath, '-es_') && !file_exists($filepath)) { $fallbackFile = preg_replace('/-es_[A-Z]{2}/', '-es_ES', $filepath); if ($fallbackFile && file_exists($fallbackFile)) { return $fallbackFile; } } return $filepath; } // To cover legacy conflicts. // phpcs:ignore class ExtendifySdk { }