Version 1.4.0: Rename plugin and update text domain
This commit is contained in:
@ -2,6 +2,11 @@
|
|||||||
|
|
||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
|
## [1.4.0] - 2023-11-30
|
||||||
|
### Changed
|
||||||
|
- Updated plugin name and text domain
|
||||||
|
- Repository rename from plugin-reference-cleaner to fix-plugin-does-not-exist-notices
|
||||||
|
|
||||||
## [1.3.3] - 2023-10-05
|
## [1.3.3] - 2023-10-05
|
||||||
### Added
|
### Added
|
||||||
- "Click here to scroll" button to automatically find missing plugins
|
- "Click here to scroll" button to automatically find missing plugins
|
||||||
|
@ -104,6 +104,10 @@ The plugin works by:
|
|||||||
|
|
||||||
## Changelog
|
## Changelog
|
||||||
|
|
||||||
|
### 1.4.0
|
||||||
|
- Updated plugin name and text domain
|
||||||
|
- Repository rename from plugin-reference-cleaner to fix-plugin-does-not-exist-notices
|
||||||
|
|
||||||
### 1.3.3
|
### 1.3.3
|
||||||
* Improved notification placement next to WordPress error messages
|
* Improved notification placement next to WordPress error messages
|
||||||
* Added "Click here to scroll" button that automatically locates missing plugins
|
* Added "Click here to scroll" button that automatically locates missing plugins
|
||||||
|
4
build.sh
4
build.sh
@ -10,7 +10,7 @@ if [ -z "$1" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
VERSION=$1
|
VERSION=$1
|
||||||
PLUGIN_SLUG="plugin-reference-cleaner"
|
PLUGIN_SLUG="fix-plugin-does-not-exist-notices"
|
||||||
BUILD_DIR="build/$PLUGIN_SLUG"
|
BUILD_DIR="build/$PLUGIN_SLUG"
|
||||||
ZIP_FILE="${PLUGIN_SLUG}-${VERSION}.zip"
|
ZIP_FILE="${PLUGIN_SLUG}-${VERSION}.zip"
|
||||||
|
|
||||||
@ -20,7 +20,7 @@ mkdir -p $BUILD_DIR
|
|||||||
|
|
||||||
# Copy required files
|
# Copy required files
|
||||||
echo "Copying plugin files..."
|
echo "Copying plugin files..."
|
||||||
cp plugin-reference-cleaner.php $BUILD_DIR/
|
cp fix-plugin-does-not-exist-notices.php $BUILD_DIR/
|
||||||
cp readme.txt $BUILD_DIR/
|
cp readme.txt $BUILD_DIR/
|
||||||
cp LICENSE $BUILD_DIR/
|
cp LICENSE $BUILD_DIR/
|
||||||
cp README.md $BUILD_DIR/
|
cp README.md $BUILD_DIR/
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
* @wordpress-plugin
|
* @wordpress-plugin
|
||||||
* Plugin Name: Fix 'Plugin file does not exist.' Notices
|
* Plugin Name: Fix 'Plugin file does not exist.' Notices
|
||||||
* Description: Adds missing plugins to the plugins list with a "Remove Reference" link so you can clean up invalid plugin entries.
|
* Description: Adds missing plugins to the plugins list with a "Remove Reference" link so you can clean up invalid plugin entries.
|
||||||
* Version: 1.3.3
|
* Version: 1.4.0
|
||||||
* Author: Marcus Quinn
|
* Author: Marcus Quinn
|
||||||
* Author URI: https://www.wpallstars.com
|
* Author URI: https://www.wpallstars.com
|
||||||
* License: GPL-2.0+
|
* License: GPL-2.0+
|
||||||
@ -103,7 +103,7 @@ class Fix_Plugin_Does_Not_Exist_Notices {
|
|||||||
// Add our action
|
// Add our action
|
||||||
$nonce = wp_create_nonce('remove_plugin_reference_' . $plugin_file);
|
$nonce = wp_create_nonce('remove_plugin_reference_' . $plugin_file);
|
||||||
$remove_url = admin_url('plugins.php?action=remove_reference&plugin=' . urlencode($plugin_file) . '&_wpnonce=' . $nonce);
|
$remove_url = admin_url('plugins.php?action=remove_reference&plugin=' . urlencode($plugin_file) . '&_wpnonce=' . $nonce);
|
||||||
$actions['remove_reference'] = '<a href="' . esc_url($remove_url) . '" class="delete" aria-label="' . esc_attr__('Remove Reference', 'plugin-reference-cleaner') . '">Remove Reference</a>';
|
$actions['remove_reference'] = '<a href="' . esc_url($remove_url) . '" class="delete" aria-label="' . esc_attr__('Remove Reference', 'fix-plugin-does-not-exist-notices') . '">Remove Reference</a>';
|
||||||
}
|
}
|
||||||
|
|
||||||
return $actions;
|
return $actions;
|
||||||
@ -120,7 +120,7 @@ class Fix_Plugin_Does_Not_Exist_Notices {
|
|||||||
|
|
||||||
// Verify permissions
|
// Verify permissions
|
||||||
if (!current_user_can('activate_plugins')) {
|
if (!current_user_can('activate_plugins')) {
|
||||||
wp_die(__('You do not have sufficient permissions to perform this action.', 'plugin-reference-cleaner'));
|
wp_die(__('You do not have sufficient permissions to perform this action.', 'fix-plugin-does-not-exist-notices'));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the plugin file
|
// Get the plugin file
|
||||||
@ -231,7 +231,7 @@ class Fix_Plugin_Does_Not_Exist_Notices {
|
|||||||
ourNotice.className = 'prc-notice';
|
ourNotice.className = 'prc-notice';
|
||||||
|
|
||||||
// Add content
|
// Add content
|
||||||
ourNotice.innerHTML = '<h3 style="margin-top:0;color:#826200;">👉 Plugin Reference Cleaner Can Fix This</h3>' +
|
ourNotice.innerHTML = '<h3 style="margin-top:0;color:#826200;">👉 Fix Plugin Does Not Exist Notices Can Fix This</h3>' +
|
||||||
'<p>To remove the above error notification, scroll down to find the plugin marked with "<strong style="color:red">(File Missing)</strong>" and click its "<strong>Remove Reference</strong>" link.</p>' +
|
'<p>To remove the above error notification, scroll down to find the plugin marked with "<strong style="color:red">(File Missing)</strong>" and click its "<strong>Remove Reference</strong>" link.</p>' +
|
||||||
'<p>This will permanently remove the missing plugin reference from your database.</p>' +
|
'<p>This will permanently remove the missing plugin reference from your database.</p>' +
|
||||||
'<p><a href="#" id="prc-scroll-to-plugin" style="font-weight:bold;text-decoration:underline;color:#826200;">Click here to scroll to the missing plugin</a></p>';
|
'<p><a href="#" id="prc-scroll-to-plugin" style="font-weight:bold;text-decoration:underline;color:#826200;">Click here to scroll to the missing plugin</a></p>';
|
||||||
@ -288,7 +288,7 @@ class Fix_Plugin_Does_Not_Exist_Notices {
|
|||||||
|
|
||||||
// Also display our standard info notice with more details
|
// Also display our standard info notice with more details
|
||||||
echo '<div class="notice notice-info is-dismissible">';
|
echo '<div class="notice notice-info is-dismissible">';
|
||||||
echo '<h3>Plugin Reference Cleaner</h3>';
|
echo '<h3>Fix Plugin Does Not Exist Notices</h3>';
|
||||||
echo '<p><strong>Missing plugin files detected:</strong> The plugins listed below with <span style="color:red;">(File Missing)</span> tag no longer exist but are still referenced in your database.</p>';
|
echo '<p><strong>Missing plugin files detected:</strong> The plugins listed below with <span style="color:red;">(File Missing)</span> tag no longer exist but are still referenced in your database.</p>';
|
||||||
echo '<p><strong>How to fix:</strong> Click the "Remove Reference" link next to each missing plugin to safely remove it from your active plugins list.</p>';
|
echo '<p><strong>How to fix:</strong> Click the "Remove Reference" link next to each missing plugin to safely remove it from your active plugins list.</p>';
|
||||||
echo '<p>This will clean up your database and remove the error notifications.</p>';
|
echo '<p>This will clean up your database and remove the error notifications.</p>';
|
||||||
|
@ -1,343 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* Plugin Reference Cleaner
|
|
||||||
*
|
|
||||||
* @package PluginReferenceCleaner
|
|
||||||
* @author Marcus Quinn
|
|
||||||
* @copyright 2023 WP All Stars
|
|
||||||
* @license GPL-2.0+
|
|
||||||
*
|
|
||||||
* @wordpress-plugin
|
|
||||||
* Plugin Name: Plugin Reference Cleaner
|
|
||||||
* Description: Adds a "Remove Reference" button to plugin deactivation error notices, allowing users to clean up invalid plugin entries.
|
|
||||||
* Version: 1.3.3
|
|
||||||
* Author: Marcus Quinn
|
|
||||||
* Author URI: https://www.wpallstars.com
|
|
||||||
* License: GPL-2.0+
|
|
||||||
* License URI: https://www.gnu.org/licenses/gpl-2.0.html
|
|
||||||
* Text Domain: plugin-reference-cleaner
|
|
||||||
* Domain Path: /languages
|
|
||||||
* Requires at least: 5.0
|
|
||||||
* Requires PHP: 7.0
|
|
||||||
*
|
|
||||||
* This plugin is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 2 of the License, or
|
|
||||||
* any later version.
|
|
||||||
*
|
|
||||||
* This plugin is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this plugin. If not, see https://www.gnu.org/licenses/gpl-2.0.html.
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Exit if accessed directly
|
|
||||||
if (!defined('ABSPATH')) {
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
class Plugin_Reference_Cleaner {
|
|
||||||
public function __construct() {
|
|
||||||
// Add our plugin to the plugins list
|
|
||||||
add_filter('all_plugins', array($this, 'add_missing_plugins_references'));
|
|
||||||
|
|
||||||
// Add our action link to the plugins list
|
|
||||||
add_filter('plugin_action_links', array($this, 'add_remove_reference_action'), 20, 4);
|
|
||||||
|
|
||||||
// Handle the remove reference action
|
|
||||||
add_action('admin_init', array($this, 'handle_remove_reference'));
|
|
||||||
|
|
||||||
// Add admin notices for operation feedback
|
|
||||||
add_action('admin_notices', array($this, 'admin_notices'));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Find and add invalid plugin references to the plugins list
|
|
||||||
*/
|
|
||||||
public function add_missing_plugins_references($plugins) {
|
|
||||||
// Only run on the plugins page
|
|
||||||
if (!$this->is_plugins_page()) {
|
|
||||||
return $plugins;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get active plugins that don't exist
|
|
||||||
$invalid_plugins = $this->get_invalid_plugins();
|
|
||||||
|
|
||||||
// Add each invalid plugin to the plugin list
|
|
||||||
foreach ($invalid_plugins as $plugin_path) {
|
|
||||||
if (!isset($plugins[$plugin_path])) {
|
|
||||||
$plugin_name = basename($plugin_path);
|
|
||||||
$plugins[$plugin_path] = array(
|
|
||||||
'Name' => $plugin_name . ' <span class="error">(File Missing)</span>',
|
|
||||||
'Description' => 'This plugin file does not exist. You can safely remove this reference.',
|
|
||||||
'Version' => 'N/A',
|
|
||||||
'Author' => '',
|
|
||||||
'PluginURI' => '',
|
|
||||||
'AuthorURI' => '',
|
|
||||||
'Title' => $plugin_name . ' (Missing)',
|
|
||||||
'AuthorName' => ''
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $plugins;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add the Remove Reference action link to invalid plugins
|
|
||||||
*/
|
|
||||||
public function add_remove_reference_action($actions, $plugin_file, $plugin_data, $context) {
|
|
||||||
// Only run on the plugins page
|
|
||||||
if (!$this->is_plugins_page()) {
|
|
||||||
return $actions;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if this is a missing plugin
|
|
||||||
if (isset($plugin_data['Name']) && strpos($plugin_data['Name'], '<span class="error">(File Missing)</span>') !== false) {
|
|
||||||
// Clear existing actions
|
|
||||||
$actions = array();
|
|
||||||
|
|
||||||
// Add our action
|
|
||||||
$nonce = wp_create_nonce('remove_plugin_reference_' . $plugin_file);
|
|
||||||
$remove_url = admin_url('plugins.php?action=remove_reference&plugin=' . urlencode($plugin_file) . '&_wpnonce=' . $nonce);
|
|
||||||
$actions['remove_reference'] = '<a href="' . esc_url($remove_url) . '" class="delete" aria-label="' . esc_attr__('Remove Reference', 'plugin-reference-cleaner') . '">Remove Reference</a>';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $actions;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handle the remove reference action
|
|
||||||
*/
|
|
||||||
public function handle_remove_reference() {
|
|
||||||
// Check if we're removing a reference
|
|
||||||
if (!isset($_GET['action']) || $_GET['action'] !== 'remove_reference' || !isset($_GET['plugin'])) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Verify permissions
|
|
||||||
if (!current_user_can('activate_plugins')) {
|
|
||||||
wp_die(__('You do not have sufficient permissions to perform this action.', 'plugin-reference-cleaner'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get the plugin file
|
|
||||||
$plugin_file = isset($_GET['plugin']) ? $_GET['plugin'] : '';
|
|
||||||
|
|
||||||
// Verify nonce
|
|
||||||
check_admin_referer('remove_plugin_reference_' . $plugin_file);
|
|
||||||
|
|
||||||
// Remove the plugin reference
|
|
||||||
$success = $this->remove_plugin_reference($plugin_file);
|
|
||||||
|
|
||||||
// Redirect back to plugins page with a message
|
|
||||||
$redirect = admin_url('plugins.php');
|
|
||||||
$redirect = add_query_arg($success ? 'reference_removed' : 'reference_removal_failed', '1', $redirect);
|
|
||||||
wp_redirect($redirect);
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove a plugin reference from the active plugins
|
|
||||||
*/
|
|
||||||
public function remove_plugin_reference($plugin_file) {
|
|
||||||
$success = false;
|
|
||||||
|
|
||||||
// Handle multisite network admin
|
|
||||||
if (is_multisite() && is_network_admin()) {
|
|
||||||
$active_plugins = get_site_option('active_sitewide_plugins', array());
|
|
||||||
if (isset($active_plugins[$plugin_file])) {
|
|
||||||
unset($active_plugins[$plugin_file]);
|
|
||||||
$success = update_site_option('active_sitewide_plugins', $active_plugins);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Handle single site or multisite subsite
|
|
||||||
else {
|
|
||||||
$active_plugins = get_option('active_plugins', array());
|
|
||||||
$key = array_search($plugin_file, $active_plugins);
|
|
||||||
if ($key !== false) {
|
|
||||||
unset($active_plugins[$key]);
|
|
||||||
$active_plugins = array_values($active_plugins); // Re-index array
|
|
||||||
$success = update_option('active_plugins', $active_plugins);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $success;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Display admin notices
|
|
||||||
*/
|
|
||||||
public function admin_notices() {
|
|
||||||
// Only run on the plugins page
|
|
||||||
if (!$this->is_plugins_page()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get invalid plugins
|
|
||||||
$invalid_plugins = $this->get_invalid_plugins();
|
|
||||||
|
|
||||||
// Create a highlighted notice immediately after WordPress error messages
|
|
||||||
if (!empty($invalid_plugins)) {
|
|
||||||
// Add a notice specifically targeting the WordPress error notification
|
|
||||||
// Use admin_head to ensure it runs early in the page load process
|
|
||||||
add_action('admin_head', function() use ($invalid_plugins) {
|
|
||||||
?>
|
|
||||||
<style type="text/css">
|
|
||||||
.prc-notice {
|
|
||||||
border-left: 4px solid #ffba00;
|
|
||||||
background-color: #fff8e5;
|
|
||||||
padding: 10px 12px;
|
|
||||||
margin: 5px 0 15px;
|
|
||||||
font-size: 14px;
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
.prc-notice h3 {
|
|
||||||
margin-top: 0;
|
|
||||||
color: #826200;
|
|
||||||
}
|
|
||||||
.prc-notice::before {
|
|
||||||
content: "";
|
|
||||||
position: absolute;
|
|
||||||
top: -10px;
|
|
||||||
left: 20px;
|
|
||||||
width: 0;
|
|
||||||
height: 0;
|
|
||||||
border-left: 10px solid transparent;
|
|
||||||
border-right: 10px solid transparent;
|
|
||||||
border-bottom: 10px solid #fff8e5;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
<script type="text/javascript">
|
|
||||||
// Function to inject our notice
|
|
||||||
function injectNotice() {
|
|
||||||
// Find all notification containers first
|
|
||||||
var noticeContainers = document.querySelectorAll('.notice, .error, .updated');
|
|
||||||
|
|
||||||
// Find all error notifications about missing plugins
|
|
||||||
noticeContainers.forEach(function(notice) {
|
|
||||||
if (notice.textContent.includes('Plugin file does not exist') ||
|
|
||||||
notice.textContent.includes('has been deactivated due to an error')) {
|
|
||||||
|
|
||||||
// Check if we already added our notice
|
|
||||||
if (notice.nextElementSibling && notice.nextElementSibling.classList.contains('prc-notice')) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create our custom notice
|
|
||||||
var ourNotice = document.createElement('div');
|
|
||||||
ourNotice.className = 'prc-notice';
|
|
||||||
|
|
||||||
// Add content
|
|
||||||
ourNotice.innerHTML = '<h3 style="margin-top:0;color:#826200;">👉 Plugin Reference Cleaner Can Fix This</h3>' +
|
|
||||||
'<p>To remove the above error notification, scroll down to find the plugin marked with "<strong style="color:red">(File Missing)</strong>" and click its "<strong>Remove Reference</strong>" link.</p>' +
|
|
||||||
'<p>This will permanently remove the missing plugin reference from your database.</p>' +
|
|
||||||
'<p><a href="#" id="prc-scroll-to-plugin" style="font-weight:bold;text-decoration:underline;color:#826200;">Click here to scroll to the missing plugin</a></p>';
|
|
||||||
|
|
||||||
// Insert our notice right after the error
|
|
||||||
notice.parentNode.insertBefore(ourNotice, notice.nextSibling);
|
|
||||||
|
|
||||||
// Add scroll behavior
|
|
||||||
var scrollLink = document.getElementById('prc-scroll-to-plugin');
|
|
||||||
if (scrollLink) {
|
|
||||||
scrollLink.addEventListener('click', function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
var missingPlugins = document.querySelectorAll('tr.inactive:not(.plugin-update-tr)');
|
|
||||||
for (var i = 0; i < missingPlugins.length; i++) {
|
|
||||||
if (missingPlugins[i].textContent.includes('(File Missing)')) {
|
|
||||||
missingPlugins[i].style.backgroundColor = '#fff8e5';
|
|
||||||
missingPlugins[i].scrollIntoView({behavior: 'smooth', block: 'center'});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// Try to inject notices on multiple events to ensure it works
|
|
||||||
document.addEventListener('DOMContentLoaded', function() {
|
|
||||||
injectNotice();
|
|
||||||
|
|
||||||
// Also set up a MutationObserver to watch for dynamically added notices
|
|
||||||
var observer = new MutationObserver(function(mutations) {
|
|
||||||
mutations.forEach(function(mutation) {
|
|
||||||
if (mutation.addedNodes && mutation.addedNodes.length > 0) {
|
|
||||||
injectNotice();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
// Start observing the body for changes
|
|
||||||
observer.observe(document.body, { childList: true, subtree: true });
|
|
||||||
});
|
|
||||||
|
|
||||||
// Backup attempt with window.onload
|
|
||||||
window.onload = function() {
|
|
||||||
setTimeout(injectNotice, 500);
|
|
||||||
};
|
|
||||||
|
|
||||||
// Final backup in case other methods fail
|
|
||||||
setTimeout(injectNotice, 1000);
|
|
||||||
</script>
|
|
||||||
<?php
|
|
||||||
});
|
|
||||||
|
|
||||||
// Also display our standard info notice with more details
|
|
||||||
echo '<div class="notice notice-info is-dismissible">';
|
|
||||||
echo '<h3>Plugin Reference Cleaner</h3>';
|
|
||||||
echo '<p><strong>Missing plugin files detected:</strong> The plugins listed below with <span style="color:red;">(File Missing)</span> tag no longer exist but are still referenced in your database.</p>';
|
|
||||||
echo '<p><strong>How to fix:</strong> Click the "Remove Reference" link next to each missing plugin to safely remove it from your active plugins list.</p>';
|
|
||||||
echo '<p>This will clean up your database and remove the error notifications.</p>';
|
|
||||||
echo '</div>';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Show success message
|
|
||||||
if (isset($_GET['reference_removed']) && $_GET['reference_removed'] === '1') {
|
|
||||||
echo '<div class="notice notice-success is-dismissible"><p>Plugin reference removed successfully.</p></div>';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Show error message
|
|
||||||
if (isset($_GET['reference_removal_failed']) && $_GET['reference_removal_failed'] === '1') {
|
|
||||||
echo '<div class="notice notice-error is-dismissible"><p>Failed to remove plugin reference. The plugin may already have been removed.</p></div>';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if we're on the plugins page
|
|
||||||
*/
|
|
||||||
private function is_plugins_page() {
|
|
||||||
global $pagenow;
|
|
||||||
return is_admin() && $pagenow === 'plugins.php';
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get a list of invalid plugin references
|
|
||||||
*/
|
|
||||||
private function get_invalid_plugins() {
|
|
||||||
$invalid_plugins = array();
|
|
||||||
|
|
||||||
// Get all active plugins
|
|
||||||
if (is_multisite() && is_network_admin()) {
|
|
||||||
$active_plugins = array_keys(get_site_option('active_sitewide_plugins', array()));
|
|
||||||
} else {
|
|
||||||
$active_plugins = get_option('active_plugins', array());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if each plugin exists
|
|
||||||
foreach ($active_plugins as $plugin) {
|
|
||||||
$plugin_path = WP_PLUGIN_DIR . '/' . $plugin;
|
|
||||||
if (!file_exists($plugin_path)) {
|
|
||||||
$invalid_plugins[] = $plugin;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $invalid_plugins;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize the plugin
|
|
||||||
new Plugin_Reference_Cleaner();
|
|
@ -5,7 +5,7 @@ Tags: plugins, missing plugins, cleanup, error fix, admin tools, plugin file doe
|
|||||||
Requires at least: 5.0
|
Requires at least: 5.0
|
||||||
Tested up to: 6.4
|
Tested up to: 6.4
|
||||||
Requires PHP: 7.0
|
Requires PHP: 7.0
|
||||||
Stable tag: 1.3.3
|
Stable tag: 1.4.0
|
||||||
License: GPL-2.0+
|
License: GPL-2.0+
|
||||||
License URI: https://www.gnu.org/licenses/gpl-2.0.html
|
License URI: https://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
|
||||||
@ -85,6 +85,10 @@ If you remove a reference to a plugin that you later want to reinstall, simply i
|
|||||||
|
|
||||||
== Changelog ==
|
== Changelog ==
|
||||||
|
|
||||||
|
= 1.4.0 =
|
||||||
|
* Updated plugin name and text domain
|
||||||
|
* Repository rename from plugin-reference-cleaner to fix-plugin-does-not-exist-notices
|
||||||
|
|
||||||
= 1.3.3 =
|
= 1.3.3 =
|
||||||
* Improved notification placement next to WordPress error messages
|
* Improved notification placement next to WordPress error messages
|
||||||
* Added "Click here to scroll" button that automatically locates missing plugins
|
* Added "Click here to scroll" button that automatically locates missing plugins
|
||||||
|
@ -1,63 +0,0 @@
|
|||||||
# Repository Rename Migration Guide
|
|
||||||
|
|
||||||
This document outlines the steps needed to safely rename the GitHub and Gitea repositories from `plugin-reference-cleaner` to `fix-plugin-does-not-exist-notices` while maintaining history and ensuring proper redirects.
|
|
||||||
|
|
||||||
## GitHub Repository Rename
|
|
||||||
|
|
||||||
1. Go to the GitHub repository settings:
|
|
||||||
- https://github.com/wpallstars/plugin-reference-cleaner/settings
|
|
||||||
|
|
||||||
2. In the "General" tab, find the "Repository name" section and enter the new name:
|
|
||||||
- `fix-plugin-does-not-exist-notices`
|
|
||||||
|
|
||||||
3. Click "Rename"
|
|
||||||
|
|
||||||
GitHub will automatically set up redirects from the old URL to the new URL, so any existing links to the old repository will still work.
|
|
||||||
|
|
||||||
## Gitea Repository Rename
|
|
||||||
|
|
||||||
1. Go to the Gitea repository settings:
|
|
||||||
- https://gitea.wpallstars.com/wpallstars/plugin-reference-cleaner/settings
|
|
||||||
|
|
||||||
2. Find the "Repository Name" field and change it to:
|
|
||||||
- `fix-plugin-does-not-exist-notices`
|
|
||||||
|
|
||||||
3. Click "Update Repository"
|
|
||||||
|
|
||||||
## Update Local Repository
|
|
||||||
|
|
||||||
After renaming the remote repositories, update your local git configuration:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
# 1. Update the remote URLs for both GitHub and Gitea
|
|
||||||
git remote set-url github https://github.com/wpallstars/fix-plugin-does-not-exist-notices.git
|
|
||||||
git remote set-url gitea git@gitea.wpallstars.com:wpallstars/fix-plugin-does-not-exist-notices.git
|
|
||||||
|
|
||||||
# 2. Verify the changes
|
|
||||||
git remote -v
|
|
||||||
|
|
||||||
# 3. Create a new local clone (optional but recommended)
|
|
||||||
cd ..
|
|
||||||
git clone git@gitea.wpallstars.com:wpallstars/fix-plugin-does-not-exist-notices.git
|
|
||||||
cd fix-plugin-does-not-exist-notices
|
|
||||||
```
|
|
||||||
|
|
||||||
## WordPress.org Plugin Submission
|
|
||||||
|
|
||||||
When submitting to WordPress.org, you'll need to use the new slug:
|
|
||||||
|
|
||||||
- Plugin slug: `fix-plugin-does-not-exist-notices`
|
|
||||||
|
|
||||||
After approval, update the GitHub secrets with:
|
|
||||||
|
|
||||||
```
|
|
||||||
SVN_USERNAME: your_wordpress_username
|
|
||||||
SVN_PASSWORD: your_wordpress_password
|
|
||||||
SLUG: fix-plugin-does-not-exist-notices
|
|
||||||
```
|
|
||||||
|
|
||||||
## Final Steps
|
|
||||||
|
|
||||||
1. Update any documentation or links that reference the old repository name
|
|
||||||
2. Commit and push all the renamed files
|
|
||||||
3. Create a new release with the new file naming conventions
|
|
Reference in New Issue
Block a user