1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
<?php
/**
* This class hooks the main sync actions.
*
* @package automattic/jetpack-sync
*/
namespace Automattic\Jetpack\Sync;
use Automattic\Jetpack\Sync\Actions as Sync_Actions;
/**
* Jetpack Sync main class.
*/
class Main {
/**
* Sets up event handlers for the Sync package. Is used from the Config package.
*
* @action plugins_loaded
*/
public static function configure() {
if ( Actions::sync_allowed() ) {
add_action( 'plugins_loaded', array( __CLASS__, 'on_plugins_loaded_early' ), 5 );
add_action( 'plugins_loaded', array( __CLASS__, 'on_plugins_loaded_late' ), 90 );
}
// Any hooks below are special cases that need to be declared even if Sync is not allowed.
add_action( 'jetpack_user_authorized', array( 'Automattic\\Jetpack\\Sync\\Actions', 'do_initial_sync' ), 10, 0 );
}
/**
* Initialize the main sync actions.
*
* @action plugins_loaded
*/
public static function on_plugins_loaded_early() {
/**
* Additional Sync modules can be carried out into their own packages and they
* will get their own config settings.
*
* For now additional modules are enabled based on whether the third party plugin
* class exists or not.
*/
Sync_Actions::initialize_woocommerce();
Sync_Actions::initialize_wp_super_cache();
// We need to define this here so that it's hooked before `updating_jetpack_version` is called.
add_action( 'updating_jetpack_version', array( 'Automattic\\Jetpack\\Sync\\Actions', 'cleanup_on_upgrade' ), 10, 2 );
}
/**
* Runs after most of plugins_loaded hook functions have been run.
*
* @action plugins_loaded
*/
public static function on_plugins_loaded_late() {
/*
* Init after plugins loaded and before the `init` action. This helps with issues where plugins init
* with a high priority or sites that use alternate cron.
*/
Sync_Actions::init();
}
}
|