You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
add bedrock-autoloader.php to mu-plugins directory
<?php/** * Plugin Name: Bedrock Autoloader * Plugin URI: https://github.com/roots/bedrock/ * Description: An autoloader that enables standard plugins to be required just like must-use plugins. The autoloaded plugins are included during mu-plugin loading. An asterisk (*) next to the name of the plugin designates the plugins that have been autoloaded. * Version: 1.0.0 * Author: Roots * Author URI: https://roots.io/ * License: MIT License */namespaceRoots\Bedrock;
if (!is_blog_installed()) {
return;
}
/** * Class Autoloader * @package Roots\Bedrock * @author Roots * @link https://roots.io/ */class Autoloader
{
/** @var static Singleton instance */privatestatic$instance;
/** @var array Store Autoloader cache and site option */private$cache;
/** @var array Autoloaded plugins */private$autoPlugins;
/** @var array Autoloaded mu-plugins */private$muPlugins;
/** @var int Number of plugins */private$count;
/** @var array Newly activated plugins */private$activated;
/** @var string Relative path to the mu-plugins dir */private$relativePath;
/** * Create singleton, populate vars, and set WordPress hooks */publicfunction__construct()
{
if (isset(self::$instance)) {
return;
}
self::$instance = $this;
$this->relativePath = '/../' . basename(__DIR__);
if (is_admin()) {
add_filter('show_advanced_plugins', [$this, 'showInAdmin'], 0, 2);
}
$this->loadPlugins();
}
/** * Run some checks then autoload our plugins. */publicfunctionloadPlugins()
{
$this->checkCache();
$this->validatePlugins();
$this->countPlugins();
array_map(staticfunction () {
include_onceWPMU_PLUGIN_DIR . '/' . func_get_args()[0];
}, array_keys($this->cache['plugins']));
$this->pluginHooks();
}
/** * Filter show_advanced_plugins to display the autoloaded plugins. * @param $show bool Whether to show the advanced plugins for the specified plugin type. * @param $type string The plugin type, i.e., `mustuse` or `dropins` * @return bool We return `false` to prevent WordPress from overriding our work * {@internal We add the plugin details ourselves, so we return false to disable the filter.} */publicfunctionshowInAdmin($show, $type)
{
$screen = get_current_screen();
$current = is_multisite() ? 'plugins-network' : 'plugins';
if ($screen->base !== $current || $type !== 'mustuse' || !current_user_can('activate_plugins')) {
return$show;
}
$this->updateCache();
$this->autoPlugins = array_map(function ($auto_plugin) {
$auto_plugin['Name'] .= ' *';
return$auto_plugin;
}, $this->autoPlugins);
$GLOBALS['plugins']['mustuse'] = array_unique(array_merge($this->autoPlugins, $this->muPlugins), SORT_REGULAR);
returnfalse;
}
/** * This sets the cache or calls for an update */privatefunctioncheckCache()
{
$cache = get_site_option('bedrock_autoloader');
if ($cache === false || (isset($cache['plugins'], $cache['count']) && count($cache['plugins']) !== $cache['count'])) {
$this->updateCache();
return;
}
$this->cache = $cache;
}
/** * Get the plugins and mu-plugins from the mu-plugin path and remove duplicates. * Check cache against current plugins for newly activated plugins. * After that, we can update the cache. */privatefunctionupdateCache()
{
require_onceABSPATH . 'wp-admin/includes/plugin.php';
$this->autoPlugins = get_plugins($this->relativePath);
$this->muPlugins = get_mu_plugins();
$plugins = array_diff_key($this->autoPlugins, $this->muPlugins);
$rebuild = !is_array($this->cache['plugins']);
$this->activated = $rebuild ? $plugins : array_diff_key($plugins, $this->cache['plugins']);
$this->cache = ['plugins' => $plugins, 'count' => $this->countPlugins()];
update_site_option('bedrock_autoloader', $this->cache);
}
/** * This accounts for the plugin hooks that would run if the plugins were * loaded as usual. Plugins are removed by deletion, so there's no way * to deactivate or uninstall. */privatefunctionpluginHooks()
{
if (!is_array($this->activated)) {
return;
}
foreach ($this->activatedas$plugin_file => $plugin_info) {
do_action('activate_' . $plugin_file);
}
}
/** * Check that the plugin file exists, if it doesn't update the cache. */privatefunctionvalidatePlugins()
{
foreach ($this->cache['plugins'] as$plugin_file => $plugin_info) {
if (!file_exists(WPMU_PLUGIN_DIR . '/' . $plugin_file)) {
$this->updateCache();
break;
}
}
}
/** * Count the number of autoloaded plugins. * * Count our plugins (but only once) by counting the top level folders in the * mu-plugins dir. If it's more or less than last time, update the cache. * * @return int Number of autoloaded plugins. */privatefunctioncountPlugins()
{
if (isset($this->count)) {
return$this->count;
}
$count = count(glob(WPMU_PLUGIN_DIR . '/*/', GLOB_ONLYDIR | GLOB_NOSORT));
if (!isset($this->cache['count']) || $count !== $this->cache['count']) {
$this->count = $count;
$this->updateCache();
}
return$this->count;
}
}
newAutoloader();
The text was updated successfully, but these errors were encountered:
add
bedrock-autoloader.php
tomu-plugins
directoryThe text was updated successfully, but these errors were encountered: