Forum Replies Created

Viewing 8 replies - 1 through 8 (of 8 total)
  • Forum: Plugins
    In reply to: [WooCommerce] Fatal error
    Thread Starter epoirriez

    (@epoirriez)

    Hi.

    First of all : thanks a lot.
    In fact, my browser cache is still runing, when i use an other one, link is ok,
    i will restart my Firefox,

    thanks again.

    Forum: Plugins
    In reply to: [WooCommerce] Fatal error
    Thread Starter epoirriez

    (@epoirriez)

    I wasn’y clear enough : i enable all plugins now and i have no more fatal error, may be after Forminator update, i don’t know really, but with all plugins activated, no more fatal error, but nothing more to https://www.poirriez.com/boutique/, no more link to this pager

    Forum: Plugins
    In reply to: [WooCommerce] Fatal error
    Thread Starter epoirriez

    (@epoirriez)

    Ok, i tested,
    Now it comes back without Fatal error, but my shop page doesn’t work anymore :
    https://www.poirriez.com/boutique/
    No more link working to this page…

    Forum: Plugins
    In reply to: [WooCommerce] Fatal error
    Thread Starter epoirriez

    (@epoirriez)

    Hi
    And https://www.poirriez.com/boutique/ doesn’t link anymore to my shop

    Forum: Plugins
    In reply to: [WooCommerce] Fatal error
    Thread Starter epoirriez

    (@epoirriez)

    I have now :

    2022-06-02T09:23:46+02:00 CRITICAL Uncaught Error: Failed opening required '/home/poirrii/www/wp-content/plugins/jetpack/_inc/lib/core-api/class.jetpack-core-api-module-endpoints.php' (include_path='.:/usr/local/php8.1/lib/php') in /home/poirrii/www/wp-content/plugins/jetpack/_inc/lib/class.core-rest-api-endpoints.php:57
    Stack trace:
    #0 /home/poirrii/www/wp-includes/class-wp-hook.php(307): Jetpack_Core_Json_Api_Endpoints::register_endpoints(Object(WP_REST_Server))
    #1 /home/poirrii/www/wp-includes/class-wp-hook.php(331): WP_Hook->apply_filters(NULL, Array)
    #2 /home/poirrii/www/wp-includes/plugin.php(476): WP_Hook->do_action(Array)
    #3 /home/poirrii/www/wp-includes/rest-api.php(561): do_action('rest_api_init', Object(WP_REST_Server))
    #4 /home/poirrii/www/wp-includes/rest-api.php(387): rest_get_server()
    #5 /home/poirrii/www/wp-includes/class-wp-hook.php(307): rest_api_loaded(Object(WP))
    #6 /home/poirrii/www/wp-includes/class-wp-hook.php(331): WP_Hook->apply_filters(NULL, Array)
    #7 /home/poirrii/www/wp-includes/plugin.php(524): WP_Hook->do_action(Array)
    #8 /home/poirrii/www/wp-includes/class-wp.php(398): do_action_ref_array('parse_request', Array)
    #9 /home/poirrii/www/wp-includes/class-wp.php(770): WP->parse_request('')
    #10 /home/poirrii/www/wp-includes/functions.php(1330): WP->main('')
    #11 /home/poirrii/www/wp-blog-header.php(16): wp()
    #12 /home/poirrii/www/index.php(17): require('/home/poirrii/w...')
    #13 {main}
      thrown dans /home/poirrii/www/wp-content/plugins/jetpack/_inc/lib/class.core-rest-api-endpoints.php à la ligne 57
    
    2022-06-02T09:25:40+02:00 CRITICAL Uncaught Error: Failed opening required '/home/poirrii/www/wp-content/plugins/woocommerce/src/Internal/Admin/Notes/WooSubscriptionsNotes.php' (include_path='.:/usr/local/php8.1/lib/php') in /home/poirrii/www/wp-content/plugins/jetpack/vendor/jetpack-autoloader/class-php-autoloader.php:90
    Stack trace:
    #0 /home/poirrii/www/wp-content/plugins/woocommerce/src/Internal/Admin/FeaturePlugin.php(164): Automattic\Jetpack\Autoloader\jpf11009ded9fc4592b6a05b61ce272b3c_jetpack?10_9_1\PHP_Autoloader::load_class('Automattic\\WooC...')
    #1 /home/poirrii/www/wp-content/plugins/woocommerce/src/Internal/Admin/FeaturePlugin.php(103): Automattic\WooCommerce\Internal\Admin\FeaturePlugin->includes()
    #2 /home/poirrii/www/wp-content/plugins/woocommerce/src/Internal/Admin/FeaturePlugin.php(86): Automattic\WooCommerce\Internal\Admin\FeaturePlugin->on_plugins_loaded()
    #3 /home/poirrii/www/wp-content/plugins/woocommerce/src/Admin/Composer/Package.php(65): Automattic\WooCommerce\Internal\Admin\FeaturePlugin->init()
    #4 /home/poirrii/www/wp-content/plugins/woocommerce/src/Packages.php(64): Automattic\WooCommerce\Admin\Composer\Package::init()
    #5 /home/poirrii/www/wp-content/plugins/woocommerce/src/Packages.php(44): Automattic\WooCommerce\Packages::load_packages()
    #6 /home/poirrii/www/wp-includes/class-wp-hook.php(307): Automattic\WooCommerce\Packages::on_init('')
    #7 /home/poirrii/www/wp-includes/class-wp-hook.php(331): WP_Hook->apply_filters(NULL, Array)
    #8 /home/poirrii/www/wp-includes/plugin.php(476): WP_Hook->do_action(Array)
    #9 /home/poirrii/www/wp-settings.php(461): do_action('plugins_loaded')
    #10 /home/poirrii/www/wp-config.php(92): require_once('/home/poirrii/w...')
    #11 /home/poirrii/www/wp-load.php(50): require_once('/home/poirrii/w...')
    #12 /home/poirrii/www/wp-blog-header.php(13): require_once('/home/poirrii/w...')
    #13 /home/poirrii/www/index.php(17): require('/home/poirrii/w...')
    #14 {main}
      thrown dans /home/poirrii/www/wp-content/plugins/jetpack/vendor/jetpack-autoloader/class-php-autoloader.php à la ligne 90
    Forum: Plugins
    In reply to: [WooCommerce] Fatal error
    Thread Starter epoirriez

    (@epoirriez)

    Hi again.
    I have the Woocommerce Log :

    2022-05-10T05:33:44+00:00 CRITICAL Uncaught Error: Class 'WooCommerce\PayPalCommerce\Webhooks\WebhookInfoStorage' not found in /home/poirrii/www/wp-content/plugins/woocommerce-paypal-payments/modules/ppcp-webhooks/services.php:197
    Stack trace:
    #0 /home/poirrii/www/wp-content/plugins/woocommerce-paypal-payments/vendor/dhii/containers/src/DelegatingContainer.php(117): WooCommerce\PayPalCommerce\Webhooks\WebhookModule::WooCommerce\PayPalCommerce\Webhooks\{closure}(Object(Dhii\Container\DelegatingContainer))
    #1 /home/poirrii/www/wp-content/plugins/woocommerce-paypal-payments/vendor/dhii/containers/src/DelegatingContainer.php(56): Dhii\Container\DelegatingContainer->invokeFactory(Object(Closure))
    #2 /home/poirrii/www/wp-content/plugins/woocommerce-paypal-payments/modules/ppcp-webhooks/services.php(55): Dhii\Container\DelegatingContainer->get('webhook.last-we...')
    #3 /home/poirrii/www/wp-content/plugins/woocommerce-paypal-payments/vendor/dhii/containers/src/DelegatingContainer.php(117): WooCommerce\PayPalCommerce\Webhooks\WebhookModule->WooCommerce\ dans /home/poirrii/www/wp-content/plugins/woocommerce-paypal-payments/modules/ppcp-webhooks/services.php à la ligne 197

    And this :

    fatal-errors-2022-05-26-205c40520957c0339bb107762f75a379.log Effacer le journal
    
    2022-05-26T11:06:26+02:00 CRITICAL Uncaught Error: Class "ProteusThemes\WPContentImporter2\WXRImporter" not found in /home/poirrii/www/wp-content/plugins/colibri-page-builder/src/OCDI/WXRImporter.php:12
    Stack trace:
    #0 /home/poirrii/www/wp-content/plugins/colibri-page-builder/vendor/composer/ClassLoader.php(444): include()
    #1 /home/poirrii/www/wp-content/plugins/colibri-page-builder/vendor/composer/ClassLoader.php(322): Composer\Autoload\includeFile('/home/poirrii/w...')
    #2 /home/poirrii/www/wp-content/plugins/colibri-page-builder/src/OCDI/Importer.php(48): Composer\Autoload\ClassLoader->loadClass('ColibriWP\\PageB...')
    #3 /home/poirrii/www/wp-content/plugins/colibri-page-builder/src/OCDI/OneClickDemoImport.php(541): ColibriWP\PageBuilder\OCDI\Importer->__construct(Array, Object(ColibriWP\PageBuilder\OCDI\Logger))
    #4 /home/poirrii/www/wp-includes/class-wp-hook.php(307): ColibriWP\PageBuilder\OCDI\OneClickDemoImport->setup_plugin_with_filter_data('')
    #5 /home/poirrii/www/wp-includes/class-wp-hook.php(331): WP_Hook->apply_filters(NULL, Array)
    #6 /home/poirrii/www/wp-includes/plugin.php(474): WP_Hook->do_action(Array)
    #7 /home/poirrii/www/wp-settings.php(565): do_action('after_setup_the...')
    #8 /home/poirrii/www/wp-config.php(92): require_once('/home/poirrii/w...')
    #9 /home/poirrii/www/wp-load.php(50): require_once('/home/poirrii/w...')
    #10 /home/poirrii/www/wp-blog-header.php(13): require_once('/home/poirrii/w...')
    #11 /home/poirrii/www/index.php(17): require('/home/poirrii/w...')
    #12 {main}
      thrown dans /home/poirrii/www/wp-content/plugins/colibri-page-builder/src/OCDI/WXRImporter.php à la ligne 12
    
    2022-05-26T11:06:41+02:00 CRITICAL Uncaught Error: Class "Forminator_Admin_AJAX" not found in /home/poirrii/www/wp-content/plugins/forminator/admin/classes/class-admin.php:50
    Stack trace:
    #0 /home/poirrii/www/wp-content/plugins/forminator/library/class-core.php(81): Forminator_Admin->__construct()
    #1 /home/poirrii/www/wp-content/plugins/forminator/library/class-core.php(61): Forminator_Core->__construct()
    #2 /home/poirrii/www/wp-content/plugins/forminator/forminator.php(403): Forminator_Core::get_instance()
    #3 /home/poirrii/www/wp-content/plugins/forminator/forminator.php(138): Forminator->init()
    #4 /home/poirrii/www/wp-content/plugins/forminator/forminator.php(116): Forminator->__construct()
    #5 /home/poirrii/www/wp-content/plugins/forminator/forminator.php(540): Forminator::get_instance()
    #6 /home/poirrii/www/wp-includes/class-wp-hook.php(307): forminator('')
    #7 /home/poirrii/www/wp-includes/class-wp-hook.php(331): WP_Hook->apply_filters(NULL, Array)
    #8 /home/poirrii/www/wp-includes/plugin.php(474): WP_Hook->do_action(Array)
    #9 /home/poirrii/www/wp-settings.php(450): do_action('plugins_loaded')
    #10 /home/poirrii/www/wp-config.php(92): require_once('/home/poirrii/w...')
    #11 /home/poirrii/www/wp-load.php(50): require_once('/home/poirrii/w...')
    #12 /home/poirrii/www/wp-admin/admin-ajax.php(22): require_once('/home/poirrii/w...')
    #13 {main}
      thrown dans /home/poirrii/www/wp-content/plugins/forminator/admin/classes/class-admin.php à la ligne 50
    Forum: Plugins
    In reply to: [WooCommerce] Fatal error
    Thread Starter epoirriez

    (@epoirriez)

    Hi, i am in debug mode in WordPress and i had this :

    Une bo?te à outils eCommerce qui vous aide à tout vendre. Magnifiquement.
    Version 6.5.1 | Par Automattic | Afficher les détails
    
    Cette extension n’a pas pu se charger correctement et a été mise en pause dans le cadre du mode de récupération.
    
    Une erreur de type E_ERROR a été causée dans la ligne 332 du fichier /home/poirrii/www/wp-content/plugins/woocommerce/src/Admin/API/Reports/TimeInterval.php. Message d’erreur : Maximum execution time of 165 seconds exceeded

    Here is the Timeinterval.php :

    <?php
    /**
     * Class for time interval and numeric range handling for reports.
     */
    
    namespace Automattic\WooCommerce\Admin\API\Reports;
    
    defined( 'ABSPATH' ) || exit;
    
    /**
     * Date & time interval and numeric range handling class for Reporting API.
     */
    class TimeInterval {
    
    	/**
    	 * Format string for ISO DateTime formatter.
    	 *
    	 * @var string
    	 */
    	public static $iso_datetime_format = 'Y-m-d\TH:i:s';
    
    	/**
    	 * Format string for use in SQL queries.
    	 *
    	 * @var string
    	 */
    	public static $sql_datetime_format = 'Y-m-d H:i:s';
    
    	/**
    	 * Converts local datetime to GMT/UTC time.
    	 *
    	 * @param string $datetime_string String representation of local datetime.
    	 * @return DateTime
    	 */
    	public static function convert_local_datetime_to_gmt( $datetime_string ) {
    		$datetime = new \DateTime( $datetime_string, new \DateTimeZone( wc_timezone_string() ) );
    		$datetime->setTimezone( new \DateTimeZone( 'GMT' ) );
    		return $datetime;
    	}
    
    	/**
    	 * Returns default 'before' parameter for the reports.
    	 *
    	 * @return DateTime
    	 */
    	public static function default_before() {
    		$datetime = new \WC_DateTime();
    		// Set local timezone or offset.
    		if ( get_option( 'timezone_string' ) ) {
    			$datetime->setTimezone( new \DateTimeZone( wc_timezone_string() ) );
    		} else {
    			$datetime->set_utc_offset( wc_timezone_offset() );
    		}
    		return $datetime;
    	}
    
    	/**
    	 * Returns default 'after' parameter for the reports.
    	 *
    	 * @return DateTime
    	 */
    	public static function default_after() {
    		$now       = time();
    		$week_back = $now - WEEK_IN_SECONDS;
    
    		$datetime = new \WC_DateTime();
    		$datetime->setTimestamp( $week_back );
    		// Set local timezone or offset.
    		if ( get_option( 'timezone_string' ) ) {
    			$datetime->setTimezone( new \DateTimeZone( wc_timezone_string() ) );
    		} else {
    			$datetime->set_utc_offset( wc_timezone_offset() );
    		}
    		return $datetime;
    	}
    
    	/**
    	 * Returns date format to be used as grouping clause in SQL.
    	 *
    	 * @param string $time_interval Time interval.
    	 * @param string $table_name Name of the db table relevant for the date constraint.
    	 * @return mixed
    	 */
    	public static function db_datetime_format( $time_interval, $table_name ) {
    		$first_day_of_week = absint( get_option( 'start_of_week' ) );
    
    		if ( 1 === $first_day_of_week ) {
    			// Week begins on Monday, ISO 8601.
    			$week_format = "DATE_FORMAT({$table_name}.date_created, '%x-%v')";
    		} else {
    			// Week begins on day other than specified by ISO 8601, needs to be in sync with function simple_week_number.
    			$week_format = "CONCAT(YEAR({$table_name}.date_created), '-', LPAD( FLOOR( ( DAYOFYEAR({$table_name}.date_created) + ( ( DATE_FORMAT(MAKEDATE(YEAR({$table_name}.date_created),1), '%w') - $first_day_of_week + 7 ) % 7 ) - 1 ) / 7  ) + 1 , 2, '0'))";
    
    		}
    
    		// Whenever this is changed, double check method time_interval_id to make sure they are in sync.
    		$mysql_date_format_mapping = array(
    			'hour'    => "DATE_FORMAT({$table_name}.date_created, '%Y-%m-%d %H')",
    			'day'     => "DATE_FORMAT({$table_name}.date_created, '%Y-%m-%d')",
    			'week'    => $week_format,
    			'month'   => "DATE_FORMAT({$table_name}.date_created, '%Y-%m')",
    			'quarter' => "CONCAT(YEAR({$table_name}.date_created), '-', QUARTER({$table_name}.date_created))",
    			'year'    => "YEAR({$table_name}.date_created)",
    
    		);
    
    		return $mysql_date_format_mapping[ $time_interval ];
    	}
    
    	/**
    	 * Returns quarter for the DateTime.
    	 *
    	 * @param DateTime $datetime Local date & time.
    	 * @return int|null
    	 */
    	public static function quarter( $datetime ) {
    		switch ( (int) $datetime->format( 'm' ) ) {
    			case 1:
    			case 2:
    			case 3:
    				return 1;
    			case 4:
    			case 5:
    			case 6:
    				return 2;
    			case 7:
    			case 8:
    			case 9:
    				return 3;
    			case 10:
    			case 11:
    			case 12:
    				return 4;
    
    		}
    		return null;
    	}
    
    	/**
    	 * Returns simple week number for the DateTime, for week starting on $first_day_of_week.
    	 *
    	 * The first week of the year is considered to be the week containing January 1.
    	 * The second week starts on the next $first_day_of_week.
    	 *
    	 * @param DateTime $datetime          Local date for which the week number is to be calculated.
    	 * @param int      $first_day_of_week 0 for Sunday to 6 for Saturday.
    	 * @return int
    	 */
    	public static function simple_week_number( $datetime, $first_day_of_week ) {
    		$beg_of_year_day          = new \DateTime( "{$datetime->format('Y')}-01-01" );
    		$adj_day_beg_of_year      = ( (int) $beg_of_year_day->format( 'w' ) - $first_day_of_week + 7 ) % 7;
    		$days_since_start_of_year = (int) $datetime->format( 'z' ) + 1;
    
    		return (int) floor( ( ( $days_since_start_of_year + $adj_day_beg_of_year - 1 ) / 7 ) ) + 1;
    	}
    
    	/**
    	 * Returns ISO 8601 week number for the DateTime, if week starts on Monday,
    	 * otherwise returns simple week number.
    	 *
    	 * @see TimeInterval::simple_week_number()
    	 *
    	 * @param DateTime $datetime          Local date for which the week number is to be calculated.
    	 * @param int      $first_day_of_week 0 for Sunday to 6 for Saturday.
    	 * @return int
    	 */
    	public static function week_number( $datetime, $first_day_of_week ) {
    		if ( 1 === $first_day_of_week ) {
    			$week_number = (int) $datetime->format( 'W' );
    		} else {
    			$week_number = self::simple_week_number( $datetime, $first_day_of_week );
    		}
    		return $week_number;
    	}
    
    	/**
    	 * Returns time interval id for the DateTime.
    	 *
    	 * @param string   $time_interval Time interval type (week, day, etc).
    	 * @param DateTime $datetime      Date & time.
    	 * @return string
    	 */
    	public static function time_interval_id( $time_interval, $datetime ) {
    		// Whenever this is changed, double check method db_datetime_format to make sure they are in sync.
    		$php_time_format_for = array(
    			'hour'    => 'Y-m-d H',
    			'day'     => 'Y-m-d',
    			'week'    => 'o-W',
    			'month'   => 'Y-m',
    			'quarter' => 'Y-' . self::quarter( $datetime ),
    			'year'    => 'Y',
    		);
    
    		// If the week does not begin on Monday.
    		$first_day_of_week = absint( get_option( 'start_of_week' ) );
    
    		if ( 'week' === $time_interval && 1 !== $first_day_of_week ) {
    			$week_no = self::simple_week_number( $datetime, $first_day_of_week );
    			$week_no = str_pad( $week_no, 2, '0', STR_PAD_LEFT );
    			$year_no = $datetime->format( 'Y' );
    			return "$year_no-$week_no";
    		}
    
    		return $datetime->format( $php_time_format_for[ $time_interval ] );
    	}
    
    	/**
    	 * Calculates number of time intervals between two dates, closed interval on both sides.
    	 *
    	 * @param DateTime $start_datetime Start date & time.
    	 * @param DateTime $end_datetime End date & time.
    	 * @param string   $interval Time interval increment, e.g. hour, day, week.
    	 *
    	 * @return int
    	 */
    	public static function intervals_between( $start_datetime, $end_datetime, $interval ) {
    		switch ( $interval ) {
    			case 'hour':
    				$end_timestamp   = (int) $end_datetime->format( 'U' );
    				$start_timestamp = (int) $start_datetime->format( 'U' );
    				$addendum        = 0;
    				// modulo HOUR_IN_SECONDS would normally work, but there are non-full hour timezones, e.g. Nepal.
    				$start_min_sec = (int) $start_datetime->format( 'i' ) * MINUTE_IN_SECONDS + (int) $start_datetime->format( 's' );
    				$end_min_sec   = (int) $end_datetime->format( 'i' ) * MINUTE_IN_SECONDS + (int) $end_datetime->format( 's' );
    				if ( $end_min_sec < $start_min_sec ) {
    					$addendum = 1;
    				}
    				$diff_timestamp = $end_timestamp - $start_timestamp;
    
    				return (int) floor( ( (int) $diff_timestamp ) / HOUR_IN_SECONDS ) + 1 + $addendum;
    			case 'day':
    				$end_timestamp      = (int) $end_datetime->format( 'U' );
    				$start_timestamp    = (int) $start_datetime->format( 'U' );
    				$addendum           = 0;
    				$end_hour_min_sec   = (int) $end_datetime->format( 'H' ) * HOUR_IN_SECONDS + (int) $end_datetime->format( 'i' ) * MINUTE_IN_SECONDS + (int) $end_datetime->format( 's' );
    				$start_hour_min_sec = (int) $start_datetime->format( 'H' ) * HOUR_IN_SECONDS + (int) $start_datetime->format( 'i' ) * MINUTE_IN_SECONDS + (int) $start_datetime->format( 's' );
    				if ( $end_hour_min_sec < $start_hour_min_sec ) {
    					$addendum = 1;
    				}
    				$diff_timestamp = $end_timestamp - $start_timestamp;
    
    				return (int) floor( ( (int) $diff_timestamp ) / DAY_IN_SECONDS ) + 1 + $addendum;
    			case 'week':
    				// @todo Optimize? approximately day count / 7, but year end is tricky, a week can have fewer days.
    				$week_count = 0;
    				do {
    					$start_datetime = self::next_week_start( $start_datetime );
    					$week_count++;
    				} while ( $start_datetime <= $end_datetime );
    				return $week_count;
    			case 'month':
    				// Year diff in months: (end_year - start_year - 1) * 12.
    				$year_diff_in_months = ( (int) $end_datetime->format( 'Y' ) - (int) $start_datetime->format( 'Y' ) - 1 ) * 12;
    				// All the months in end_date year plus months from X to 12 in the start_date year.
    				$month_diff = (int) $end_datetime->format( 'n' ) + ( 12 - (int) $start_datetime->format( 'n' ) );
    				// Add months for number of years between end_date and start_date.
    				$month_diff += $year_diff_in_months + 1;
    				return $month_diff;
    			case 'quarter':
    				// Year diff in quarters: (end_year - start_year - 1) * 4.
    				$year_diff_in_quarters = ( (int) $end_datetime->format( 'Y' ) - (int) $start_datetime->format( 'Y' ) - 1 ) * 4;
    				// All the quarters in end_date year plus quarters from X to 4 in the start_date year.
    				$quarter_diff = self::quarter( $end_datetime ) + ( 4 - self::quarter( $start_datetime ) );
    				// Add quarters for number of years between end_date and start_date.
    				$quarter_diff += $year_diff_in_quarters + 1;
    				return $quarter_diff;
    			case 'year':
    				$year_diff = (int) $end_datetime->format( 'Y' ) - (int) $start_datetime->format( 'Y' );
    				return $year_diff + 1;
    		}
    		return 0;
    	}
    
    	/**
    	 * Returns a new DateTime object representing the next hour start/previous hour end if reversed.
    	 *
    	 * @param DateTime $datetime Date and time.
    	 * @param bool     $reversed Going backwards in time instead of forward.
    	 * @return DateTime
    	 */
    	public static function next_hour_start( $datetime, $reversed = false ) {
    		$hour_increment         = $reversed ? 0 : 1;
    		$timestamp              = (int) $datetime->format( 'U' );
    		$seconds_into_hour      = (int) $datetime->format( 'i' ) * MINUTE_IN_SECONDS + (int) $datetime->format( 's' );
    		$hours_offset_timestamp = $timestamp + ( $hour_increment * HOUR_IN_SECONDS - $seconds_into_hour );
    
    		if ( $reversed ) {
    			$hours_offset_timestamp --;
    		}
    
    		$hours_offset_time = new \DateTime();
    		$hours_offset_time->setTimestamp( $hours_offset_timestamp );
    		$hours_offset_time->setTimezone( new \DateTimeZone( wc_timezone_string() ) );
    		return $hours_offset_time;
    	}
    
    	/**
    	 * Returns a new DateTime object representing the next day start, or previous day end if reversed.
    	 *
    	 * @param DateTime $datetime Date and time.
    	 * @param bool     $reversed Going backwards in time instead of forward.
    	 * @return DateTime
    	 */
    	public static function next_day_start( $datetime, $reversed = false ) {
    		$oneday       = new \DateInterval( 'P1D' );
    		$new_datetime = clone $datetime;
    
    		if ( $reversed ) {
    			$new_datetime->sub( $oneday );
    			$new_datetime->setTime( 23, 59, 59 );
    		} else {
    			$new_datetime->add( $oneday );
    			$new_datetime->setTime( 0, 0, 0 );
    		}
    
    		return $new_datetime;
    	}
    
    	/**
    	 * Returns DateTime object representing the next week start, or previous week end if reversed.
    	 *
    	 * The next week start is the first day of the next week at 00:00:00.
    	 * The previous week end is the last day of the previous week at 23:59:59.
    	 * The start day is determined by the "start_of_week" wp_option.
    	 *
    	 * @param DateTime $datetime Date and time.
    	 * @param bool     $reversed Going backwards in time instead of forward.
    	 * @return DateTime
    	 */
    	public static function next_week_start( $datetime, $reversed = false ) {
    		$seven_days = new \DateInterval( 'P7D' );
    		$start_end  = get_weekstartend( $datetime->format( 'Y-m-d' ) );
    
    		if ( $reversed ) {
    			return \DateTime::createFromFormat( 'U', $start_end['end'] )->sub( $seven_days );
    		}
    		return \DateTime::createFromFormat( 'U', $start_end['start'] )->add( $seven_days );
    	}
    
    	/**
    	 * Returns a new DateTime object representing the next month start, or previous month end if reversed.
    	 *
    	 * @param DateTime $datetime Date and time.
    	 * @param bool     $reversed Going backwards in time instead of forward.
    	 * @return DateTime
    	 */
    	public static function next_month_start( $datetime, $reversed = false ) {
    		$month_increment = 1;
    		$year            = $datetime->format( 'Y' );
    		$month           = (int) $datetime->format( 'm' );
    
    		if ( $reversed ) {
    			$beg_of_month_datetime       = new \DateTime( "$year-$month-01 00:00:00", new \DateTimeZone( wc_timezone_string() ) );
    			$timestamp                   = (int) $beg_of_month_datetime->format( 'U' );
    			$end_of_prev_month_timestamp = $timestamp - 1;
    			$datetime->setTimestamp( $end_of_prev_month_timestamp );
    		} else {
    			$month += $month_increment;
    			if ( $month > 12 ) {
    				$month = 1;
    				$year ++;
    			}
    			$day      = '01';
    			$datetime = new \DateTime( "$year-$month-$day 00:00:00", new \DateTimeZone( wc_timezone_string() ) );
    		}
    
    		return $datetime;
    	}
    
    	/**
    	 * Returns a new DateTime object representing the next quarter start, or previous quarter end if reversed.
    	 *
    	 * @param DateTime $datetime Date and time.
    	 * @param bool     $reversed Going backwards in time instead of forward.
    	 * @return DateTime
    	 */
    	public static function next_quarter_start( $datetime, $reversed = false ) {
    		$year  = $datetime->format( 'Y' );
    		$month = (int) $datetime->format( 'n' );
    
    		switch ( $month ) {
    			case 1:
    			case 2:
    			case 3:
    				if ( $reversed ) {
    					$month = 1;
    				} else {
    					$month = 4;
    				}
    				break;
    			case 4:
    			case 5:
    			case 6:
    				if ( $reversed ) {
    					$month = 4;
    				} else {
    					$month = 7;
    				}
    				break;
    			case 7:
    			case 8:
    			case 9:
    				if ( $reversed ) {
    					$month = 7;
    				} else {
    					$month = 10;
    				}
    				break;
    			case 10:
    			case 11:
    			case 12:
    				if ( $reversed ) {
    					$month = 10;
    				} else {
    					$month = 1;
    					$year ++;
    				}
    				break;
    		}
    		$datetime = new \DateTime( "$year-$month-01 00:00:00", new \DateTimeZone( wc_timezone_string() ) );
    		if ( $reversed ) {
    			$timestamp                   = (int) $datetime->format( 'U' );
    			$end_of_prev_month_timestamp = $timestamp - 1;
    			$datetime->setTimestamp( $end_of_prev_month_timestamp );
    		}
    
    		return $datetime;
    	}
    
    	/**
    	 * Return a new DateTime object representing the next year start, or previous year end if reversed.
    	 *
    	 * @param DateTime $datetime Date and time.
    	 * @param bool     $reversed Going backwards in time instead of forward.
    	 * @return DateTime
    	 */
    	public static function next_year_start( $datetime, $reversed = false ) {
    		$year_increment = 1;
    		$year           = (int) $datetime->format( 'Y' );
    		$month          = '01';
    		$day            = '01';
    
    		if ( $reversed ) {
    			$datetime                   = new \DateTime( "$year-$month-$day 00:00:00", new \DateTimeZone( wc_timezone_string() ) );
    			$timestamp                  = (int) $datetime->format( 'U' );
    			$end_of_prev_year_timestamp = $timestamp - 1;
    			$datetime->setTimestamp( $end_of_prev_year_timestamp );
    		} else {
    			$year    += $year_increment;
    			$datetime = new \DateTime( "$year-$month-$day 00:00:00", new \DateTimeZone( wc_timezone_string() ) );
    		}
    
    		return $datetime;
    	}
    
    	/**
    	 * Returns beginning of next time interval for provided DateTime.
    	 *
    	 * E.g. for current DateTime, beginning of next day, week, quarter, etc.
    	 *
    	 * @param DateTime $datetime      Date and time.
    	 * @param string   $time_interval Time interval, e.g. week, day, hour.
    	 * @param bool     $reversed Going backwards in time instead of forward.
    	 * @return DateTime
    	 */
    	public static function iterate( $datetime, $time_interval, $reversed = false ) {
    		return call_user_func( array( __CLASS__, "next_{$time_interval}_start" ), $datetime, $reversed );
    	}
    
    	/**
    	 * Returns expected number of items on the page in case of date ordering.
    	 *
    	 * @param int $expected_interval_count Expected number of intervals in total.
    	 * @param int $items_per_page          Number of items per page.
    	 * @param int $page_no                 Page number.
    	 *
    	 * @return float|int
    	 */
    	public static function expected_intervals_on_page( $expected_interval_count, $items_per_page, $page_no ) {
    		$total_pages = (int) ceil( $expected_interval_count / $items_per_page );
    		if ( $page_no < $total_pages ) {
    			return $items_per_page;
    		} elseif ( $page_no === $total_pages ) {
    			return $expected_interval_count - ( $page_no - 1 ) * $items_per_page;
    		} else {
    			return 0;
    		}
    	}
    
    	/**
    	 * Returns true if there are any intervals that need to be filled in the response.
    	 *
    	 * @param int    $expected_interval_count Expected number of intervals in total.
    	 * @param int    $db_records              Total number of records for given period in the database.
    	 * @param int    $items_per_page          Number of items per page.
    	 * @param int    $page_no                 Page number.
    	 * @param string $order                   asc or desc.
    	 * @param string $order_by                Column by which the result will be sorted.
    	 * @param int    $intervals_count         Number of records for given (possibly shortened) time interval.
    	 *
    	 * @return bool
    	 */
    	public static function intervals_missing( $expected_interval_count, $db_records, $items_per_page, $page_no, $order, $order_by, $intervals_count ) {
    		if ( $expected_interval_count <= $db_records ) {
    			return false;
    		}
    		if ( 'date' === $order_by ) {
    			$expected_intervals_on_page = self::expected_intervals_on_page( $expected_interval_count, $items_per_page, $page_no );
    			return $intervals_count < $expected_intervals_on_page;
    		}
    		if ( 'desc' === $order ) {
    			return $page_no > floor( $db_records / $items_per_page );
    		}
    		if ( 'asc' === $order ) {
    			return $page_no <= ceil( ( $expected_interval_count - $db_records ) / $items_per_page );
    		}
    		// Invalid ordering.
    		return false;
    	}
    
    	/**
    	 * Normalize "*_between" parameters to "*_min" and "*_max" for numeric values
    	 * and "*_after" and "*_before" for date values.
    	 *
    	 * @param array        $request Query params from REST API request.
    	 * @param string|array $param_names One or more param names to handle. Should not include "_between" suffix.
    	 * @param bool         $is_date Boolean if the param is date is related.
    	 * @return array Normalized query values.
    	 */
    	public static function normalize_between_params( $request, $param_names, $is_date ) {
    		if ( ! is_array( $param_names ) ) {
    			$param_names = array( $param_names );
    		}
    
    		$normalized = array();
    
    		foreach ( $param_names as $param_name ) {
    			if ( ! is_array( $request[ $param_name . '_between' ] ) ) {
    				continue;
    			}
    
    			$range = $request[ $param_name . '_between' ];
    
    			if ( 2 !== count( $range ) ) {
    				continue;
    			}
    
    			$min = $is_date ? '_after' : '_min';
    			$max = $is_date ? '_before' : '_max';
    
    			if ( $range[0] < $range[1] ) {
    				$normalized[ $param_name . $min ] = $range[0];
    				$normalized[ $param_name . $max ] = $range[1];
    			} else {
    				$normalized[ $param_name . $min ] = $range[1];
    				$normalized[ $param_name . $max ] = $range[0];
    			}
    		}
    
    		return $normalized;
    	}
    
    	/**
    	 * Validate a "*_between" range argument (an array with 2 numeric items).
    	 *
    	 * @param  mixed           $value Parameter value.
    	 * @param  WP_REST_Request $request REST Request.
    	 * @param  string          $param Parameter name.
    	 * @return WP_Error|boolean
    	 */
    	public static function rest_validate_between_numeric_arg( $value, $request, $param ) {
    		if ( ! wp_is_numeric_array( $value ) ) {
    			return new \WP_Error(
    				'rest_invalid_param',
    				/* translators: 1: parameter name */
    				sprintf( __( '%1$s is not a numerically indexed array.', 'woocommerce' ), $param )
    			);
    		}
    
    		if (
    			2 !== count( $value ) ||
    			! is_numeric( $value[0] ) ||
    			! is_numeric( $value[1] )
    		) {
    			return new \WP_Error(
    				'rest_invalid_param',
    				/* translators: %s: parameter name */
    				sprintf( __( '%s must contain 2 numbers.', 'woocommerce' ), $param )
    			);
    		}
    
    		return true;
    	}
    
    	/**
    	 * Validate a "*_between" range argument (an array with 2 date items).
    	 *
    	 * @param  mixed           $value Parameter value.
    	 * @param  WP_REST_Request $request REST Request.
    	 * @param  string          $param Parameter name.
    	 * @return WP_Error|boolean
    	 */
    	public static function rest_validate_between_date_arg( $value, $request, $param ) {
    		if ( ! wp_is_numeric_array( $value ) ) {
    			return new \WP_Error(
    				'rest_invalid_param',
    				/* translators: 1: parameter name */
    				sprintf( __( '%1$s is not a numerically indexed array.', 'woocommerce' ), $param )
    			);
    		}
    
    		if (
    			2 !== count( $value ) ||
    			! rest_parse_date( $value[0] ) ||
    			! rest_parse_date( $value[1] )
    		) {
    			return new \WP_Error(
    				'rest_invalid_param',
    				/* translators: %s: parameter name */
    				sprintf( __( '%s must contain 2 valid dates.', 'woocommerce' ), $param )
    			);
    		}
    
    		return true;
    	}
    }

    Is there any way to get the Log file in debug mode ?

    Forum: Plugins
    In reply to: [WooCommerce] Fatal error
    Thread Starter epoirriez

    (@epoirriez)

    That is not the repport i sent above ?

Viewing 8 replies - 1 through 8 (of 8 total)