thefrosty/wordpress-mu-loader

将插件目录中的常规插件加载为“必须使用”插件,强制执行其活动,同时保持典型的更新流程。

安装次数: 4,010

依赖者: 0

推荐者: 0

安全性: 0

星标: 3

关注者: 2

分支: 0

开放问题: 0

类型:wordpress-muplugin

1.0.1 2023-01-27 20:11 UTC

This package is auto-updated.

Last update: 2024-09-27 23:28:55 UTC


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?
        }
    });
});