Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
Total | |
95.00% |
19 / 20 |
|
100.00% |
3 / 3 |
CRAP | n/a |
0 / 0 |
|
bh_wp_autologin_urls_clear_transients | |
100.00% |
8 / 8 |
|
100.00% |
1 / 1 |
1 | |||
bh_wp_autologin_urls_delete_settings | |
100.00% |
3 / 3 |
|
100.00% |
1 / 1 |
1 | |||
bh_wp_autologin_urls_drop_table | |
100.00% |
4 / 4 |
|
100.00% |
1 / 1 |
1 |
1 | <?php |
2 | /** |
3 | * Fired when the plugin is uninstalled. |
4 | * |
5 | * When populating this file, consider the following flow |
6 | * of control: |
7 | * |
8 | * - This method should be static |
9 | * - Check if the $_REQUEST content actually is the plugin name |
10 | * - Run an admin referrer check to make sure it goes through authentication |
11 | * - Verify the output of $_GET makes sense |
12 | * - Repeat with other user roles. Best directly by using the links/query string parameters. |
13 | * - Repeat things for multisite. Once for a single site in the network, once sitewide. |
14 | * |
15 | * This file may be updated more in future version of the Boilerplate; however, this is the |
16 | * general skeleton and outline for how the file should work. |
17 | * |
18 | * For more information, see the following discussion: |
19 | * https://github.com/tommcfarlin/WordPress-Plugin-Boilerplate/pull/123#issuecomment-28541913 |
20 | * |
21 | * @link https://BrianHenry.ie |
22 | * @since 1.0.0 |
23 | * |
24 | * @package bh-wp-autologin-urls |
25 | */ |
26 | |
27 | // If uninstall not called from WordPress, then exit. |
28 | if ( ! defined( 'WP_UNINSTALL_PLUGIN' ) ) { |
29 | throw new \Exception( 'WP_UNINSTALL_PLUGIN not defined' ); |
30 | } |
31 | |
32 | use BrianHenryIE\WP_Autologin_URLs\Settings_Interface; |
33 | |
34 | /** |
35 | * Delete the passwords stored as transients in wp_options. |
36 | * |
37 | * phpcs:disable WordPress.DB.DirectDatabaseQuery.DirectQuery |
38 | * phpcs:disable WordPress.DB.DirectDatabaseQuery.NoCaching |
39 | */ |
40 | function bh_wp_autologin_urls_clear_transients(): void { |
41 | global $wpdb; |
42 | |
43 | $wpdb->query( |
44 | $wpdb->prepare( |
45 | "DELETE FROM {$wpdb->options} WHERE option_name LIKE %s OR option_name LIKE %s", |
46 | $wpdb->esc_like( '_transient_bh_autologin_bh_autologin_%' ), |
47 | $wpdb->esc_like( '_transient_timeout_bh_autologin_%' ) |
48 | ) |
49 | ); |
50 | } |
51 | bh_wp_autologin_urls_clear_transients(); |
52 | |
53 | /** |
54 | * Delete each of the wp_options entries used by the plugin. |
55 | * |
56 | * @see Settings_Interface |
57 | */ |
58 | function bh_wp_autologin_urls_delete_settings(): void { |
59 | |
60 | // TODO: ReflectionClass::getConstants. |
61 | |
62 | delete_option( 'bh_wp_autologin_urls_seconds_until_expiry' ); |
63 | delete_option( 'bh_wp_autologin_urls_is_admin_enabled' ); |
64 | delete_option( 'bh_wp_autologin_urls_subject_filter_regex_dictionary' ); |
65 | } |
66 | bh_wp_autologin_urls_delete_settings(); |
67 | |
68 | |
69 | /** |
70 | * Delete the database table used to save the passwords. |
71 | * |
72 | * phpcs:disable WordPress.DB.DirectDatabaseQuery.SchemaChange |
73 | */ |
74 | function bh_wp_autologin_urls_drop_table(): void { |
75 | global $wpdb; |
76 | |
77 | $wpdb->query( |
78 | "DROP TABLE IF EXISTS {$wpdb->prefix}autologin_urls" |
79 | ); |
80 | } |
81 | bh_wp_autologin_urls_drop_table(); |