The pre_uninstall_plugin WordPress PHP action fires immediately before a plugin is uninstalled.
Usage
add_action('pre_uninstall_plugin', 'my_custom_pre_uninstall_plugin', 10, 2);
function my_custom_pre_uninstall_plugin($plugin, $uninstallable_plugins) {
// your custom code here
}
Parameters
- $plugin (string): Path to the plugin file relative to the plugins directory.
- $uninstallable_plugins (array): An array of uninstallable plugins.
More information
See WordPress Developer Resources: pre_uninstall_plugin
Examples
Log plugin uninstallation
Log the name of the plugin being uninstalled in a custom log file.
add_action('pre_uninstall_plugin', 'log_plugin_uninstall', 10, 2);
function log_plugin_uninstall($plugin, $uninstallable_plugins) {
$log_message = "Uninstalling plugin: " . $plugin . "\n";
error_log($log_message, 3, "/path/to/your/logfile.log");
}
Prevent specific plugin uninstallation
Prevent the uninstallation of a specific plugin by checking its name.
add_action('pre_uninstall_plugin', 'prevent_plugin_uninstall', 10, 2);
function prevent_plugin_uninstall($plugin, $uninstallable_plugins) {
if ($plugin == 'my-important-plugin/my-important-plugin.php') {
wp_die("You cannot uninstall this important plugin.");
}
}
Delete custom plugin options
Delete custom options created by a plugin during its uninstallation process.
add_action('pre_uninstall_plugin', 'delete_custom_plugin_options', 10, 2);
function delete_custom_plugin_options($plugin, $uninstallable_plugins) {
if ($plugin == 'my-custom-plugin/my-custom-plugin.php') {
delete_option('my_custom_plugin_option');
}
}
Send email notification on plugin uninstallation
Send an email to the administrator when a specific plugin is uninstalled.
add_action('pre_uninstall_plugin', 'send_email_on_plugin_uninstall', 10, 2);
function send_email_on_plugin_uninstall($plugin, $uninstallable_plugins) {
if ($plugin == 'my-notifiable-plugin/my-notifiable-plugin.php') {
$to = get_option('admin_email');
$subject = 'Plugin Uninstalled';
$message = 'The My Notifiable Plugin has been uninstalled.';
wp_mail($to, $subject, $message);
}
}
Deactivate dependent plugins
Deactivate other plugins that depend on a specific plugin before it’s uninstalled.
add_action('pre_uninstall_plugin', 'deactivate_dependent_plugins', 10, 2);
function deactivate_dependent_plugins($plugin, $uninstallable_plugins) {
if ($plugin == 'my-main-plugin/my-main-plugin.php') {
deactivate_plugins('dependent-plugin/dependent-plugin.php');
}
}