HEX
Server: Apache/2.4.65 (Ubuntu)
System: Linux ielts-store-v2 6.8.0-1036-gcp #38~22.04.1-Ubuntu SMP Thu Aug 14 01:19:18 UTC 2025 x86_64
User: root (0)
PHP: 7.2.34-54+ubuntu20.04.1+deb.sury.org+1
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,
Upload Files
File: /var/www/html/ielts-store/wp-content/plugins/woocommerce-zapier/src/Uninstall.php
<?php

namespace OM4\WooCommerceZapier;

defined( 'ABSPATH' ) || exit;

/**
 * WooCommerce Zapier Uninstall routine.
 * Deletes all existing data from the database, including database table and
 * options. Only remove all plugin settings/data if the `WC_ZAPIER_REMOVE_ALL_DATA`
 * constant is defined and set to true in user's wp-config.php.
 *
 * @since 2.0.0
 */
class Uninstall {

	/**
	 * Run the uninstall routine
	 *
	 * @return void
	 */
	public static function run() {
		if ( ! defined( 'WC_ZAPIER_REMOVE_ALL_DATA' ) || true !== WC_ZAPIER_REMOVE_ALL_DATA ) {
			return;
		}

		/**
		 * ################# REST-API (2.0+) based data #################
		 */

		// Delete Task History database table.
		global $wpdb;
		// phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching, WordPress.DB.DirectDatabaseQuery.SchemaChange
		$wpdb->query( "DROP TABLE IF EXISTS `{$wpdb->prefix}wc_zapier_history`" );

		// Delete all existing WooCommerce Zapier Webhooks.
		// phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
		$wpdb->query( "DELETE FROM `{$wpdb->prefix}wc_webhooks` WHERE `name` LIKE 'Zapier #%' AND `delivery_url` LIKE '%hooks.zapier.com%'" );

		// Delete all existing WooCommerce Zapier REST API Keys.
		// phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
		$wpdb->query( "DELETE FROM `{$wpdb->prefix}woocommerce_api_keys` WHERE `description` LIKE '%Zapier%'" );

		/**
		 * ################# 1.9.x Legacy Feed based data #################
		 */

		// Delete all existing 1.9.x Legacy Zapier Feed records.
		foreach ( get_posts(
			array(
				'post_type'      => 'wc_zapier_feed',
				'posts_per_page' => -1,
			)
		) as $feed ) {
			if ( isset( $feed->ID ) ) {
				wp_delete_post( $feed->ID, false );
			}
		}

		// Delete all options/settings.
		// phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
		$wpdb->query( "DELETE FROM `$wpdb->options` WHERE option_name LIKE 'wc\_zapier\_%';" );

		// Clear any cached data that has been removed.
		wp_cache_flush();
	}
}