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 |
||
0 ignored issues
–
show
|
|||
35 | */ |
||
36 | private function __construct() { |
||
37 | if ( ! Jetpack::is_active() ) |
||
0 ignored issues
–
show
The method
Jetpack::is_active() has been deprecated with message: 7.5 Use Connection_Manager instead.
This method has been deprecated. The supplier of the class has supplied an explanatory message. The explanatory message should give you some clue as to whether and when the method will be removed from the class and what other method or class to use instead. ![]() |
|||
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() ? 'yes' : 'no'; |
||
118 | $return["{$prefix}plugins"] = implode( ',', Jetpack::get_active_plugins() ); |
||
119 | $return["{$prefix}manage-enabled"] = true; |
||
120 | |||
121 | // is-multi-network can have three values, `single-site`, `single-network`, and `multi-network` |
||
122 | $return["{$prefix}is-multi-network"] = 'single-site'; |
||
123 | if ( is_multisite() ) { |
||
124 | $return["{$prefix}is-multi-network"] = Jetpack::is_multi_network() ? 'multi-network' : 'single-network'; |
||
125 | } |
||
126 | |||
127 | if ( ! empty( $_SERVER['SERVER_ADDR'] ) || ! empty( $_SERVER['LOCAL_ADDR'] ) ) { |
||
128 | $ip = ! empty( $_SERVER['SERVER_ADDR'] ) ? $_SERVER['SERVER_ADDR'] : $_SERVER['LOCAL_ADDR']; |
||
129 | $ip_arr = array_map( 'intval', explode( '.', $ip ) ); |
||
130 | if ( 4 == count( $ip_arr ) ) { |
||
131 | $return["{$prefix}ip-2-octets"] = implode( '.', array_slice( $ip_arr, 0, 2 ) ); |
||
132 | } |
||
133 | } |
||
134 | |||
135 | foreach ( Jetpack::get_available_modules() as $slug ) { |
||
136 | $return["{$prefix}module-{$slug}"] = Jetpack::is_module_active( $slug ) ? 'on' : 'off'; |
||
137 | } |
||
138 | |||
139 | return $return; |
||
140 | } |
||
141 | |||
142 | public static function jetpack_xmlrpc_methods( $methods ) { |
||
143 | $methods['jetpack.getHeartbeatData'] = array( __CLASS__, 'xmlrpc_data_response' ); |
||
144 | return $methods; |
||
145 | } |
||
146 | |||
147 | public static function xmlrpc_data_response( $params = array() ) { |
||
148 | // The WordPress XML-RPC server sets a default param of array() |
||
149 | // if no argument is passed on the request and the method handlers get this array in $params. |
||
150 | // generate_stats_array() needs a string as first argument. |
||
151 | $params = empty( $params ) ? '' : $params; |
||
152 | return self::generate_stats_array( $params ); |
||
0 ignored issues
–
show
It seems like
$params defined by empty($params) ? '' : $params on line 151 can also be of type array ; however, Jetpack_Heartbeat::generate_stats_array() does only seem to accept string , maybe add an additional type check?
If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check: /**
* @return array|string
*/
function returnsDifferentValues($x) {
if ($x) {
return 'foo';
}
return array();
}
$x = returnsDifferentValues($y);
if (is_array($x)) {
// $x is an array.
}
If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue. ![]() |
|||
153 | } |
||
154 | |||
155 | public function deactivate() { |
||
156 | // Deal with the old pre-3.0 weekly one. |
||
157 | if ( $timestamp = wp_next_scheduled( 'jetpack_heartbeat' ) ) { |
||
158 | wp_unschedule_event( $timestamp, 'jetpack_heartbeat' ); |
||
159 | } |
||
160 | |||
161 | $timestamp = wp_next_scheduled( $this->cron_name ); |
||
162 | wp_unschedule_event( $timestamp, $this->cron_name ); |
||
163 | } |
||
164 | |||
165 | } |
||
166 |
Adding a
@return
annotation to a constructor is not recommended, since a constructor does not have a meaningful return value.Please refer to the PHP core documentation on constructors.