芝麻web文件管理V1.00
编辑当前文件:/home/ezdajrnh/www/wp-content/plugins/woocommerce/includes/admin/helper/class-wc-helper-admin.php
WC_Helper::is_site_connected(), 'connectURL' => self::get_connection_url(), 'reConnectURL' => self::get_connection_url( true ), 'userEmail' => $auth_user_email, 'userAvatar' => get_avatar_url( $auth_user_email, array( 'size' => '48' ) ), 'storeCountry' => wc_get_base_location()['country'], 'storeName' => $blog_name ? $blog_name : '', 'inAppPurchaseURLParams' => WC_Admin_Addons::get_in_app_purchase_url_params(), 'installedProducts' => $installed_products, 'mySubscriptionsTabLoaded' => WC_Helper_Options::get( 'my_subscriptions_tab_loaded' ), 'wooUpdateManagerInstalled' => WC_Woo_Update_Manager_Plugin::is_plugin_installed(), 'wooUpdateManagerActive' => WC_Woo_Update_Manager_Plugin::is_plugin_active(), 'wooUpdateManagerInstallUrl' => WC_Woo_Update_Manager_Plugin::generate_install_url(), 'wooUpdateManagerPluginSlug' => WC_Woo_Update_Manager_Plugin::WOO_UPDATE_MANAGER_SLUG, 'dismissNoticeNonce' => wp_create_nonce( 'dismiss_notice' ), 'trackingAllowed' => 'yes' === get_option( 'woocommerce_allow_tracking' ), ); // This data is only used in the `Extensions` screen, so only populate it there. // More specifically, it's used in `My Subscriptions`, however, switching tabs doesn't require // a page reload, so we just check for `path` (/extensions), rather than `tab` (my-subscriptions). if ( ! empty( $_GET['path'] ) && '/extensions' === $_GET['path'] ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $settings['wccomHelper']['wooUpdateCount'] = WC_Helper_Updater::get_updates_count_based_on_site_status(); $settings['wccomHelper']['connected_notice'] = PluginsHelper::get_wccom_connected_notice( $auth_user_email ); $settings['wccomHelper']['woocomConnectNoticeType'] = WC_Helper_Updater::get_woo_connect_notice_type(); if ( WC_Helper::is_site_connected() ) { $settings['wccomHelper']['subscription_expired_notice'] = PluginsHelper::get_expired_subscription_notice( false ); $settings['wccomHelper']['subscription_expiring_notice'] = PluginsHelper::get_expiring_subscription_notice( false ); $settings['wccomHelper']['subscription_missing_notice'] = PluginsHelper::get_missing_subscription_notice(); $settings['wccomHelper']['connection_url_notice'] = WC_Woo_Helper_Connection::get_connection_url_notice(); $settings['wccomHelper']['has_host_plan_orders'] = WC_Woo_Helper_Connection::has_host_plan_orders(); } else { $settings['wccomHelper']['disconnected_notice'] = PluginsHelper::get_wccom_disconnected_notice(); } } return $settings; } /** * Generates the URL for connecting or disconnecting the store to/from WooCommerce.com. * Approach taken from existing helper code that isn't exposed. * * @param bool $reconnect indicate if the site is being reconnected. * * @return string */ public static function get_connection_url( $reconnect = false ) { // Default to wc-addons, although this can be changed from the frontend // in the function `connectUrl()` within marketplace functions.tsx. $connect_url_args = array( 'page' => 'wc-addons', 'section' => 'helper', ); // No active connection. if ( WC_Helper::is_site_connected() && ! $reconnect ) { $connect_url_args['wc-helper-disconnect'] = 1; $connect_url_args['wc-helper-nonce'] = wp_create_nonce( 'disconnect' ); } else { $connect_url_args['wc-helper-connect'] = 1; $connect_url_args['wc-helper-nonce'] = wp_create_nonce( 'connect' ); } if ( ! empty( $_GET['utm_source'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $connect_url_args['utm_source'] = wc_clean( wp_unslash( $_GET['utm_source'] ) ); // phpcs:ignore WordPress.Security.NonceVerification.Recommended } if ( ! empty( $_GET['utm_campaign'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $connect_url_args['utm_campaign'] = wc_clean( wp_unslash( $_GET['utm_campaign'] ) ); // phpcs:ignore WordPress.Security.NonceVerification.Recommended } return add_query_arg( $connect_url_args, admin_url( 'admin.php' ) ); } /** * Registers the REST routes for the featured products and product * previews endpoints. */ public static function register_rest_routes() { /* Used by the WooCommerce > Extensions > Discover page. */ register_rest_route( 'wc/v3', '/marketplace/featured', array( 'methods' => 'GET', 'callback' => array( __CLASS__, 'get_featured' ), 'permission_callback' => array( __CLASS__, 'get_permission' ), ) ); /* Used to show previews of products in a modal in in-app marketplace. */ register_rest_route( 'wc/v1', '/marketplace/product-preview', array( 'methods' => 'GET', 'callback' => array( __CLASS__, 'get_product_preview' ), 'permission_callback' => array( __CLASS__, 'get_permission' ), ) ); } /** * The Extensions page can only be accessed by users with the manage_woocommerce * capability. So the API mimics that behavior. */ public static function get_permission() { return current_user_can( 'manage_woocommerce' ); } /** * Fetch featured products from WooCommerce.com and serve them * as JSON. */ public static function get_featured() { $featured = WC_Admin_Addons::fetch_featured(); if ( is_wp_error( $featured ) ) { wp_send_json_error( array( 'message' => $featured->get_error_message() ) ); } wp_send_json( $featured ); } /** * Fetch data for product previews from WooCommerce.com. * * @param WP_REST_Request $request Request object. */ public static function get_product_preview( $request ) { $product_id = (int) $request->get_param( 'product_id' ); if ( ! $product_id ) { wp_send_json_error( array( 'message' => __( 'Missing product ID', 'woocommerce' ), ), 400 ); } $product_preview = WC_Admin_Addons::fetch_product_preview( $product_id ); if ( ! $product_preview ) { wp_send_json_error( array( 'message' => __( 'We couldn\'t find a preview for this product.', 'woocommerce' ), ), 404 ); } if ( is_wp_error( $product_preview ) ) { wp_send_json_error( array( 'message' => $product_preview->get_error_message(), ) ); } if ( ! isset( $product_preview['css'] ) || ! is_string( $product_preview['css'] ) || ! isset( $product_preview['html'] ) || ! is_string( $product_preview['html'] ) ) { wp_send_json_error( array( 'message' => __( 'API response is missing required elements, or they are in the wrong form.', 'woocommerce' ), ), 500 ); } $sanitized_product_preview = array( 'css' => WC_Helper_Sanitization::sanitize_css( $product_preview['css'] ), 'html' => WC_Helper_Sanitization::sanitize_html( $product_preview['html'] ), ); wp_send_json( $sanitized_product_preview ); } /** * Register the cache clearing tool on the WooCommerce > Status > Tools page. * * @param array $debug_tools Available debug tool registrations. * @return array Filtered debug tool registrations. */ public static function register_cache_clear_tool( $debug_tools ) { $debug_tools[ self::CACHE_TOOL_ID ] = array( 'name' => __( 'Clear WooCommerce.com cache', 'woocommerce' ), 'button' => __( 'Clear', 'woocommerce' ), 'desc' => sprintf( __( 'This tool will empty the WooCommerce.com data cache, used in WooCommerce Extensions.', 'woocommerce' ), ), 'callback' => array( __CLASS__, 'run_clear_cache_tool' ), ); return $debug_tools; } /** * "Clear" helper cache by invalidating it. */ public static function run_clear_cache_tool() { WC_Helper::_flush_subscriptions_cache(); WC_Helper::flush_product_usage_notice_rules_cache(); WC_Helper::flush_connection_data_cache(); WC_Helper_Updater::flush_updates_cache(); return __( 'Helper cache cleared.', 'woocommerce' ); } } WC_Helper_Admin::load();