2019-10-10 20:54:44 +00:00
< ? php
/**
* WooCommerce Admin Updates
*
* Functions for updating data , used by the background updater .
*
2020-08-11 19:18:47 +00:00
* @ package WooCommerce\Admin
2019-10-10 20:54:44 +00:00
*/
2022-02-17 19:14:23 +00:00
use Automattic\WooCommerce\Internal\Admin\Install as Installer ;
2021-10-08 21:01:12 +00:00
use \Automattic\WooCommerce\Admin\Features\OnboardingTasks\TaskLists ;
2020-09-28 04:35:10 +00:00
use \Automattic\WooCommerce\Admin\Notes\Notes ;
2022-03-08 13:55:27 +00:00
use \Automattic\WooCommerce\Internal\Admin\Notes\UnsecuredReportFiles ;
use \Automattic\WooCommerce\Internal\Admin\Notes\DeactivatePlugin ;
2021-09-21 19:06:49 +00:00
use \Automattic\WooCommerce\Admin\ReportExporter ;
2019-10-10 20:54:44 +00:00
/**
* Update order stats `status` index length .
* See : https :// github . com / woocommerce / woocommerce - admin / issues / 2969.
*/
function wc_admin_update_0201_order_status_index () {
global $wpdb ;
// Max DB index length. See wp_get_db_schema().
$max_index_length = 191 ;
$index = $wpdb -> get_row ( " SHOW INDEX FROM { $wpdb -> prefix } wc_order_stats WHERE key_name = 'status' " );
if ( property_exists ( $index , 'Sub_part' ) ) {
// The index was created with the right length. Time to bail.
if ( $max_index_length === $index -> Sub_part ) { // phpcs:ignore WordPress.NamingConventions.ValidVariableName
return ;
}
// We need to drop the index so it can be recreated.
$wpdb -> query ( " DROP INDEX `status` ON { $wpdb -> prefix } wc_order_stats " );
}
// Recreate the status index with a max length.
$wpdb -> query ( $wpdb -> prepare ( " ALTER TABLE { $wpdb -> prefix } wc_order_stats ADD INDEX status (status(%d)) " , $max_index_length ) );
}
/**
* Update DB Version .
*/
function wc_admin_update_0201_db_version () {
Installer :: update_db_version ( '0.20.1' );
}
2019-11-22 15:06:14 +00:00
/**
* Rename " gross_total " to " total_sales " .
* See : https :// github . com / woocommerce / woocommerce - admin / issues / 3175
*/
function wc_admin_update_0230_rename_gross_total () {
global $wpdb ;
// We first need to drop the new `total_sales` column, since dbDelta() will have created it.
$wpdb -> query ( " ALTER TABLE { $wpdb -> prefix } wc_order_stats DROP COLUMN `total_sales` " );
// Then we can rename the existing `gross_total` column.
$wpdb -> query ( " ALTER TABLE { $wpdb -> prefix } wc_order_stats CHANGE COLUMN `gross_total` `total_sales` double DEFAULT 0 NOT NULL " );
}
/**
* Update DB Version .
*/
function wc_admin_update_0230_db_version () {
Installer :: update_db_version ( '0.23.0' );
}
2020-02-20 11:59:02 +00:00
/**
* Remove the note unsnoozing scheduled action .
*/
function wc_admin_update_0251_remove_unsnooze_action () {
2020-09-28 04:35:10 +00:00
as_unschedule_action ( Notes :: UNSNOOZE_HOOK , null , 'wc-admin-data' );
as_unschedule_action ( Notes :: UNSNOOZE_HOOK , null , 'wc-admin-notes' );
2020-02-20 11:59:02 +00:00
}
/**
* Update DB Version .
*/
function wc_admin_update_0251_db_version () {
Installer :: update_db_version ( '0.25.1' );
}
2020-04-08 20:25:59 +00:00
/**
* Remove Facebook Extension note .
*/
function wc_admin_update_110_remove_facebook_note () {
2020-09-28 04:35:10 +00:00
Notes :: delete_notes_with_name ( 'wc-admin-facebook-extension' );
2020-04-08 20:25:59 +00:00
}
2020-05-08 19:35:06 +00:00
/**
* Update DB Version .
*/
function wc_admin_update_110_db_version () {
Installer :: update_db_version ( '1.1.0' );
}
2020-06-10 14:16:56 +00:00
/**
* Remove Dismiss action from tracking opt - in admin note .
*/
function wc_admin_update_130_remove_dismiss_action_from_tracking_opt_in_note () {
global $wpdb ;
$wpdb -> query ( " DELETE actions FROM { $wpdb -> prefix } wc_admin_note_actions actions INNER JOIN { $wpdb -> prefix } wc_admin_notes notes USING (note_id) WHERE actions.name = 'tracking-dismiss' AND notes.name = 'wc-admin-usage-tracking-opt-in' " );
}
2020-06-24 12:23:35 +00:00
/**
* Update DB Version .
*/
function wc_admin_update_130_db_version () {
Installer :: update_db_version ( '1.3.0' );
}
2020-07-08 00:15:00 +00:00
/**
* Change the deactivate plugin note type to 'info' .
*/
function wc_admin_update_140_change_deactivate_plugin_note_type () {
global $wpdb ;
2020-10-28 17:12:14 +00:00
$wpdb -> query ( $wpdb -> prepare ( " UPDATE { $wpdb -> prefix } wc_admin_notes SET type = 'info' WHERE name = %s " , DeactivatePlugin :: NOTE_NAME ) );
2020-07-08 00:15:00 +00:00
}
2020-07-16 16:08:40 +00:00
/**
* Update DB Version .
*/
function wc_admin_update_140_db_version () {
Installer :: update_db_version ( '1.4.0' );
}
2020-09-17 17:50:49 +00:00
/**
* Remove Facebook Experts note .
*/
function wc_admin_update_160_remove_facebook_note () {
2020-10-28 17:12:14 +00:00
Notes :: delete_notes_with_name ( 'wc-admin-facebook-marketing-expert' );
2020-09-17 17:50:49 +00:00
}
/**
* Update DB Version .
*/
function wc_admin_update_160_db_version () {
Installer :: update_db_version ( '1.6.0' );
}
2020-11-06 17:53:03 +00:00
/**
* Set " two column " homescreen layout as default for existing stores .
*/
function wc_admin_update_170_homescreen_layout () {
add_option ( 'woocommerce_default_homepage_layout' , 'two_columns' , '' , 'no' );
}
/**
* Update DB Version .
*/
function wc_admin_update_170_db_version () {
Installer :: update_db_version ( '1.7.0' );
}
2021-09-02 21:40:02 +00:00
2021-09-21 19:06:49 +00:00
/**
* Delete the preexisting export files .
*/
function wc_admin_update_270_delete_report_downloads () {
$upload_dir = wp_upload_dir ();
$base_dir = trailingslashit ( $upload_dir [ 'basedir' ] );
$failed_files = array ();
$exports_status = get_option ( ReportExporter :: EXPORT_STATUS_OPTION , array () );
$has_failure = false ;
if ( ! is_array ( $exports_status ) ) {
// This is essentially the same path as files failing deletion. Handle as such.
return ;
}
// Delete all export files based on the status option values.
foreach ( $exports_status as $key => $progress ) {
list ( $report_type , $export_id ) = explode ( ':' , $key );
if ( ! $export_id ) {
continue ;
}
$file = " { $base_dir } wc- { $report_type } -report-export- { $export_id } .csv " ;
$header = $file . '.headers' ;
// phpcs:ignore
if ( @ file_exists ( $file ) && false === @ unlink ( $file ) ) {
array_push ( $failed_files , $file );
}
// phpcs:ignore
if ( @ file_exists ( $header ) && false === @ unlink ( $header ) ) {
array_push ( $failed_files , $header );
}
}
// If the status option was missing or corrupt, there will be files left over.
$potential_exports = glob ( $base_dir . 'wc-*-report-export-*.csv' );
$reports_pattern = '(revenue|products|variations|orders|categories|coupons|taxes|stock|customers|downloads)' ;
/**
* Look for files we can be reasonably sure were created by the report export .
*
* Export files we created will match the 'wc-*-report-export-*.csv' glob , with
* the first wildcard being one of the exportable report slugs , and the second
* being an integer with 11 - 14 digits ( from microtime () ' s output ) that represents
* a time in the past .
*/
foreach ( $potential_exports as $potential_export ) {
$matches = array ();
// See if the filename matches an unfiltered export pattern.
if ( ! preg_match ( " /wc- { $reports_pattern } -report-export-(?P<export_id> \ d { 11,14}) \ .csv \$ / " , $potential_export , $matches ) ) {
$has_failure = true ;
continue ;
}
// Validate the timestamp (anything in the past).
$timestamp = ( int ) substr ( $matches [ 'export_id' ], 0 , 10 );
if ( ! $timestamp || $timestamp > time () ) {
$has_failure = true ;
continue ;
}
// phpcs:ignore
if ( false === @ unlink ( $potential_export ) ) {
array_push ( $failed_files , $potential_export );
}
}
// Try deleting failed files once more.
foreach ( $failed_files as $failed_file ) {
// phpcs:ignore
if ( false === @ unlink ( $failed_file ) ) {
$has_failure = true ;
}
}
if ( $has_failure ) {
UnsecuredReportFiles :: possibly_add_note ();
}
}
2021-09-02 21:40:02 +00:00
/**
* Update DB Version .
*/
function wc_admin_update_270_db_version () {
Installer :: update_db_version ( '2.7.0' );
}
2021-09-23 07:45:54 +00:00
2021-09-24 17:04:43 +00:00
/**
* Update the old task list options .
*/
function wc_admin_update_271_update_task_list_options () {
$hidden_lists = get_option ( 'woocommerce_task_list_hidden_lists' , array () );
$setup_list_hidden = get_option ( 'woocommerce_task_list_hidden' , 'no' );
$extended_list_hidden = get_option ( 'woocommerce_extended_task_list_hidden' , 'no' );
if ( 'yes' === $setup_list_hidden ) {
$hidden_lists [] = 'setup' ;
}
if ( 'yes' === $extended_list_hidden ) {
$hidden_lists [] = 'extended' ;
}
update_option ( 'woocommerce_task_list_hidden_lists' , array_unique ( $hidden_lists ) );
delete_option ( 'woocommerce_task_list_hidden' );
delete_option ( 'woocommerce_extended_task_list_hidden' );
}
/**
* Update DB Version .
*/
function wc_admin_update_271_db_version () {
Installer :: update_db_version ( '2.7.1' );
}
/**
* Update order stats `status` .
*/
2021-09-23 07:45:54 +00:00
function wc_admin_update_280_order_status () {
global $wpdb ;
$wpdb -> query (
" UPDATE { $wpdb -> prefix } wc_order_stats refunds
INNER JOIN { $wpdb -> prefix } wc_order_stats orders
ON orders . order_id = refunds . parent_id
SET refunds . status = orders . status
WHERE refunds . parent_id != 0 "
);
}
/**
* Update DB Version .
*/
function wc_admin_update_280_db_version () {
Installer :: update_db_version ( '2.8.0' );
}
2021-10-08 21:01:12 +00:00
/**
* Update the old task list options .
*/
function wc_admin_update_290_update_apperance_task_option () {
$is_actioned = get_option ( 'woocommerce_task_list_appearance_complete' , false );
$task = TaskLists :: get_task ( 'appearance' );
if ( $task && $is_actioned ) {
$task -> mark_actioned ();
}
delete_option ( 'woocommerce_task_list_appearance_complete' );
}
2021-11-29 21:04:34 +00:00
/**
* Delete the old woocommerce_default_homepage_layout option .
*/
function wc_admin_update_290_delete_default_homepage_layout_option () {
delete_option ( 'woocommerce_default_homepage_layout' );
}
2021-10-08 21:01:12 +00:00
/**
* Update DB Version .
*/
function wc_admin_update_290_db_version () {
Installer :: update_db_version ( '2.9.0' );
}
2021-11-25 01:44:30 +00:00
/**
* Use woocommerce_admin_activity_panel_inbox_last_read from the user meta to set wc_admin_notes . is_read col .
*/
function wc_admin_update_300_update_is_read_from_last_read () {
global $wpdb ;
$meta_key = 'woocommerce_admin_activity_panel_inbox_last_read' ;
// phpcs:ignore
$users = get_users ( " meta_key= { $meta_key } &orderby= { $meta_key } &fields=all_with_meta&number=1 " );
if ( count ( $users ) ) {
$last_read = current ( $users ) -> { $meta_key };
$date_in_utc = gmdate ( 'Y-m-d H:i:s' , intval ( $last_read ) / 1000 );
$wpdb -> query (
$wpdb -> prepare (
"
update { $wpdb -> prefix } wc_admin_notes set is_read = 1
where
date_created <= % s " ,
$date_in_utc
)
);
$wpdb -> query ( $wpdb -> prepare ( " delete from { $wpdb -> usermeta } where meta_key=%s " , $meta_key ) );
}
}
/**
* Update DB Version .
*/
function wc_admin_update_300_db_version () {
Installer :: update_db_version ( '3.0.0' );
}