-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathuninstall.php
115 lines (98 loc) · 3.01 KB
/
uninstall.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
<?php
/**
* Fired when the plugin is uninstalled.
*
* When populating this file, consider the following flow
* of control:
*
* - This method should be static
* - Check if the $_REQUEST content actually is the plugin name
* - Run an admin referrer check to make sure it goes through authentication
* - Verify the output of $_GET makes sense
* - Repeat with other user roles. Best directly by using the links/query string parameters.
* - Repeat things for multisite. Once for a single site in the network, once sitewide.
*
* This file may be updated more in future version of the Boilerplate; however, this is the
* general skeleton and outline for how the file should work.
*
* @since 0.1.5
* @package Classic_SEO
*/
// If uninstall not called from ClassicPress, then exit.
if ( ! defined( 'WP_UNINSTALL_PLUGIN' ) ) {
exit;
}
$delete = get_option('cpseo-options-general', ['cpseo_remove_data_on_uninstall' => 'off']);
if ( $delete['cpseo_remove_data_on_uninstall'] === 'on' ) {
if ( ! is_multisite() ) {
cpseo_remove_data();
return;
}
global $wpdb;
$blog_ids = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs WHERE archived = '0' AND spam = '0' AND deleted = '0'" );
if ( ! empty( $blog_ids ) ) {
foreach ( $blog_ids as $blog_id ) {
switch_to_blog( $blog_id );
cpseo_remove_data();
restore_current_blog();
}
}
}
/**
* Removes ALL plugin data
*
* @since 0.3.0
*/
function cpseo_remove_data() {
// Delete all options.
cpseo_delete_options();
// Delete meta for post, user and term.
cpseo_delete_meta( 'post' );
cpseo_delete_meta( 'user' );
cpseo_delete_meta( 'term' );
// Drop Tables.
cpseo_drop_table( 'cpseo_404_logs' );
cpseo_drop_table( 'cpseo_redirections' );
cpseo_drop_table( 'cpseo_redirections_cache' );
cpseo_drop_table( 'cpseo_internal_links' );
cpseo_drop_table( 'cpseo_internal_meta' );
// Remove Capabilities.
/**
* PSR-4 Autoload.
*/
include dirname( __FILE__ ) . '/vendor/autoload.php';
\Classic_SEO\Role_Manager\Capability_Manager::get()->remove_capabilities();
// Clear any cached data that has been removed.
wp_cache_flush();
}
/**
* Delete options.
*
* @return void
*/
function cpseo_delete_options() {
global $wpdb;
$where = $wpdb->prepare( 'WHERE option_name LIKE %s OR option_name LIKE %s', '%' . $wpdb->esc_like( 'cpseo' ) . '%', '%' . $wpdb->esc_like( 'cpseo' ) . '%' );
$wpdb->query( "DELETE FROM {$wpdb->prefix}options {$where}" ); // phpcs:ignore
}
/**
* Delete post meta.
*
* @param string $table Table name.
* @return void
*/
function cpseo_delete_meta( $table = 'post' ) {
global $wpdb;
$where = $wpdb->prepare( 'WHERE meta_key LIKE %s OR meta_key LIKE %s', '%' . $wpdb->esc_like( 'cpseo' ) . '%', '%' . $wpdb->esc_like( 'cpseo' ) . '%' );
$wpdb->query( "DELETE FROM {$wpdb->prefix}{$table}meta {$where}" ); // phpcs:ignore
}
/**
* Drop table from database
*
* @param string $name Name of table.
* @return void
*/
function cpseo_drop_table( $name ) {
global $wpdb;
$wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}{$name}" ); // phpcs:ignore
}