Completed
Push — update/check-for-idc ( 30d174 )
by
unknown
29:45 queued 17:59
created

class.jetpack-heartbeat.php (1 issue)

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
3
class Jetpack_Heartbeat {
4
5
	/**
6
	 * Holds the singleton instance of this class
7
	 *
8
	 * @since 2.3.3
9
	 * @var Jetpack_Heartbeat
10
	 */
11
	private static $instance = false;
12
13
	private $cron_name = 'jetpack_v2_heartbeat';
14
15
	/**
16
	 * Singleton
17
	 *
18
	 * @since 2.3.3
19
	 * @static
20
	 * @return Jetpack_Heartbeat
21
	 */
22
	public static function init() {
23
		if ( ! self::$instance ) {
24
			self::$instance = new Jetpack_Heartbeat;
25
		}
26
27
		return self::$instance;
28
	}
29
30
	/**
31
	 * Constructor for singleton
32
	 *
33
	 * @since 2.3.3
34
	 * @return Jetpack_Heartbeat
35
	 */
36
	private function __construct() {
37
		if ( ! Jetpack::is_active() )
38
			return;
39
40
		// Schedule the task
41
		add_action( $this->cron_name, array( $this, 'cron_exec' ) );
42
43
		if ( ! wp_next_scheduled( $this->cron_name ) ) {
44
			// Deal with the old pre-3.0 weekly one.
45
			if ( $timestamp = wp_next_scheduled( 'jetpack_heartbeat' ) ) {
46
				wp_unschedule_event( $timestamp, 'jetpack_heartbeat' );
47
			}
48
49
			wp_schedule_event( time(), 'daily', $this->cron_name );
50
		}
51
52
		add_filter( 'jetpack_xmlrpc_methods', array( __CLASS__, 'jetpack_xmlrpc_methods' ) );
53
	}
54
55
	/**
56
	 * Method that gets executed on the wp-cron call
57
	 *
58
	 * @since 2.3.3
59
	 * @global string $wp_version
60
	 */
61
	public function cron_exec() {
62
63
		$jetpack = Jetpack::init();
64
65
		/*
66
		 * This should run daily.  Figuring in for variances in
67
		 * WP_CRON, don't let it run more than every 23 hours at most.
68
		 *
69
		 * i.e. if it ran less than 23 hours ago, fail out.
70
		 */
71
		$last = (int) Jetpack_Options::get_option( 'last_heartbeat' );
72
		if ( $last && ( $last + DAY_IN_SECONDS - HOUR_IN_SECONDS > time() ) ) {
73
			return;
74
		}
75
76
		/*
77
		 * Check for an identity crisis
78
		 *
79
		 * If one exists:
80
		 * - Bump stat for ID crisis
81
		 * - Email site admin about potential ID crisis
82
		 */
83
84
		// Coming Soon!
85
86
		foreach ( self::generate_stats_array( 'v2-' ) as $key => $value ) {
87
			$jetpack->stat( $key, $value );
88
		}
89
90
		Jetpack_Options::update_option( 'last_heartbeat', time() );
91
92
		$jetpack->do_stats( 'server_side' );
93
94
		/**
95
		 * Fires when we synchronize all registered options on heartbeat.
96
		 *
97
		 * @since 3.3.0
98
		 */
99
		do_action( 'jetpack_heartbeat' );
100
	}
101
102
	public static function generate_stats_array( $prefix = '' ) {
103
		$return = array();
104
105
		$return["{$prefix}version"]        = JETPACK__VERSION;
106
		$return["{$prefix}wp-version"]     = get_bloginfo( 'version' );
107
		$return["{$prefix}php-version"]    = PHP_VERSION;
108
		$return["{$prefix}branch"]         = floatval( JETPACK__VERSION );
109
		$return["{$prefix}wp-branch"]      = floatval( get_bloginfo( 'version' ) );
110
		$return["{$prefix}php-branch"]     = floatval( PHP_VERSION );
111
		$return["{$prefix}public"]         = Jetpack_Options::get_option( 'public' );
112
		$return["{$prefix}ssl"]            = Jetpack::permit_ssl();
113
		$return["{$prefix}is-https"]       = is_ssl() ? 'https' : 'http';
114
		$return["{$prefix}language"]       = get_bloginfo( 'language' );
115
		$return["{$prefix}charset"]        = get_bloginfo( 'charset' );
116
		$return["{$prefix}is-multisite"]   = is_multisite() ? 'multisite' : 'singlesite';
117
		$return["{$prefix}identitycrisis"] = Jetpack::check_identity_crisis( 1 ) ? 'yes' : 'no';
0 ignored issues
show
The call to Jetpack::check_identity_crisis() has too many arguments starting with 1.

This check compares calls to functions or methods with their respective definitions. If the call has more arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress.

In this case you can add the @ignore PhpDoc annotation to the duplicate definition and it will be ignored.

Loading history...
118
		$return["{$prefix}plugins"]        = implode( ',', Jetpack::get_active_plugins() );
119
120
		$return["{$prefix}single-user-site"]= Jetpack::is_single_user_site();
121
122
		$return["{$prefix}manage-enabled"] = Jetpack::is_module_active( 'manage' );
123
124
		// is-multi-network can have three values, `single-site`, `single-network`, and `multi-network`
125
		$return["{$prefix}is-multi-network"] = 'single-site';
126
		if ( is_multisite() ) {
127
			$return["{$prefix}is-multi-network"] = Jetpack::is_multi_network() ? 'multi-network' : 'single-network';
128
		}
129
130
		if ( ! empty( $_SERVER['SERVER_ADDR'] ) || ! empty( $_SERVER['LOCAL_ADDR'] ) ) {
131
			$ip     = ! empty( $_SERVER['SERVER_ADDR'] ) ? $_SERVER['SERVER_ADDR'] : $_SERVER['LOCAL_ADDR'];
132
			$ip_arr = array_map( 'intval', explode( '.', $ip ) );
133
			if ( 4 == count( $ip_arr ) ) {
134
				$return["{$prefix}ip-2-octets"] = implode( '.', array_slice( $ip_arr, 0, 2 ) );
135
			}
136
		}
137
138
		foreach ( Jetpack::get_available_modules() as $slug ) {
139
			$return["{$prefix}module-{$slug}"] = Jetpack::is_module_active( $slug ) ? 'on' : 'off';
140
		}
141
142
		return $return;
143
	}
144
145
	public static function jetpack_xmlrpc_methods( $methods ) {
146
		$methods['jetpack.getHeartbeatData'] = array( __CLASS__, 'generate_stats_array' );
147
		return $methods;
148
	}
149
150
	public function deactivate() {
151
		// Deal with the old pre-3.0 weekly one.
152
		if ( $timestamp = wp_next_scheduled( 'jetpack_heartbeat' ) ) {
153
			wp_unschedule_event( $timestamp, 'jetpack_heartbeat' );
154
		}
155
156
		$timestamp = wp_next_scheduled( $this->cron_name );
157
		wp_unschedule_event( $timestamp, $this->cron_name );
158
	}
159
160
}
161