WC_Woo_Helper_Connection{}
WC_Helper_Plugin Class
Contains the logic to manage WooCommerce.com Helper Connection.
No Hooks.
Usage
$WC_Woo_Helper_Connection = new WC_Woo_Helper_Connection(); // use class methods
Methods
- public static get_connection_url_notice()
- public static get_deleted_connection_notice()
- public static has_host_plan_orders()
WC_Woo_Helper_Connection{} WC Woo Helper Connection{} code WC 10.7.0
class WC_Woo_Helper_Connection {
/**
* Get the notice for the connection URL mismatch.
*
* @return string The notice for the connection URL mismatch.
*/
public static function get_connection_url_notice(): string {
$connection_data = WC_Helper::get_cached_connection_data();
if ( false === $connection_data || ! empty( $connection_data['maybe_deleted_connection'] ) || false === ( $connection_data['alert_url_mismatch'] ?? false ) ) {
return '';
}
$auth = WC_Helper_Options::get( 'auth' );
$url_raw = is_array( $auth ) ? ( $auth['url'] ?? '' ) : '';
$url = esc_html( rtrim( $url_raw, '/' ) );
$home_url = esc_html( rtrim( home_url(), '/' ) );
if ( empty( $url ) || $home_url === $url ) {
return '';
}
return sprintf(
/* translators: 1: WooCommerce.com connection URL, 2: home URL */
__( 'Your site is currently connected to WooCommerce.com using <b>%1$s</b>, but your actual site URL is <b>%2$s</b>. To fix this, please reconnect your site to <b>WooCommerce.com</b> to ensure everything works correctly.', 'woocommerce' ),
$url,
$home_url
);
}
/**
* Get the notice for a deleted connection on WCCOM
*
* @return string The notice for a deleted connection on WCCOM.
*
* @since 10.6.0
*/
public static function get_deleted_connection_notice(): string {
$connection_data = WC_Helper::get_cached_connection_data();
if ( false === $connection_data || empty( $connection_data['maybe_deleted_connection'] ) ) {
return '';
}
$home_url = esc_html( rtrim( home_url(), '/' ) );
return sprintf(
/* translators: 1: home URL */
__( 'There is no connection for <b>%1$s</b> on WooCommerce.com. The connection may have been deleted. To fix this, please reconnect your site to <b>WooCommerce.com</b> to ensure everything works correctly.', 'woocommerce' ),
$home_url
);
}
/**
* Check if the site has and linked host-plan orders.
*
* @return bool
*/
public static function has_host_plan_orders(): bool {
$subscriptions = WC_Helper::get_subscriptions();
foreach ( $subscriptions as $subscription ) {
if ( isset( $subscription['included_in_host_plan'] ) && true === (bool) $subscription['included_in_host_plan'] ) {
return true;
}
}
return false;
}
}