thefrosty / wordpress-mu-loader
将插件目录中的常规插件加载为“必须使用”插件,强制执行其活动,同时保持典型的更新流程。
1.0.1
2023-01-27 20:11 UTC
Requires
- php: ^7.4 || ^8.0
Suggests
- roots/bedrock-autoloader: Bedrock Autoloader will autoload plugin from the directory when in `mu-plugins/.
README
安装
composer require thefosty/wordpress-mu-loader:^1.0
将插件目录中的常规插件作为“必须使用”插件加载,强制执行其活动,同时保持典型的更新流程。此文件将负责所有必要的逻辑,包括防止这些插件的常规激活/停用/删除。
优势
- 强制插件在整个安装过程中保持活跃。
- 继续接收自动更新通知。
- 能够在WordPress仪表板中轻松更新这些插件。
- 插件激活、停用和卸载程序按常规执行。
要求
- WordPress >= 5.0
- PHP >= 7.4
使用方法
- 您可以将要加载为MU插件的插件的基名作为数组传递给
wp_plugin_mu_loader()
函数的构造函数调用。 - 插件基名由插件目录名、尾随斜杠和插件主文件名组成,例如 wordpress-seo/wp-seo.php、jetpack/jetpack.php 或 woocommerce/woocommerce.php。
- 或者,如果您不想修改函数本身的代码,您也可以从外部访问加载器:通过wp_plugin_mu_loader()检索实例,然后调用其load_plugin()方法,向其传递单个插件基名字符串。
示例
wp_plugin_mu_loader()->loadPlugin( 'wordpress-seo/wp-seo.php' );
或者,创建一个由git管理的mu-plugin
<?php declare(strict_types=1); /** * @wordpress-muplugin * Plugin Name: WordPress Plugins as Must-use * Description: Require regular WordPress plugins as "must-use" plugins. * Version: 1.0.0 * Author: Austin Passy * Author URI: https://github.com/thefrosty */ namespace TheFrosty; /** * Returns an array of basename formatted plugins to set as "must-use". * @return array */ function getRequiredPlugins(): array { // Add plugins to the array here... return \array_filter([ 'disable-emojis/disable-emojis.php', 'soil/soil.php', 'stream/stream.php', ]); } \add_action('muplugins_loaded', function () { $plugins = getRequiredPlugins(); \array_walk($plugins, function (string $plugin_basename) { try { if (!\function_exists('wp_plugin_mu_loader') && // You only need the file_exists/require is not using autoloading... \file_exists(WPMU_PLUGIN_DIR . '/wordpress-mu-loader/wp-plugin-mu-loader.php') ) { require_once WPMU_PLUGIN_DIR . '/wordpress-mu-loader/wp-plugin-mu-loader.php'; } \wp_plugin_mu_loader()->loadPlugin($plugin_basename); } catch (\InvalidArgumentException | \RuntimeException $exception) { // Log something here? } }); });