give
Last commit date
assets
5 years ago
blocks
5 years ago
includes
5 years ago
languages
5 years ago
sample-data
6 years ago
src
5 years ago
templates
6 years ago
vendor
5 years ago
.stylelintignore
6 years ago
give.php
5 years ago
license.txt
6 years ago
readme.txt
5 years ago
uninstall.php
5 years ago
wpml-config.xml
6 years ago
uninstall.php
136 lines
| 1 | <?php |
| 2 | /** |
| 3 | * Uninstall Give |
| 4 | * |
| 5 | * @package Give |
| 6 | * @subpackage Uninstall |
| 7 | * @copyright Copyright (c) 2016, GiveWP |
| 8 | * @license https://opensource.org/licenses/gpl-license GNU Public License |
| 9 | * @since 1.0 |
| 10 | */ |
| 11 | |
| 12 | // Exit if accessed directly. |
| 13 | if ( ! defined( 'WP_UNINSTALL_PLUGIN' ) ) { |
| 14 | exit; |
| 15 | } |
| 16 | |
| 17 | // Load Give file. |
| 18 | include_once( 'give.php' ); |
| 19 | |
| 20 | /** |
| 21 | * Initialize the main Give class, which includes loading the code necessary to process the uninstall. |
| 22 | * This is included manually because the plugins_loaded hook does not run on uninstall. |
| 23 | * |
| 24 | * @since 2.7.4 |
| 25 | */ |
| 26 | give()->init(); |
| 27 | |
| 28 | global $wpdb, $wp_roles; |
| 29 | |
| 30 | |
| 31 | if ( give_is_setting_enabled( give_get_option( 'uninstall_on_delete' ) ) ) { |
| 32 | |
| 33 | // Delete All the Custom Post Types. |
| 34 | $give_taxonomies = [ 'form_category', 'form_tag' ]; |
| 35 | $give_post_types = [ 'give_forms', 'give_payment' ]; |
| 36 | foreach ( $give_post_types as $post_type ) { |
| 37 | |
| 38 | $give_taxonomies = array_merge( $give_taxonomies, get_object_taxonomies( $post_type ) ); |
| 39 | $items = get_posts( |
| 40 | [ |
| 41 | 'post_type' => $post_type, |
| 42 | 'post_status' => 'any', |
| 43 | 'numberposts' => - 1, |
| 44 | 'fields' => 'ids', |
| 45 | ] |
| 46 | ); |
| 47 | |
| 48 | if ( $items ) { |
| 49 | foreach ( $items as $item ) { |
| 50 | wp_delete_post( $item, true ); |
| 51 | } |
| 52 | } |
| 53 | } |
| 54 | |
| 55 | // Delete All the Terms & Taxonomies. |
| 56 | foreach ( array_unique( array_filter( $give_taxonomies ) ) as $taxonomy ) { |
| 57 | |
| 58 | $terms = $wpdb->get_results( $wpdb->prepare( "SELECT t.*, tt.* FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON t.term_id = tt.term_id WHERE tt.taxonomy IN ('%s') ORDER BY t.name ASC", $taxonomy ) ); |
| 59 | |
| 60 | // Delete Terms. |
| 61 | if ( $terms ) { |
| 62 | foreach ( $terms as $term ) { |
| 63 | $wpdb->delete( $wpdb->term_taxonomy, [ 'term_taxonomy_id' => $term->term_taxonomy_id ] ); |
| 64 | $wpdb->delete( $wpdb->terms, [ 'term_id' => $term->term_id ] ); |
| 65 | } |
| 66 | } |
| 67 | |
| 68 | // Delete Taxonomies. |
| 69 | $wpdb->delete( $wpdb->term_taxonomy, [ 'taxonomy' => $taxonomy ], [ '%s' ] ); |
| 70 | } |
| 71 | |
| 72 | // Delete the Plugin Pages. |
| 73 | $give_created_pages = [ 'success_page', 'failure_page', 'history_page' ]; |
| 74 | foreach ( $give_created_pages as $p ) { |
| 75 | $page = give_get_option( $p, false ); |
| 76 | if ( $page ) { |
| 77 | wp_delete_post( $page, true ); |
| 78 | } |
| 79 | } |
| 80 | |
| 81 | // Delete Capabilities. |
| 82 | Give()->roles = new Give_Roles(); |
| 83 | Give()->roles->remove_caps(); |
| 84 | |
| 85 | // Delete the Roles. |
| 86 | $give_roles = [ 'give_manager', 'give_accountant', 'give_worker', 'give_donor' ]; |
| 87 | foreach ( $give_roles as $role ) { |
| 88 | remove_role( $role ); |
| 89 | } |
| 90 | |
| 91 | // Remove all database tables. |
| 92 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_donors" ); |
| 93 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_donormeta" ); |
| 94 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_donationmeta" ); |
| 95 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_formmeta" ); |
| 96 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_logs" ); |
| 97 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_logmeta" ); |
| 98 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_comments" ); |
| 99 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_commentmeta" ); |
| 100 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_sequential_ordering" ); |
| 101 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_sessions" ); |
| 102 | |
| 103 | // Remove tables which are supported with backward compatibility. |
| 104 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_customers" ); |
| 105 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_customermeta" ); |
| 106 | $wpdb->query( "DROP TABLE IF EXISTS {$wpdb->prefix}give_paymentmeta" ); |
| 107 | |
| 108 | // Cleanup Cron Events. |
| 109 | wp_clear_scheduled_hook( 'give_daily_scheduled_events' ); |
| 110 | wp_clear_scheduled_hook( 'give_weekly_scheduled_events' ); |
| 111 | wp_clear_scheduled_hook( 'give_daily_cron' ); |
| 112 | wp_clear_scheduled_hook( 'give_weekly_cron' ); |
| 113 | |
| 114 | // Get all options. |
| 115 | $give_option_names = $wpdb->get_col( |
| 116 | $wpdb->prepare( |
| 117 | "SELECT option_name FROM {$wpdb->options} where option_name LIKE '%%%s%%'", |
| 118 | 'give' |
| 119 | ) |
| 120 | ); |
| 121 | |
| 122 | if ( ! empty( $give_option_names ) ) { |
| 123 | // Convert option name to transient or option name. |
| 124 | $new_give_option_names = []; |
| 125 | |
| 126 | // Delete all the Plugin Options. |
| 127 | foreach ( $give_option_names as $option ) { |
| 128 | if ( false !== strpos( $option, 'give_cache' ) ) { |
| 129 | Give_Cache::delete( $option ); |
| 130 | } else { |
| 131 | delete_option( $option ); |
| 132 | } |
| 133 | } |
| 134 | } |
| 135 | } |
| 136 |