Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/clone/wp-conte.../plugins/wordpres.../src/services/importin...
File: conflicting-plugins-service.php
<?php
[0] Fix | Delete
[1] Fix | Delete
namespace Yoast\WP\SEO\Services\Importing;
[2] Fix | Delete
[3] Fix | Delete
use Yoast\WP\SEO\Config\Conflicting_Plugins;
[4] Fix | Delete
[5] Fix | Delete
/**
[6] Fix | Delete
* Detects plugin conflicts.
[7] Fix | Delete
*/
[8] Fix | Delete
class Conflicting_Plugins_Service {
[9] Fix | Delete
[10] Fix | Delete
/**
[11] Fix | Delete
* Detects the conflicting plugins.
[12] Fix | Delete
*
[13] Fix | Delete
* @return array A list of all active conflicting plugins.
[14] Fix | Delete
*/
[15] Fix | Delete
public function detect_conflicting_plugins() {
[16] Fix | Delete
$all_active_plugins = $this->get_active_plugins();
[17] Fix | Delete
[18] Fix | Delete
// Search for active plugins.
[19] Fix | Delete
return $this->get_active_conflicting_plugins( $all_active_plugins );
[20] Fix | Delete
}
[21] Fix | Delete
[22] Fix | Delete
/**
[23] Fix | Delete
* Deactivates the specified plugin(s) if any, or the entire list of known conflicting plugins.
[24] Fix | Delete
*
[25] Fix | Delete
* @param string|array|false $plugins Optional. The plugin filename, or array of plugin filenames, to deactivate.
[26] Fix | Delete
*
[27] Fix | Delete
* @return void
[28] Fix | Delete
*/
[29] Fix | Delete
public function deactivate_conflicting_plugins( $plugins = false ) {
[30] Fix | Delete
// If no plugins are specified, deactivate any known conflicting plugins that are active.
[31] Fix | Delete
if ( ! $plugins ) {
[32] Fix | Delete
$plugins = $this->detect_conflicting_plugins();
[33] Fix | Delete
}
[34] Fix | Delete
[35] Fix | Delete
// In case of a single plugin, wrap it in an array.
[36] Fix | Delete
if ( \is_string( $plugins ) ) {
[37] Fix | Delete
$plugins = [ $plugins ];
[38] Fix | Delete
}
[39] Fix | Delete
[40] Fix | Delete
if ( ! \is_array( $plugins ) ) {
[41] Fix | Delete
return;
[42] Fix | Delete
}
[43] Fix | Delete
[44] Fix | Delete
// Deactivate all specified plugins across the network, while retaining their deactivation hook.
[45] Fix | Delete
\deactivate_plugins( $plugins );
[46] Fix | Delete
}
[47] Fix | Delete
[48] Fix | Delete
/**
[49] Fix | Delete
* Loop through the list of known conflicting plugins to check if one of the plugins is active.
[50] Fix | Delete
*
[51] Fix | Delete
* @param array $all_active_plugins All plugins loaded by WordPress.
[52] Fix | Delete
*
[53] Fix | Delete
* @return array The array of activated conflicting plugins.
[54] Fix | Delete
*/
[55] Fix | Delete
protected function get_active_conflicting_plugins( $all_active_plugins ) {
[56] Fix | Delete
$active_conflicting_plugins = [];
[57] Fix | Delete
[58] Fix | Delete
foreach ( Conflicting_Plugins::all_plugins() as $plugin ) {
[59] Fix | Delete
if ( \in_array( $plugin, $all_active_plugins, true ) ) {
[60] Fix | Delete
$active_conflicting_plugins[] = $plugin;
[61] Fix | Delete
}
[62] Fix | Delete
}
[63] Fix | Delete
[64] Fix | Delete
return $active_conflicting_plugins;
[65] Fix | Delete
}
[66] Fix | Delete
[67] Fix | Delete
/**
[68] Fix | Delete
* Get a list of all plugins active in the current WordPress instance.
[69] Fix | Delete
*
[70] Fix | Delete
* @return false|array The names of all active plugins.
[71] Fix | Delete
*/
[72] Fix | Delete
protected function get_active_plugins() {
[73] Fix | Delete
// Request a list of active plugins from WordPress.
[74] Fix | Delete
$all_active_plugins = \get_option( 'active_plugins' );
[75] Fix | Delete
[76] Fix | Delete
return $this->ignore_deactivating_plugin( $all_active_plugins );
[77] Fix | Delete
}
[78] Fix | Delete
[79] Fix | Delete
/**
[80] Fix | Delete
* While deactivating a plugin, we should ignore the plugin currently being deactivated.
[81] Fix | Delete
*
[82] Fix | Delete
* @param array $all_active_plugins All plugins currently loaded by WordPress.
[83] Fix | Delete
*
[84] Fix | Delete
* @return array The remaining active plugins.
[85] Fix | Delete
*/
[86] Fix | Delete
protected function ignore_deactivating_plugin( $all_active_plugins ) {
[87] Fix | Delete
// phpcs:ignore WordPress.Security.ValidatedSanitizedInput.InputNotSanitized -- Reason: We are strictly comparing only.
[88] Fix | Delete
if ( isset( $_GET['action'] ) && isset( $_GET['plugin'] ) && \is_string( $_GET['action'] ) && \is_string( $_GET['plugin'] ) && \wp_unslash( $_GET['action'] ) === 'deactivate' ) {
[89] Fix | Delete
$deactivated_plugin = \sanitize_text_field( \wp_unslash( $_GET['plugin'] ) );
[90] Fix | Delete
[91] Fix | Delete
\check_admin_referer( 'deactivate-plugin_' . $deactivated_plugin );
[92] Fix | Delete
[93] Fix | Delete
$key_to_remove = \array_search( $deactivated_plugin, $all_active_plugins, true );
[94] Fix | Delete
if ( $key_to_remove !== false ) {
[95] Fix | Delete
unset( $all_active_plugins[ $key_to_remove ] );
[96] Fix | Delete
}
[97] Fix | Delete
}
[98] Fix | Delete
[99] Fix | Delete
return $all_active_plugins;
[100] Fix | Delete
}
[101] Fix | Delete
}
[102] Fix | Delete
[103] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function