-
-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathuninstall.php
178 lines (168 loc) · 5.88 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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
<?php
defined('WP_UNINSTALL_PLUGIN') || exit;
function glsr_uninstall()
{
$settings = get_option('site_reviews_v7');
$uninstall = isset($settings['settings']['general']['delete_data_on_uninstall'])
? $settings['settings']['general']['delete_data_on_uninstall']
: '';
if ('all' === $uninstall) {
glsr_uninstall_all();
}
if ('minimal' === $uninstall) {
glsr_uninstall_minimal();
glsr_uninstall_minimal_drop_foreign_keys();
}
delete_option('glsr_activated');
delete_transient('glsr_cloudflare_ips');
delete_transient('glsr_remote_post_test');
delete_transient('glsr_system_info');
// finally, flush the cache
if (function_exists('wp_cache_supports') && wp_cache_supports('flush_group')) {
wp_cache_flush_group('options');
wp_cache_flush_group('reviews');
} else {
wp_cache_flush();
}
}
function glsr_uninstall_all()
{
glsr_uninstall_minimal();
glsr_uninstall_all_delete_reviews();
glsr_uninstall_all_delete_tables();
glsr_uninstall_all_delete_logs();
glsr_uninstall_all_cleanup();
}
function glsr_uninstall_all_cleanup()
{
global $wpdb;
// delete any remaining options
$wpdb->query("DELETE FROM {$wpdb->options} WHERE option_name LIKE '%glsr_%'");
$wpdb->query("DELETE FROM {$wpdb->options} WHERE option_name LIKE 'site-review-category%'");
if (defined('DB_ENGINE') && 'sqlite' === DB_ENGINE) {
return;
}
// optimise affected database tables
$wpdb->query("OPTIMIZE TABLE {$wpdb->options}");
$wpdb->query("OPTIMIZE TABLE {$wpdb->postmeta}");
$wpdb->query("OPTIMIZE TABLE {$wpdb->posts}");
$wpdb->query("OPTIMIZE TABLE {$wpdb->term_taxonomy}");
$wpdb->query("OPTIMIZE TABLE {$wpdb->termmeta}");
$wpdb->query("OPTIMIZE TABLE {$wpdb->terms}");
$wpdb->query("OPTIMIZE TABLE {$wpdb->usermeta}");
}
function glsr_uninstall_all_delete_logs()
{
require_once ABSPATH.'wp-admin/includes/file.php';
global $wp_filesystem;
// delete the Site Reviews logs directory
if (WP_Filesystem()) {
$uploads = wp_upload_dir(null, true, true); // do not use the cached path
$dirname = trailingslashit($uploads['basedir'].'/site-reviews/logs');
$wp_filesystem->rmdir(wp_normalize_path($dirname), true);
}
}
function glsr_uninstall_all_delete_reviews()
{
global $wpdb;
// delete all reviews and revisions
$wpdb->query("
DELETE p, pr, tr, pm
FROM {$wpdb->posts} p
LEFT JOIN {$wpdb->posts} pr ON (pr.post_parent = p.ID AND pr.post_type = 'revision')
LEFT JOIN {$wpdb->term_relationships} tr ON (tr.object_id = p.ID)
LEFT JOIN {$wpdb->postmeta} pm ON (pm.post_id = p.ID)
WHERE p.post_type = 'site-review'
");
// delete all review categories
$wpdb->query("
DELETE tt, t, tm
FROM {$wpdb->term_taxonomy} tt
LEFT JOIN {$wpdb->terms} t ON (t.term_id = tt.term_id)
LEFT JOIN {$wpdb->termmeta} tm ON (tm.term_id = tt.term_id)
WHERE tt.taxonomy = 'site-review-category'
");
// delete all assigned_posts meta
$wpdb->query("DELETE FROM {$wpdb->postmeta} WHERE meta_key LIKE '%glsr_%'");
// delete all Site Reviews user meta
$wpdb->query("
DELETE FROM {$wpdb->usermeta}
WHERE (meta_key LIKE '%glsr_%' OR meta_key LIKE '%_site-review%' OR meta_key LIKE '%-site-review%')
");
}
function glsr_uninstall_all_delete_tables()
{
global $wpdb;
// order is intentional
$wpdb->query("DROP TABLE IF EXISTS {$wpdb->prefix}glsr_assigned_users");
$wpdb->query("DROP TABLE IF EXISTS {$wpdb->prefix}glsr_assigned_terms");
$wpdb->query("DROP TABLE IF EXISTS {$wpdb->prefix}glsr_assigned_posts");
$wpdb->query("DROP TABLE IF EXISTS {$wpdb->prefix}glsr_ratings");
}
function glsr_uninstall_minimal()
{
global $wpdb;
$options = [
'geminilabs_site_reviews-v2', // v2 settings
'geminilabs_site_reviews_settings', // v1 settings
'site_reviews_v3', // v3 settings
'site_reviews_v4', // v4 settings
'site_reviews_v5', // v5 settings
'site_reviews_v6', // v6 settings
'site_reviews_v7', // v7 settings
'theme_mods_site-reviews',
'widget_glsr_site-reviews',
'widget_glsr_site-reviews-form',
'widget_glsr_site-reviews-summary',
];
foreach ($options as $option) {
delete_option($option);
}
delete_transient('glsr_migrations');
$wpdb->query("DELETE FROM {$wpdb->usermeta} WHERE meta_key = '_glsr_notices'");
}
function glsr_uninstall_minimal_drop_foreign_keys()
{
global $wpdb;
if (defined('DB_ENGINE') && 'sqlite' === DB_ENGINE) {
return;
}
$constraints = $wpdb->get_results("
SELECT CONSTRAINT_NAME, TABLE_NAME
FROM INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS
WHERE CONSTRAINT_SCHEMA = '{$wpdb->dbname}'
");
$tables = [ // order is intentional
$wpdb->prefix.'glsr_assigned_posts',
$wpdb->prefix.'glsr_assigned_terms',
$wpdb->prefix.'glsr_assigned_users',
$wpdb->prefix.'glsr_ratings',
];
foreach ($tables as $tablename) {
foreach ($constraints as $constraint) {
if ($tablename !== $constraint->TABLE_NAME) {
continue;
}
$wpdb->query("
ALTER TABLE {$constraint->TABLE_NAME} DROP FOREIGN KEY {$constraint->CONSTRAINT_NAME};
"); // true if constraint exists, false if it doesn't exist
}
}
// delete the saved database version
delete_option('glsr_db_version');
}
if (!is_multisite()) {
glsr_uninstall();
return;
}
if (!function_exists('get_sites')) {
global $wpdb;
$siteIds = $wpdb->get_col("SELECT blog_id FROM {$wpdb->blogs}");
} else {
$siteIds = get_sites(['count' => false, 'fields' => 'ids']);
}
foreach ($siteIds as $siteId) {
switch_to_blog($siteId);
glsr_uninstall();
restore_current_blog();
}