GhostManSec
Server: LiteSpeed
System: Linux premium117.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: eblama1 (1214)
PHP: 8.2.31
Disabled: NONE
Upload Files
File: /home/eblama1/mintawon.farm/wp-content/plugins/burst-statistics/includes/Admin/class-milestones.php
<?php
/**
 * Milestone class to handle all milestone related functionality.
 */
namespace Burst\Admin;

use Burst\Admin\Statistics\Statistics_Query;
use Burst\Traits\Helper;

defined( 'ABSPATH' ) || exit;

/**
 * Class Milestones
 */
class Milestones {
	use Helper;

	/**
	 * Initialize hooks.
	 */
	public function init(): void {
		add_action( 'burst_dismiss_task', [ $this, 'pageviews_milestone_dismiss' ] );
	}

	/**
	 * Check if a new pageviews milestone has been reached.
	 *
	 * @return bool True if milestone reached, false otherwise.
	 */
	public static function pageviews_milestone_reached(): bool {
		// Get last milestone.
		$last_milestone = (int) get_option( 'burst_last_pageviews_milestone', 0 );

		// If no milestone yet, check activation date.
		if ( $last_milestone === 0 ) {
			$activated = (int) get_option( 'burst_activation_time', 0 );

			// Not active long enough → skip.
			if ( $activated === 0 || $activated > strtotime( '-1 month' ) ) {
				return false;
			}
		}

		// Current month pageviews.
		$current_month_start = strtotime( gmdate( 'Y-m-01 00:00:00' ) );
		$current_month_end   = strtotime( gmdate( 'Y-m-t 23:59:59' ) );

		$current_pv = self::get_pageviews( $current_month_start, $current_month_end );

		// If we have a milestone, check previous month for 80% rule.
		if ( $last_milestone > 0 ) {
			$previous_month_start = strtotime( gmdate( 'Y-m-01 00:00:00', strtotime( '-1 month' ) ) );
			$previous_month_end   = strtotime( gmdate( 'Y-m-t 23:59:59', strtotime( '-1 month' ) ) );
			$previous_pv          = self::get_pageviews( $previous_month_start, $previous_month_end );
			if ( $previous_pv > 0 && $current_pv < ( 0.8 * $previous_pv ) ) {
				return false;
			}
		}

		// Determine next milestone.
		$next_milestone = self::get_next_milestone( $current_pv );
		if ( $next_milestone > 0 && $next_milestone > $last_milestone ) {
			update_option( 'burst_current_pageviews_milestone', $next_milestone, false );
			return true;
		}

		return false;
	}

	/**
	 * Query DB for pageviews in given range.
	 *
	 * @param int $start Start timestamp.
	 * @param int $end   End timestamp.
	 * @return int Number of pageviews.
	 */
	private static function get_pageviews( int $start, int $end ): int {
		$qd = Statistics_Query::create( 'milestones_pageviews' )
			->date_range( $start, $end )
			->select( [ 'pageviews' ] );

		$result = $qd->fetch_row( 'ARRAY_A' );

		return null !== $result ? (int) $result['pageviews'] : 0;
	}

	/**
	 * Get the next milestone number based on the last one.
	 *
	 * @param int $current_pageviews Current pageviews.
	 * @return int The next milestone.
	 */
	private static function get_next_milestone( int $current_pageviews ): int {
		// Determine which milestone was just reached.
		if ( $current_pageviews < 100 ) {
			// No milestone reached yet.
			return 0;
		} elseif ( $current_pageviews < 1000 ) {
			$reached = floor( $current_pageviews / 100 ) * 100;
		} elseif ( $current_pageviews < 10000 ) {
			$reached = floor( $current_pageviews / 1000 ) * 1000;
		} elseif ( $current_pageviews < 100000 ) {
			$reached = floor( $current_pageviews / 10000 ) * 10000;
		} else {
			$reached = floor( $current_pageviews / 100000 ) * 100000;
		}

		return (int) $reached;
	}

	/**
	 * Handle dismissal of pageviews milestone task.
	 *
	 * @param string $task_id The ID of the dismissed task.
	 * @return void Returns void.
	 */
	public function pageviews_milestone_dismiss( string $task_id ): void {
		if ( $task_id !== 'pageviews_milestone' ) {
			return;
		}

		$current_pageviews_milestone = (int) get_option( 'burst_current_pageviews_milestone', 0 );
		delete_option( 'burst_current_pageviews_milestone' );
		update_option( 'burst_last_pageviews_milestone', $current_pageviews_milestone, false );
	}

	/**
	 * Format milestone number for display. Alias for format_number_short from Helper trait.
	 *
	 * @param int $number The milestone number.
	 * @return string Formatted milestone.
	 */
	public function format_milestone( int $number ): string {
		return $this->format_number_short( $number );
	}
}