2017-08-02 21:57:17 +00:00
< ? php
/**
* Class for displaying plugin warning notifications and determining 3 rd party plugin compatibility .
*
* @ package WooCommerce / Admin
* @ version 3.2 . 0
*/
2018-03-06 13:50:06 +00:00
2020-02-01 06:18:47 +00:00
use Automattic\Jetpack\Constants ;
2017-08-02 21:57:17 +00:00
if ( ! defined ( 'ABSPATH' ) ) {
exit ;
}
/**
* WC_Admin_Plugin_Updates Class .
*/
class WC_Plugin_Updates {
/**
* This is the header used by extensions to show requirements .
2018-03-05 18:59:17 +00:00
*
2017-08-02 21:57:17 +00:00
* @ var string
*/
const VERSION_REQUIRED_HEADER = 'WC requires at least' ;
/**
* This is the header used by extensions to show testing .
2018-03-05 18:59:17 +00:00
*
2017-08-02 21:57:17 +00:00
* @ var string
*/
const VERSION_TESTED_HEADER = 'WC tested up to' ;
/**
* The version for the update to WooCommerce .
2018-03-05 18:59:17 +00:00
*
2017-08-02 21:57:17 +00:00
* @ var string
*/
protected $new_version = '' ;
/**
* Array of plugins lacking testing with the major version .
2018-03-05 18:59:17 +00:00
*
2017-08-02 21:57:17 +00:00
* @ var array
*/
protected $major_untested_plugins = array ();
/**
* Array of plugins lacking testing with the minor version .
2018-03-05 18:59:17 +00:00
*
2017-08-02 21:57:17 +00:00
* @ var array
*/
protected $minor_untested_plugins = array ();
/**
* Common JS for initializing and managing thickbox - based modals .
*/
protected function generic_modal_js () {
?>
< script >
( function ( $ ) {
// Initialize thickbox.
tb_init ( '.wc-thickbox' );
var old_tb_position = false ;
// Make the WC thickboxes look good when opened.
$ ( '.wc-thickbox' ) . on ( 'click' , function ( evt ) {
var $overlay = $ ( '#TB_overlay' );
if ( ! $overlay . length ) {
$ ( 'body' ) . append ( '<div id="TB_overlay"></div><div id="TB_window" class="wc_untested_extensions_modal_container"></div>' );
} else {
$ ( '#TB_window' ) . removeClass ( 'thickbox-loading' ) . addClass ( 'wc_untested_extensions_modal_container' );
}
// WP overrides the tb_position function. We need to use a different tb_position function than that one.
// This is based on the original tb_position.
if ( ! old_tb_position ) {
old_tb_position = tb_position ;
}
tb_position = function () {
$ ( '#TB_window' ) . css ( { marginLeft : '-' + parseInt ( ( TB_WIDTH / 2 ), 10 ) + 'px' , width : TB_WIDTH + 'px' } );
$ ( '#TB_window' ) . css ( { marginTop : '-' + parseInt ( ( TB_HEIGHT / 2 ), 10 ) + 'px' } );
};
});
// Reset tb_position to WP default when modal is closed.
$ ( 'body' ) . on ( 'thickbox:removed' , function () {
if ( old_tb_position ) {
tb_position = old_tb_position ;
}
});
})( jQuery );
</ script >
< ? php
}
/*
|--------------------------------------------------------------------------
| Message Helpers
|--------------------------------------------------------------------------
|
| Methods for getting messages .
*/
/**
* Get the inline warning notice for minor version updates .
*
* @ return string
*/
protected function get_extensions_inline_warning_minor () {
$upgrade_type = 'minor' ;
$plugins = ! empty ( $this -> major_untested_plugins ) ? array_diff_key ( $this -> minor_untested_plugins , $this -> major_untested_plugins ) : $this -> minor_untested_plugins ;
$version_parts = explode ( '.' , $this -> new_version );
$new_version = $version_parts [ 0 ] . '.' . $version_parts [ 1 ];
if ( empty ( $plugins ) ) {
return ;
}
/* translators: %s: version number */
2017-08-21 14:53:08 +00:00
$message = sprintf ( __ ( " <strong>Heads up!</strong> The versions of the following plugins you're running haven't been tested with the latest version of WooCommerce (%s). " , 'woocommerce' ), $new_version );
2017-08-02 21:57:17 +00:00
ob_start ();
2018-03-05 18:59:17 +00:00
include 'views/html-notice-untested-extensions-inline.php' ;
2017-08-02 21:57:17 +00:00
return ob_get_clean ();
}
/**
* Get the inline warning notice for major version updates .
*
* @ return string
*/
protected function get_extensions_inline_warning_major () {
$upgrade_type = 'major' ;
$plugins = $this -> major_untested_plugins ;
$version_parts = explode ( '.' , $this -> new_version );
$new_version = $version_parts [ 0 ] . '.0' ;
if ( empty ( $plugins ) ) {
return ;
}
/* translators: %s: version number */
2017-08-21 14:53:08 +00:00
$message = sprintf ( __ ( " <strong>Heads up!</strong> The versions of the following plugins you're running haven't been tested with WooCommerce %s. Please update them or confirm compatibility before updating WooCommerce, or you may experience issues: " , 'woocommerce' ), $new_version );
2017-08-02 21:57:17 +00:00
ob_start ();
2018-03-05 18:59:17 +00:00
include 'views/html-notice-untested-extensions-inline.php' ;
2017-08-02 21:57:17 +00:00
return ob_get_clean ();
}
/**
* Get the warning notice for the modal window .
*
* @ return string
*/
protected function get_extensions_modal_warning () {
$version_parts = explode ( '.' , $this -> new_version );
$new_version = $version_parts [ 0 ] . '.0' ;
$plugins = $this -> major_untested_plugins ;
ob_start ();
2018-03-05 18:59:17 +00:00
include 'views/html-notice-untested-extensions-modal.php' ;
2017-08-02 21:57:17 +00:00
return ob_get_clean ();
}
/*
|--------------------------------------------------------------------------
| Data Helpers
|--------------------------------------------------------------------------
|
| Methods for getting & manipulating data .
*/
/**
* Get active plugins that have a tested version lower than the input version .
*
2020-01-31 20:05:50 +00:00
* In case of testing major version compatibility and if current WC version is >= major version part
* of the $new_version , no plugins are returned , even if they don ' t explicitly declare compatibility
* with the $new_version .
*
2018-03-06 13:50:06 +00:00
* @ param string $new_version WooCommerce version to test against .
2017-08-02 21:57:17 +00:00
* @ param string $release 'major' or 'minor' .
* @ return array of plugin info arrays
*/
2017-10-17 15:27:55 +00:00
public function get_untested_plugins ( $new_version , $release ) {
$extensions = array_merge ( $this -> get_plugins_with_header ( self :: VERSION_TESTED_HEADER ), $this -> get_plugins_for_woocommerce () );
$untested = array ();
$new_version_parts = explode ( '.' , $new_version );
$version = $new_version_parts [ 0 ];
2017-08-02 21:57:17 +00:00
if ( 'minor' === $release ) {
2017-10-17 15:27:55 +00:00
$version .= '.' . $new_version_parts [ 1 ];
}
if ( 'major' === $release ) {
2020-02-01 06:18:47 +00:00
$current_version_parts = explode ( '.' , Constants :: get_constant ( 'WC_VERSION' ) );
2017-10-17 15:27:55 +00:00
// If user has already moved to the major version, we don't need to flag up anything.
if ( version_compare ( $current_version_parts [ 0 ] . '.' . $current_version_parts [ 1 ], $new_version_parts [ 0 ] . '.0' , '>=' ) ) {
return array ();
}
2017-08-02 21:57:17 +00:00
}
foreach ( $extensions as $file => $plugin ) {
2017-08-08 16:12:50 +00:00
if ( ! empty ( $plugin [ self :: VERSION_TESTED_HEADER ] ) ) {
$plugin_version_parts = explode ( '.' , $plugin [ self :: VERSION_TESTED_HEADER ] );
if ( ! is_numeric ( $plugin_version_parts [ 0 ] )
|| ( 'minor' === $release && ! isset ( $plugin_version_parts [ 1 ] ) )
|| ( 'minor' === $release && ! is_numeric ( $plugin_version_parts [ 1 ] ) )
) {
continue ;
}
$plugin_version = $plugin_version_parts [ 0 ];
if ( 'minor' === $release ) {
$plugin_version .= '.' . $plugin_version_parts [ 1 ];
}
2017-08-21 14:53:08 +00:00
if ( version_compare ( $plugin_version , $version , '<' ) ) {
2017-08-08 16:12:50 +00:00
$untested [ $file ] = $plugin ;
}
} else {
$plugin [ self :: VERSION_TESTED_HEADER ] = __ ( 'unknown' , 'woocommerce' );
2018-03-05 18:59:17 +00:00
$untested [ $file ] = $plugin ;
2017-08-02 21:57:17 +00:00
}
}
return $untested ;
}
/**
* Get plugins that have a valid value for a specific header .
*
2018-03-06 13:50:06 +00:00
* @ param string $header Plugin header to search for .
* @ return array Array of plugins that contain the searched header .
2017-08-02 21:57:17 +00:00
*/
protected function get_plugins_with_header ( $header ) {
$plugins = get_plugins ();
$matches = array ();
foreach ( $plugins as $file => $plugin ) {
if ( ! empty ( $plugin [ $header ] ) ) {
$matches [ $file ] = $plugin ;
}
}
2017-08-07 21:31:58 +00:00
return apply_filters ( 'woocommerce_get_plugins_with_header' , $matches , $header , $plugins );
2017-08-02 21:57:17 +00:00
}
2017-08-08 16:12:50 +00:00
/**
* Get plugins which " maybe " are for WooCommerce .
*
* @ return array of plugin info arrays
*/
protected function get_plugins_for_woocommerce () {
$plugins = get_plugins ();
$matches = array ();
foreach ( $plugins as $file => $plugin ) {
2018-03-06 13:50:06 +00:00
if ( 'WooCommerce' !== $plugin [ 'Name' ] && ( stristr ( $plugin [ 'Name' ], 'woocommerce' ) || stristr ( $plugin [ 'Description' ], 'woocommerce' ) ) ) {
2017-08-08 16:12:50 +00:00
$matches [ $file ] = $plugin ;
}
}
return apply_filters ( 'woocommerce_get_plugins_for_woocommerce' , $matches , $plugins );
}
2017-08-02 21:57:17 +00:00
}