Completed
Branch FET/Gutenberg/11426/event-atte... (b97e58)
by
unknown
39:30 queued 26:44
created
core/services/editor/BlockRegistrationManager.php 2 patches
Indentation   +154 added lines, -154 removed lines patch added patch discarded remove patch
@@ -40,158 +40,158 @@
 block discarded – undo
40 40
 class BlockRegistrationManager extends BlockManager
41 41
 {
42 42
 
43
-    /**
44
-     * @var AssetRegisterCollection $asset_register_collection
45
-     */
46
-    protected $asset_register_collection;
47
-
48
-
49
-    /**
50
-     * BlockRegistrationManager constructor.
51
-     *
52
-     * @param AssetRegisterCollection $asset_register_collection
53
-     * @param BlockCollection         $blocks
54
-     * @param RequestInterface        $request
55
-     */
56
-    public function __construct(
57
-        AssetRegisterCollection $asset_register_collection,
58
-        BlockCollection $blocks,
59
-        RequestInterface $request
60
-    ) {
61
-        $this->asset_register_collection = $asset_register_collection;
62
-        parent::__construct($blocks, $request);
63
-    }
64
-
65
-
66
-    /**
67
-     *  Returns the name of a hookpoint to be used to call initialize()
68
-     *
69
-     * @return string
70
-     */
71
-    public function init_hook()
72
-    {
73
-        return 'AHEE__EE_System__set_hooks_for_core';
74
-    }
75
-
76
-
77
-    /**
78
-     * Perform any early setup required for block editors to functions
79
-     *
80
-     * @return void
81
-     * @throws Exception
82
-     */
83
-    public function initialize()
84
-    {
85
-        $this->loadBlocks();
86
-        add_action('AHEE__EE_System__initialize', array($this, 'registerBlocks'));
87
-    }
88
-
89
-
90
-    /**
91
-     * @return CollectionInterface|BlockInterface[]
92
-     * @throws ReflectionException
93
-     * @throws InvalidArgumentException
94
-     * @throws EE_Error
95
-     * @throws InvalidClassException
96
-     * @throws InvalidDataTypeException
97
-     * @throws InvalidEntityException
98
-     * @throws InvalidFilePathException
99
-     * @throws InvalidIdentifierException
100
-     * @throws InvalidInterfaceException
101
-     */
102
-    protected function populateBlockCollection()
103
-    {
104
-        $loader = new CollectionLoader(
105
-            new CollectionDetails(
106
-            // collection name
107
-                'shortcodes',
108
-                // collection interface
109
-                'EventEspresso\core\domain\entities\editor\BlockInterface',
110
-                // FQCNs for classes to add (all classes within each namespace will be loaded)
111
-                apply_filters(
112
-                    'FHEE__EventEspresso_core_services_editor_BlockManager__populateBlockCollection__collection_FQCNs',
113
-                    array(
114
-                        // 'EventEspresso\core\domain\entities\editor\blocks\common',
115
-                        // 'EventEspresso\core\domain\entities\editor\blocks\editor',
116
-                        'EventEspresso\core\domain\entities\editor\blocks\widgets',
117
-                    )
118
-                ),
119
-                // filepaths to classes to add
120
-                array(),
121
-                // file mask to use if parsing folder for files to add
122
-                '',
123
-                // what to use as identifier for collection entities
124
-                // using CLASS NAME prevents duplicates (works like a singleton)
125
-                CollectionDetails::ID_CLASS_NAME
126
-            ),
127
-            $this->blocks
128
-        );
129
-        return $loader->getCollection();
130
-    }
131
-
132
-
133
-    /**
134
-     * populates the BlockCollection and calls initialize() on all installed blocks
135
-     *
136
-     * @return void
137
-     * @throws Exception
138
-     */
139
-    public function loadBlocks()
140
-    {
141
-        try {
142
-            $this->populateBlockCollection();
143
-            // cycle thru block loaders and initialize each loader
144
-            foreach ($this->blocks as $block) {
145
-                $block->initialize();
146
-            }
147
-        } catch (Exception $exception) {
148
-            new ExceptionStackTraceDisplay($exception);
149
-        }
150
-    }
151
-
152
-
153
-    /**
154
-     * calls registerBlock() and load assets for all installed blocks
155
-     *
156
-     * @return void
157
-     * @throws Exception
158
-     */
159
-    public function registerBlocks()
160
-    {
161
-        try {
162
-            // cycle thru block loader folders
163
-            foreach ($this->blocks as $block) {
164
-                // perform any setup required for the block
165
-                $block_type = $block->registerBlock();
166
-                if (! $block_type instanceof WP_Block_Type) {
167
-                    throw new InvalidEntityException($block_type, 'WP_Block_Type');
168
-                }
169
-                if (! $this->asset_register_collection->has($block->assetRegister())) {
170
-                    $this->asset_register_collection->add($block->assetRegister());
171
-                }
172
-                do_action(
173
-                    'FHEE__EventEspresso_core_services_editor_BlockManager__registerBlocks__block_type_registered',
174
-                    $block,
175
-                    $block_type
176
-                );
177
-            }
178
-            if ($this->asset_register_collection->hasObjects()) {
179
-                $this->asset_register_collection->registerManifestFile();
180
-                // register primary assets
181
-                add_action('enqueue_block_assets', array($this, 'registerAssets'));
182
-            }
183
-        } catch (Exception $exception) {
184
-            new ExceptionStackTraceDisplay($exception);
185
-        }
186
-    }
187
-
188
-
189
-    /**
190
-     * Registers assets for all classes in the AssetRegisterCollection
191
-     */
192
-    public function registerAssets()
193
-    {
194
-        $this->asset_register_collection->registerScripts();
195
-        $this->asset_register_collection->registerStyles();
196
-    }
43
+	/**
44
+	 * @var AssetRegisterCollection $asset_register_collection
45
+	 */
46
+	protected $asset_register_collection;
47
+
48
+
49
+	/**
50
+	 * BlockRegistrationManager constructor.
51
+	 *
52
+	 * @param AssetRegisterCollection $asset_register_collection
53
+	 * @param BlockCollection         $blocks
54
+	 * @param RequestInterface        $request
55
+	 */
56
+	public function __construct(
57
+		AssetRegisterCollection $asset_register_collection,
58
+		BlockCollection $blocks,
59
+		RequestInterface $request
60
+	) {
61
+		$this->asset_register_collection = $asset_register_collection;
62
+		parent::__construct($blocks, $request);
63
+	}
64
+
65
+
66
+	/**
67
+	 *  Returns the name of a hookpoint to be used to call initialize()
68
+	 *
69
+	 * @return string
70
+	 */
71
+	public function init_hook()
72
+	{
73
+		return 'AHEE__EE_System__set_hooks_for_core';
74
+	}
75
+
76
+
77
+	/**
78
+	 * Perform any early setup required for block editors to functions
79
+	 *
80
+	 * @return void
81
+	 * @throws Exception
82
+	 */
83
+	public function initialize()
84
+	{
85
+		$this->loadBlocks();
86
+		add_action('AHEE__EE_System__initialize', array($this, 'registerBlocks'));
87
+	}
88
+
89
+
90
+	/**
91
+	 * @return CollectionInterface|BlockInterface[]
92
+	 * @throws ReflectionException
93
+	 * @throws InvalidArgumentException
94
+	 * @throws EE_Error
95
+	 * @throws InvalidClassException
96
+	 * @throws InvalidDataTypeException
97
+	 * @throws InvalidEntityException
98
+	 * @throws InvalidFilePathException
99
+	 * @throws InvalidIdentifierException
100
+	 * @throws InvalidInterfaceException
101
+	 */
102
+	protected function populateBlockCollection()
103
+	{
104
+		$loader = new CollectionLoader(
105
+			new CollectionDetails(
106
+			// collection name
107
+				'shortcodes',
108
+				// collection interface
109
+				'EventEspresso\core\domain\entities\editor\BlockInterface',
110
+				// FQCNs for classes to add (all classes within each namespace will be loaded)
111
+				apply_filters(
112
+					'FHEE__EventEspresso_core_services_editor_BlockManager__populateBlockCollection__collection_FQCNs',
113
+					array(
114
+						// 'EventEspresso\core\domain\entities\editor\blocks\common',
115
+						// 'EventEspresso\core\domain\entities\editor\blocks\editor',
116
+						'EventEspresso\core\domain\entities\editor\blocks\widgets',
117
+					)
118
+				),
119
+				// filepaths to classes to add
120
+				array(),
121
+				// file mask to use if parsing folder for files to add
122
+				'',
123
+				// what to use as identifier for collection entities
124
+				// using CLASS NAME prevents duplicates (works like a singleton)
125
+				CollectionDetails::ID_CLASS_NAME
126
+			),
127
+			$this->blocks
128
+		);
129
+		return $loader->getCollection();
130
+	}
131
+
132
+
133
+	/**
134
+	 * populates the BlockCollection and calls initialize() on all installed blocks
135
+	 *
136
+	 * @return void
137
+	 * @throws Exception
138
+	 */
139
+	public function loadBlocks()
140
+	{
141
+		try {
142
+			$this->populateBlockCollection();
143
+			// cycle thru block loaders and initialize each loader
144
+			foreach ($this->blocks as $block) {
145
+				$block->initialize();
146
+			}
147
+		} catch (Exception $exception) {
148
+			new ExceptionStackTraceDisplay($exception);
149
+		}
150
+	}
151
+
152
+
153
+	/**
154
+	 * calls registerBlock() and load assets for all installed blocks
155
+	 *
156
+	 * @return void
157
+	 * @throws Exception
158
+	 */
159
+	public function registerBlocks()
160
+	{
161
+		try {
162
+			// cycle thru block loader folders
163
+			foreach ($this->blocks as $block) {
164
+				// perform any setup required for the block
165
+				$block_type = $block->registerBlock();
166
+				if (! $block_type instanceof WP_Block_Type) {
167
+					throw new InvalidEntityException($block_type, 'WP_Block_Type');
168
+				}
169
+				if (! $this->asset_register_collection->has($block->assetRegister())) {
170
+					$this->asset_register_collection->add($block->assetRegister());
171
+				}
172
+				do_action(
173
+					'FHEE__EventEspresso_core_services_editor_BlockManager__registerBlocks__block_type_registered',
174
+					$block,
175
+					$block_type
176
+				);
177
+			}
178
+			if ($this->asset_register_collection->hasObjects()) {
179
+				$this->asset_register_collection->registerManifestFile();
180
+				// register primary assets
181
+				add_action('enqueue_block_assets', array($this, 'registerAssets'));
182
+			}
183
+		} catch (Exception $exception) {
184
+			new ExceptionStackTraceDisplay($exception);
185
+		}
186
+	}
187
+
188
+
189
+	/**
190
+	 * Registers assets for all classes in the AssetRegisterCollection
191
+	 */
192
+	public function registerAssets()
193
+	{
194
+		$this->asset_register_collection->registerScripts();
195
+		$this->asset_register_collection->registerStyles();
196
+	}
197 197
 }
Please login to merge, or discard this patch.
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -163,10 +163,10 @@
 block discarded – undo
163 163
             foreach ($this->blocks as $block) {
164 164
                 // perform any setup required for the block
165 165
                 $block_type = $block->registerBlock();
166
-                if (! $block_type instanceof WP_Block_Type) {
166
+                if ( ! $block_type instanceof WP_Block_Type) {
167 167
                     throw new InvalidEntityException($block_type, 'WP_Block_Type');
168 168
                 }
169
-                if (! $this->asset_register_collection->has($block->assetRegister())) {
169
+                if ( ! $this->asset_register_collection->has($block->assetRegister())) {
170 170
                     $this->asset_register_collection->add($block->assetRegister());
171 171
                 }
172 172
                 do_action(
Please login to merge, or discard this patch.
core/services/editor/BlockAssetRegister.php 1 patch
Indentation   +193 added lines, -193 removed lines patch added patch discarded remove patch
@@ -22,197 +22,197 @@
 block discarded – undo
22 22
 abstract class BlockAssetRegister implements AssetRegisterInterface
23 23
 {
24 24
 
25
-    /**
26
-     * @var DomainInterface $domain
27
-     */
28
-    private $domain;
29
-
30
-    /**
31
-     * @var Registry $registry
32
-     */
33
-    private $registry;
34
-
35
-    /**
36
-     * @var string $script_handle
37
-     */
38
-    private $script_handle;
39
-
40
-    /**
41
-     * @var array $script_dependencies
42
-     */
43
-    private $script_dependencies;
44
-
45
-    /**
46
-     * @var string $style_handle
47
-     */
48
-    private $style_handle;
49
-
50
-    /**
51
-     * @var array $style_dependencies
52
-     */
53
-    private $style_dependencies;
54
-
55
-
56
-    /**
57
-     * BlockAssetRegister constructor.
58
-     *
59
-     * @param string          $script_handle
60
-     * @param array           $script_dependencies
61
-     * @param string          $style_handle
62
-     * @param array           $style_dependencies
63
-     * @param DomainInterface $domain
64
-     * @param Registry        $registry
65
-     */
66
-    public function __construct(
67
-        $script_handle,
68
-        array $script_dependencies,
69
-        $style_handle,
70
-        array $style_dependencies,
71
-        DomainInterface $domain,
72
-        Registry $registry
73
-    ) {
74
-        $this->script_handle       = $script_handle;
75
-        $this->script_dependencies = $script_dependencies;
76
-        $this->style_handle        = $style_handle;
77
-        $this->style_dependencies  = $style_dependencies;
78
-        $this->domain              = $domain;
79
-        $this->registry            = $registry;
80
-    }
81
-
82
-
83
-    /**
84
-     * @return string
85
-     */
86
-    public function scriptHandle()
87
-    {
88
-        return $this->script_handle;
89
-    }
90
-
91
-
92
-    /**
93
-     * @param string $script_handle
94
-     * @throws InvalidDataTypeException
95
-     */
96
-    public function setScriptHandle($script_handle)
97
-    {
98
-        if (! is_string($script_handle)) {
99
-            throw new InvalidDataTypeException('$script_handle', $script_handle, 'string');
100
-        }
101
-        $this->script_handle = $script_handle;
102
-    }
103
-
104
-
105
-    /**
106
-     * @return string
107
-     */
108
-    public function styleHandle()
109
-    {
110
-        return $this->style_handle;
111
-    }
112
-
113
-
114
-    /**
115
-     * @param string $style_handle
116
-     * @throws InvalidDataTypeException
117
-     */
118
-    public function setStyleHandle($style_handle)
119
-    {
120
-        if (! is_string($style_handle)) {
121
-            throw new InvalidDataTypeException('$style_handle', $style_handle, 'string');
122
-        }
123
-        $this->style_handle = $style_handle;
124
-    }
125
-
126
-
127
-    /**
128
-     * @return array
129
-     */
130
-    public function scriptDependencies()
131
-    {
132
-        return $this->script_dependencies;
133
-    }
134
-
135
-
136
-    /**
137
-     * @param array $script_dependencies
138
-     */
139
-    public function setScriptDependencies($script_dependencies)
140
-    {
141
-        $this->script_dependencies = $script_dependencies + array(
142
-                'eejs-core',
143
-                'wp-blocks',    // Provides useful functions and components for extending the editor
144
-                'wp-i18n',      // Provides localization functions
145
-                'wp-element',   // Provides React.Component
146
-                'wp-components' // Provides many prebuilt components and controls
147
-            );
148
-    }
149
-
150
-
151
-    /**
152
-     * @return array
153
-     */
154
-    public function styleDependencies()
155
-    {
156
-        return $this->style_dependencies;
157
-    }
158
-
159
-
160
-    /**
161
-     * @param array $style_dependencies
162
-     */
163
-    public function setStyleDependencies($style_dependencies)
164
-    {
165
-        $this->style_dependencies = $style_dependencies;
166
-    }
167
-
168
-
169
-    /**
170
-     * @return void
171
-     * @throws \EventEspresso\core\exceptions\InvalidFilePathException
172
-     * @throws \InvalidArgumentException
173
-     */
174
-    public function registerManifestFile()
175
-    {
176
-        if($this->domain->assetNamespace() !== Registry::ASSET_NAMESPACE_CORE) {
177
-            $this->registry->registerManifestFile(
178
-                $this->domain->assetNamespace(),
179
-                $this->domain->distributionAssetsUrl(),
180
-                $this->domain->distributionAssetsPath() . Registry::FILE_NAME_BUILD_MANIFEST
181
-            );
182
-        }
183
-    }
184
-
185
-
186
-    /**
187
-     * @return  void
188
-     */
189
-    public function registerScripts()
190
-    {
191
-        wp_register_script(
192
-            $this->scriptHandle(),
193
-            $this->registry->getJsUrl(
194
-                $this->domain->assetNamespace(),
195
-                $this->scriptHandle()
196
-            ),
197
-            $this->scriptDependencies(),
198
-            null,
199
-            true
200
-        );
201
-    }
202
-
203
-
204
-    /**
205
-     * @return void
206
-     */
207
-    public function registerStyles()
208
-    {
209
-        wp_register_style(
210
-            $this->styleHandle(),
211
-            $this->registry->getCssUrl(
212
-                $this->domain->assetNamespace(),
213
-                $this->styleHandle()
214
-            ),
215
-            $this->styleDependencies()
216
-        );
217
-    }
25
+	/**
26
+	 * @var DomainInterface $domain
27
+	 */
28
+	private $domain;
29
+
30
+	/**
31
+	 * @var Registry $registry
32
+	 */
33
+	private $registry;
34
+
35
+	/**
36
+	 * @var string $script_handle
37
+	 */
38
+	private $script_handle;
39
+
40
+	/**
41
+	 * @var array $script_dependencies
42
+	 */
43
+	private $script_dependencies;
44
+
45
+	/**
46
+	 * @var string $style_handle
47
+	 */
48
+	private $style_handle;
49
+
50
+	/**
51
+	 * @var array $style_dependencies
52
+	 */
53
+	private $style_dependencies;
54
+
55
+
56
+	/**
57
+	 * BlockAssetRegister constructor.
58
+	 *
59
+	 * @param string          $script_handle
60
+	 * @param array           $script_dependencies
61
+	 * @param string          $style_handle
62
+	 * @param array           $style_dependencies
63
+	 * @param DomainInterface $domain
64
+	 * @param Registry        $registry
65
+	 */
66
+	public function __construct(
67
+		$script_handle,
68
+		array $script_dependencies,
69
+		$style_handle,
70
+		array $style_dependencies,
71
+		DomainInterface $domain,
72
+		Registry $registry
73
+	) {
74
+		$this->script_handle       = $script_handle;
75
+		$this->script_dependencies = $script_dependencies;
76
+		$this->style_handle        = $style_handle;
77
+		$this->style_dependencies  = $style_dependencies;
78
+		$this->domain              = $domain;
79
+		$this->registry            = $registry;
80
+	}
81
+
82
+
83
+	/**
84
+	 * @return string
85
+	 */
86
+	public function scriptHandle()
87
+	{
88
+		return $this->script_handle;
89
+	}
90
+
91
+
92
+	/**
93
+	 * @param string $script_handle
94
+	 * @throws InvalidDataTypeException
95
+	 */
96
+	public function setScriptHandle($script_handle)
97
+	{
98
+		if (! is_string($script_handle)) {
99
+			throw new InvalidDataTypeException('$script_handle', $script_handle, 'string');
100
+		}
101
+		$this->script_handle = $script_handle;
102
+	}
103
+
104
+
105
+	/**
106
+	 * @return string
107
+	 */
108
+	public function styleHandle()
109
+	{
110
+		return $this->style_handle;
111
+	}
112
+
113
+
114
+	/**
115
+	 * @param string $style_handle
116
+	 * @throws InvalidDataTypeException
117
+	 */
118
+	public function setStyleHandle($style_handle)
119
+	{
120
+		if (! is_string($style_handle)) {
121
+			throw new InvalidDataTypeException('$style_handle', $style_handle, 'string');
122
+		}
123
+		$this->style_handle = $style_handle;
124
+	}
125
+
126
+
127
+	/**
128
+	 * @return array
129
+	 */
130
+	public function scriptDependencies()
131
+	{
132
+		return $this->script_dependencies;
133
+	}
134
+
135
+
136
+	/**
137
+	 * @param array $script_dependencies
138
+	 */
139
+	public function setScriptDependencies($script_dependencies)
140
+	{
141
+		$this->script_dependencies = $script_dependencies + array(
142
+				'eejs-core',
143
+				'wp-blocks',    // Provides useful functions and components for extending the editor
144
+				'wp-i18n',      // Provides localization functions
145
+				'wp-element',   // Provides React.Component
146
+				'wp-components' // Provides many prebuilt components and controls
147
+			);
148
+	}
149
+
150
+
151
+	/**
152
+	 * @return array
153
+	 */
154
+	public function styleDependencies()
155
+	{
156
+		return $this->style_dependencies;
157
+	}
158
+
159
+
160
+	/**
161
+	 * @param array $style_dependencies
162
+	 */
163
+	public function setStyleDependencies($style_dependencies)
164
+	{
165
+		$this->style_dependencies = $style_dependencies;
166
+	}
167
+
168
+
169
+	/**
170
+	 * @return void
171
+	 * @throws \EventEspresso\core\exceptions\InvalidFilePathException
172
+	 * @throws \InvalidArgumentException
173
+	 */
174
+	public function registerManifestFile()
175
+	{
176
+		if($this->domain->assetNamespace() !== Registry::ASSET_NAMESPACE_CORE) {
177
+			$this->registry->registerManifestFile(
178
+				$this->domain->assetNamespace(),
179
+				$this->domain->distributionAssetsUrl(),
180
+				$this->domain->distributionAssetsPath() . Registry::FILE_NAME_BUILD_MANIFEST
181
+			);
182
+		}
183
+	}
184
+
185
+
186
+	/**
187
+	 * @return  void
188
+	 */
189
+	public function registerScripts()
190
+	{
191
+		wp_register_script(
192
+			$this->scriptHandle(),
193
+			$this->registry->getJsUrl(
194
+				$this->domain->assetNamespace(),
195
+				$this->scriptHandle()
196
+			),
197
+			$this->scriptDependencies(),
198
+			null,
199
+			true
200
+		);
201
+	}
202
+
203
+
204
+	/**
205
+	 * @return void
206
+	 */
207
+	public function registerStyles()
208
+	{
209
+		wp_register_style(
210
+			$this->styleHandle(),
211
+			$this->registry->getCssUrl(
212
+				$this->domain->assetNamespace(),
213
+				$this->styleHandle()
214
+			),
215
+			$this->styleDependencies()
216
+		);
217
+	}
218 218
 }
219 219
\ No newline at end of file
Please login to merge, or discard this patch.
core/EE_System.core.php 1 patch
Indentation   +1278 added lines, -1278 removed lines patch added patch discarded remove patch
@@ -32,1284 +32,1284 @@
 block discarded – undo
32 32
 {
33 33
 
34 34
 
35
-    /**
36
-     * indicates this is a 'normal' request. Ie, not activation, nor upgrade, nor activation.
37
-     * So examples of this would be a normal GET request on the frontend or backend, or a POST, etc
38
-     */
39
-    const req_type_normal = 0;
40
-
41
-    /**
42
-     * Indicates this is a brand new installation of EE so we should install
43
-     * tables and default data etc
44
-     */
45
-    const req_type_new_activation = 1;
46
-
47
-    /**
48
-     * we've detected that EE has been reactivated (or EE was activated during maintenance mode,
49
-     * and we just exited maintenance mode). We MUST check the database is setup properly
50
-     * and that default data is setup too
51
-     */
52
-    const req_type_reactivation = 2;
53
-
54
-    /**
55
-     * indicates that EE has been upgraded since its previous request.
56
-     * We may have data migration scripts to call and will want to trigger maintenance mode
57
-     */
58
-    const req_type_upgrade = 3;
59
-
60
-    /**
61
-     * TODO  will detect that EE has been DOWNGRADED. We probably don't want to run in this case...
62
-     */
63
-    const req_type_downgrade = 4;
64
-
65
-    /**
66
-     * @deprecated since version 4.6.0.dev.006
67
-     * Now whenever a new_activation is detected the request type is still just
68
-     * new_activation (same for reactivation, upgrade, downgrade etc), but if we'r ein maintenance mode
69
-     * EE_System::initialize_db_if_no_migrations_required and EE_Addon::initialize_db_if_no_migrations_required
70
-     * will instead enqueue that EE plugin's db initialization for when we're taken out of maintenance mode.
71
-     * (Specifically, when the migration manager indicates migrations are finished
72
-     * EE_Data_Migration_Manager::initialize_db_for_enqueued_ee_plugins() will be called)
73
-     */
74
-    const req_type_activation_but_not_installed = 5;
75
-
76
-    /**
77
-     * option prefix for recording the activation history (like core's "espresso_db_update") of addons
78
-     */
79
-    const addon_activation_history_option_prefix = 'ee_addon_activation_history_';
80
-
81
-
82
-    /**
83
-     * @var EE_System $_instance
84
-     */
85
-    private static $_instance;
86
-
87
-    /**
88
-     * @var EE_Registry $registry
89
-     */
90
-    private $registry;
91
-
92
-    /**
93
-     * @var LoaderInterface $loader
94
-     */
95
-    private $loader;
96
-
97
-    /**
98
-     * @var EE_Capabilities $capabilities
99
-     */
100
-    private $capabilities;
101
-
102
-    /**
103
-     * @var RequestInterface $request
104
-     */
105
-    private $request;
106
-
107
-    /**
108
-     * @var EE_Maintenance_Mode $maintenance_mode
109
-     */
110
-    private $maintenance_mode;
111
-
112
-    /**
113
-     * Stores which type of request this is, options being one of the constants on EE_System starting with req_type_*.
114
-     * It can be a brand-new activation, a reactivation, an upgrade, a downgrade, or a normal request.
115
-     *
116
-     * @var int $_req_type
117
-     */
118
-    private $_req_type;
119
-
120
-    /**
121
-     * Whether or not there was a non-micro version change in EE core version during this request
122
-     *
123
-     * @var boolean $_major_version_change
124
-     */
125
-    private $_major_version_change = false;
126
-
127
-    /**
128
-     * A Context DTO dedicated solely to identifying the current request type.
129
-     *
130
-     * @var RequestTypeContextCheckerInterface $request_type
131
-     */
132
-    private $request_type;
133
-
134
-
135
-
136
-    /**
137
-     * @singleton method used to instantiate class object
138
-     * @param EE_Registry|null         $registry
139
-     * @param LoaderInterface|null     $loader
140
-     * @param RequestInterface|null          $request
141
-     * @param EE_Maintenance_Mode|null $maintenance_mode
142
-     * @return EE_System
143
-     */
144
-    public static function instance(
145
-        EE_Registry $registry = null,
146
-        LoaderInterface $loader = null,
147
-        RequestInterface $request = null,
148
-        EE_Maintenance_Mode $maintenance_mode = null
149
-    ) {
150
-        // check if class object is instantiated
151
-        if (! self::$_instance instanceof EE_System) {
152
-            self::$_instance = new self($registry, $loader, $request, $maintenance_mode);
153
-        }
154
-        return self::$_instance;
155
-    }
156
-
157
-
158
-
159
-    /**
160
-     * resets the instance and returns it
161
-     *
162
-     * @return EE_System
163
-     */
164
-    public static function reset()
165
-    {
166
-        self::$_instance->_req_type = null;
167
-        //make sure none of the old hooks are left hanging around
168
-        remove_all_actions('AHEE__EE_System__perform_activations_upgrades_and_migrations');
169
-        //we need to reset the migration manager in order for it to detect DMSs properly
170
-        EE_Data_Migration_Manager::reset();
171
-        self::instance()->detect_activations_or_upgrades();
172
-        self::instance()->perform_activations_upgrades_and_migrations();
173
-        return self::instance();
174
-    }
175
-
176
-
177
-
178
-    /**
179
-     * sets hooks for running rest of system
180
-     * provides "AHEE__EE_System__construct__complete" hook for EE Addons to use as their starting point
181
-     * starting EE Addons from any other point may lead to problems
182
-     *
183
-     * @param EE_Registry         $registry
184
-     * @param LoaderInterface     $loader
185
-     * @param RequestInterface          $request
186
-     * @param EE_Maintenance_Mode $maintenance_mode
187
-     */
188
-    private function __construct(
189
-        EE_Registry $registry,
190
-        LoaderInterface $loader,
191
-        RequestInterface $request,
192
-        EE_Maintenance_Mode $maintenance_mode
193
-    ) {
194
-        $this->registry         = $registry;
195
-        $this->loader           = $loader;
196
-        $this->request          = $request;
197
-        $this->maintenance_mode = $maintenance_mode;
198
-        do_action('AHEE__EE_System__construct__begin', $this);
199
-        add_action(
200
-            'AHEE__EE_Bootstrap__load_espresso_addons',
201
-            array($this, 'loadCapabilities'),
202
-            5
203
-        );
204
-        add_action(
205
-            'AHEE__EE_Bootstrap__load_espresso_addons',
206
-            array($this, 'loadCommandBus'),
207
-            7
208
-        );
209
-        add_action(
210
-            'AHEE__EE_Bootstrap__load_espresso_addons',
211
-            array($this, 'loadPluginApi'),
212
-            9
213
-        );
214
-        // allow addons to load first so that they can register autoloaders, set hooks for running DMS's, etc
215
-        add_action(
216
-            'AHEE__EE_Bootstrap__load_espresso_addons',
217
-            array($this, 'load_espresso_addons')
218
-        );
219
-        // when an ee addon is activated, we want to call the core hook(s) again
220
-        // because the newly-activated addon didn't get a chance to run at all
221
-        add_action('activate_plugin', array($this, 'load_espresso_addons'), 1);
222
-        // detect whether install or upgrade
223
-        add_action(
224
-            'AHEE__EE_Bootstrap__detect_activations_or_upgrades',
225
-            array($this, 'detect_activations_or_upgrades'),
226
-            3
227
-        );
228
-        // load EE_Config, EE_Textdomain, etc
229
-        add_action(
230
-            'AHEE__EE_Bootstrap__load_core_configuration',
231
-            array($this, 'load_core_configuration'),
232
-            5
233
-        );
234
-        // load EE_Config, EE_Textdomain, etc
235
-        add_action(
236
-            'AHEE__EE_Bootstrap__register_shortcodes_modules_and_widgets',
237
-            array($this, 'register_shortcodes_modules_and_widgets'),
238
-            7
239
-        );
240
-        // you wanna get going? I wanna get going... let's get going!
241
-        add_action(
242
-            'AHEE__EE_Bootstrap__brew_espresso',
243
-            array($this, 'brew_espresso'),
244
-            9
245
-        );
246
-        //other housekeeping
247
-        //exclude EE critical pages from wp_list_pages
248
-        add_filter(
249
-            'wp_list_pages_excludes',
250
-            array($this, 'remove_pages_from_wp_list_pages'),
251
-            10
252
-        );
253
-        // ALL EE Addons should use the following hook point to attach their initial setup too
254
-        // it's extremely important for EE Addons to register any class autoloaders so that they can be available when the EE_Config loads
255
-        do_action('AHEE__EE_System__construct__complete', $this);
256
-    }
257
-
258
-
259
-    /**
260
-     * load and setup EE_Capabilities
261
-     *
262
-     * @return void
263
-     * @throws EE_Error
264
-     */
265
-    public function loadCapabilities()
266
-    {
267
-        $this->capabilities = $this->loader->getShared('EE_Capabilities');
268
-        add_action(
269
-            'AHEE__EE_Capabilities__init_caps__before_initialization',
270
-            function ()
271
-            {
272
-                LoaderFactory::getLoader()->getShared('EE_Payment_Method_Manager');
273
-            }
274
-        );
275
-    }
276
-
277
-
278
-
279
-    /**
280
-     * create and cache the CommandBus, and also add middleware
281
-     * The CapChecker middleware requires the use of EE_Capabilities
282
-     * which is why we need to load the CommandBus after Caps are set up
283
-     *
284
-     * @return void
285
-     * @throws EE_Error
286
-     */
287
-    public function loadCommandBus()
288
-    {
289
-        $this->loader->getShared(
290
-            'CommandBusInterface',
291
-            array(
292
-                null,
293
-                apply_filters(
294
-                    'FHEE__EE_Load_Espresso_Core__handle_request__CommandBus_middleware',
295
-                    array(
296
-                        $this->loader->getShared('EventEspresso\core\services\commands\middleware\CapChecker'),
297
-                        $this->loader->getShared('EventEspresso\core\services\commands\middleware\AddActionHook'),
298
-                    )
299
-                ),
300
-            )
301
-        );
302
-    }
303
-
304
-
305
-
306
-    /**
307
-     * @return void
308
-     * @throws EE_Error
309
-     */
310
-    public function loadPluginApi()
311
-    {
312
-        // set autoloaders for all of the classes implementing EEI_Plugin_API
313
-        // which provide helpers for EE plugin authors to more easily register certain components with EE.
314
-        EEH_Autoloader::instance()->register_autoloaders_for_each_file_in_folder(EE_LIBRARIES . 'plugin_api');
315
-        $this->loader->getShared('EE_Request_Handler');
316
-    }
317
-
318
-
319
-    /**
320
-     * @param string $addon_name
321
-     * @param string $version_constant
322
-     * @param string $min_version_required
323
-     * @param string $load_callback
324
-     * @param string $plugin_file_constant
325
-     * @return void
326
-     */
327
-    private function deactivateIncompatibleAddon(
328
-        $addon_name,
329
-        $version_constant,
330
-        $min_version_required,
331
-        $load_callback,
332
-        $plugin_file_constant
333
-    ) {
334
-        if (! defined($version_constant)) {
335
-            return;
336
-        }
337
-        $addon_version = constant($version_constant);
338
-        if ($addon_version && version_compare($addon_version, $min_version_required, '<')) {
339
-            remove_action('AHEE__EE_System__load_espresso_addons', $load_callback);
340
-            if (! function_exists('deactivate_plugins')) {
341
-                require_once ABSPATH . 'wp-admin/includes/plugin.php';
342
-            }
343
-            deactivate_plugins(plugin_basename(constant($plugin_file_constant)));
344
-            unset($_GET['activate'], $_REQUEST['activate'], $_GET['activate-multi'], $_REQUEST['activate-multi']);
345
-            EE_Error::add_error(
346
-                sprintf(
347
-                    esc_html__(
348
-                        'We\'re sorry, but the Event Espresso %1$s addon was deactivated because version %2$s or higher is required with this version of Event Espresso core.',
349
-                        'event_espresso'
350
-                    ),
351
-                    $addon_name,
352
-                    $min_version_required
353
-                ),
354
-                __FILE__, __FUNCTION__ . "({$addon_name})", __LINE__
355
-            );
356
-            EE_Error::get_notices(false, true);
357
-        }
358
-    }
359
-
360
-
361
-    /**
362
-     * load_espresso_addons
363
-     * allow addons to load first so that they can set hooks for running DMS's, etc
364
-     * this is hooked into both:
365
-     *    'AHEE__EE_Bootstrap__load_core_configuration'
366
-     *        which runs during the WP 'plugins_loaded' action at priority 5
367
-     *    and the WP 'activate_plugin' hook point
368
-     *
369
-     * @access public
370
-     * @return void
371
-     */
372
-    public function load_espresso_addons()
373
-    {
374
-        $this->deactivateIncompatibleAddon(
375
-            'Wait Lists',
376
-            'EE_WAIT_LISTS_VERSION',
377
-            '1.0.0.beta.074',
378
-            'load_espresso_wait_lists',
379
-            'EE_WAIT_LISTS_PLUGIN_FILE'
380
-        );
381
-        $this->deactivateIncompatibleAddon(
382
-            'Automated Upcoming Event Notifications',
383
-            'EE_AUTOMATED_UPCOMING_EVENT_NOTIFICATION_VERSION',
384
-            '1.0.0.beta.091',
385
-            'load_espresso_automated_upcoming_event_notification',
386
-            'EE_AUTOMATED_UPCOMING_EVENT_NOTIFICATION_PLUGIN_FILE'
387
-        );
388
-        do_action('AHEE__EE_System__load_espresso_addons');
389
-        //if the WP API basic auth plugin isn't already loaded, load it now.
390
-        //We want it for mobile apps. Just include the entire plugin
391
-        //also, don't load the basic auth when a plugin is getting activated, because
392
-        //it could be the basic auth plugin, and it doesn't check if its methods are already defined
393
-        //and causes a fatal error
394
-        if (
395
-            $this->request->getRequestParam('activate') !== 'true'
396
-            && ! function_exists('json_basic_auth_handler')
397
-            && ! function_exists('json_basic_auth_error')
398
-            && ! in_array(
399
-                $this->request->getRequestParam('action'),
400
-                array('activate', 'activate-selected'),
401
-                true
402
-            )
403
-        ) {
404
-            include_once EE_THIRD_PARTY . 'wp-api-basic-auth' . DS . 'basic-auth.php';
405
-        }
406
-        do_action('AHEE__EE_System__load_espresso_addons__complete');
407
-    }
408
-
409
-
410
-
411
-    /**
412
-     * detect_activations_or_upgrades
413
-     * Checks for activation or upgrade of core first;
414
-     * then also checks if any registered addons have been activated or upgraded
415
-     * This is hooked into 'AHEE__EE_Bootstrap__detect_activations_or_upgrades'
416
-     * which runs during the WP 'plugins_loaded' action at priority 3
417
-     *
418
-     * @access public
419
-     * @return void
420
-     */
421
-    public function detect_activations_or_upgrades()
422
-    {
423
-        //first off: let's make sure to handle core
424
-        $this->detect_if_activation_or_upgrade();
425
-        foreach ($this->registry->addons as $addon) {
426
-            if ($addon instanceof EE_Addon) {
427
-                //detect teh request type for that addon
428
-                $addon->detect_activation_or_upgrade();
429
-            }
430
-        }
431
-    }
432
-
433
-
434
-
435
-    /**
436
-     * detect_if_activation_or_upgrade
437
-     * Takes care of detecting whether this is a brand new install or code upgrade,
438
-     * and either setting up the DB or setting up maintenance mode etc.
439
-     *
440
-     * @access public
441
-     * @return void
442
-     */
443
-    public function detect_if_activation_or_upgrade()
444
-    {
445
-        do_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin');
446
-        // check if db has been updated, or if its a brand-new installation
447
-        $espresso_db_update = $this->fix_espresso_db_upgrade_option();
448
-        $request_type       = $this->detect_req_type($espresso_db_update);
449
-        //EEH_Debug_Tools::printr( $request_type, '$request_type', __FILE__, __LINE__ );
450
-        switch ($request_type) {
451
-            case EE_System::req_type_new_activation:
452
-                do_action('AHEE__EE_System__detect_if_activation_or_upgrade__new_activation');
453
-                $this->_handle_core_version_change($espresso_db_update);
454
-                break;
455
-            case EE_System::req_type_reactivation:
456
-                do_action('AHEE__EE_System__detect_if_activation_or_upgrade__reactivation');
457
-                $this->_handle_core_version_change($espresso_db_update);
458
-                break;
459
-            case EE_System::req_type_upgrade:
460
-                do_action('AHEE__EE_System__detect_if_activation_or_upgrade__upgrade');
461
-                //migrations may be required now that we've upgraded
462
-                $this->maintenance_mode->set_maintenance_mode_if_db_old();
463
-                $this->_handle_core_version_change($espresso_db_update);
464
-                //				echo "done upgrade";die;
465
-                break;
466
-            case EE_System::req_type_downgrade:
467
-                do_action('AHEE__EE_System__detect_if_activation_or_upgrade__downgrade');
468
-                //its possible migrations are no longer required
469
-                $this->maintenance_mode->set_maintenance_mode_if_db_old();
470
-                $this->_handle_core_version_change($espresso_db_update);
471
-                break;
472
-            case EE_System::req_type_normal:
473
-            default:
474
-                break;
475
-        }
476
-        do_action('AHEE__EE_System__detect_if_activation_or_upgrade__complete');
477
-    }
478
-
479
-
480
-
481
-    /**
482
-     * Updates the list of installed versions and sets hooks for
483
-     * initializing the database later during the request
484
-     *
485
-     * @param array $espresso_db_update
486
-     */
487
-    private function _handle_core_version_change($espresso_db_update)
488
-    {
489
-        $this->update_list_of_installed_versions($espresso_db_update);
490
-        //get ready to verify the DB is ok (provided we aren't in maintenance mode, of course)
491
-        add_action(
492
-            'AHEE__EE_System__perform_activations_upgrades_and_migrations',
493
-            array($this, 'initialize_db_if_no_migrations_required')
494
-        );
495
-    }
496
-
497
-
498
-
499
-    /**
500
-     * standardizes the wp option 'espresso_db_upgrade' which actually stores
501
-     * information about what versions of EE have been installed and activated,
502
-     * NOT necessarily the state of the database
503
-     *
504
-     * @param mixed $espresso_db_update           the value of the WordPress option.
505
-     *                                            If not supplied, fetches it from the options table
506
-     * @return array the correct value of 'espresso_db_upgrade', after saving it, if it needed correction
507
-     */
508
-    private function fix_espresso_db_upgrade_option($espresso_db_update = null)
509
-    {
510
-        do_action('FHEE__EE_System__manage_fix_espresso_db_upgrade_option__begin', $espresso_db_update);
511
-        if (! $espresso_db_update) {
512
-            $espresso_db_update = get_option('espresso_db_update');
513
-        }
514
-        // check that option is an array
515
-        if (! is_array($espresso_db_update)) {
516
-            // if option is FALSE, then it never existed
517
-            if ($espresso_db_update === false) {
518
-                // make $espresso_db_update an array and save option with autoload OFF
519
-                $espresso_db_update = array();
520
-                add_option('espresso_db_update', $espresso_db_update, '', 'no');
521
-            } else {
522
-                // option is NOT FALSE but also is NOT an array, so make it an array and save it
523
-                $espresso_db_update = array($espresso_db_update => array());
524
-                update_option('espresso_db_update', $espresso_db_update);
525
-            }
526
-        } else {
527
-            $corrected_db_update = array();
528
-            //if IS an array, but is it an array where KEYS are version numbers, and values are arrays?
529
-            foreach ($espresso_db_update as $should_be_version_string => $should_be_array) {
530
-                if (is_int($should_be_version_string) && ! is_array($should_be_array)) {
531
-                    //the key is an int, and the value IS NOT an array
532
-                    //so it must be numerically-indexed, where values are versions installed...
533
-                    //fix it!
534
-                    $version_string                         = $should_be_array;
535
-                    $corrected_db_update[ $version_string ] = array('unknown-date');
536
-                } else {
537
-                    //ok it checks out
538
-                    $corrected_db_update[ $should_be_version_string ] = $should_be_array;
539
-                }
540
-            }
541
-            $espresso_db_update = $corrected_db_update;
542
-            update_option('espresso_db_update', $espresso_db_update);
543
-        }
544
-        do_action('FHEE__EE_System__manage_fix_espresso_db_upgrade_option__complete', $espresso_db_update);
545
-        return $espresso_db_update;
546
-    }
547
-
548
-
549
-
550
-    /**
551
-     * Does the traditional work of setting up the plugin's database and adding default data.
552
-     * If migration script/process did not exist, this is what would happen on every activation/reactivation/upgrade.
553
-     * NOTE: if we're in maintenance mode (which would be the case if we detect there are data
554
-     * migration scripts that need to be run and a version change happens), enqueues core for database initialization,
555
-     * so that it will be done when migrations are finished
556
-     *
557
-     * @param boolean $initialize_addons_too if true, we double-check addons' database tables etc too;
558
-     * @param boolean $verify_schema         if true will re-check the database tables have the correct schema.
559
-     *                                       This is a resource-intensive job
560
-     *                                       so we prefer to only do it when necessary
561
-     * @return void
562
-     * @throws EE_Error
563
-     */
564
-    public function initialize_db_if_no_migrations_required($initialize_addons_too = false, $verify_schema = true)
565
-    {
566
-        $request_type = $this->detect_req_type();
567
-        //only initialize system if we're not in maintenance mode.
568
-        if ($this->maintenance_mode->level() !== EE_Maintenance_Mode::level_2_complete_maintenance) {
569
-            update_option('ee_flush_rewrite_rules', true);
570
-            if ($verify_schema) {
571
-                EEH_Activation::initialize_db_and_folders();
572
-            }
573
-            EEH_Activation::initialize_db_content();
574
-            EEH_Activation::system_initialization();
575
-            if ($initialize_addons_too) {
576
-                $this->initialize_addons();
577
-            }
578
-        } else {
579
-            EE_Data_Migration_Manager::instance()->enqueue_db_initialization_for('Core');
580
-        }
581
-        if ($request_type === EE_System::req_type_new_activation
582
-            || $request_type === EE_System::req_type_reactivation
583
-            || (
584
-                $request_type === EE_System::req_type_upgrade
585
-                && $this->is_major_version_change()
586
-            )
587
-        ) {
588
-            add_action('AHEE__EE_System__initialize_last', array($this, 'redirect_to_about_ee'), 9);
589
-        }
590
-    }
591
-
592
-
593
-
594
-    /**
595
-     * Initializes the db for all registered addons
596
-     *
597
-     * @throws EE_Error
598
-     */
599
-    public function initialize_addons()
600
-    {
601
-        //foreach registered addon, make sure its db is up-to-date too
602
-        foreach ($this->registry->addons as $addon) {
603
-            if ($addon instanceof EE_Addon) {
604
-                $addon->initialize_db_if_no_migrations_required();
605
-            }
606
-        }
607
-    }
608
-
609
-
610
-
611
-    /**
612
-     * Adds the current code version to the saved wp option which stores a list of all ee versions ever installed.
613
-     *
614
-     * @param    array  $version_history
615
-     * @param    string $current_version_to_add version to be added to the version history
616
-     * @return    boolean success as to whether or not this option was changed
617
-     */
618
-    public function update_list_of_installed_versions($version_history = null, $current_version_to_add = null)
619
-    {
620
-        if (! $version_history) {
621
-            $version_history = $this->fix_espresso_db_upgrade_option($version_history);
622
-        }
623
-        if ($current_version_to_add === null) {
624
-            $current_version_to_add = espresso_version();
625
-        }
626
-        $version_history[ $current_version_to_add ][] = date('Y-m-d H:i:s', time());
627
-        // re-save
628
-        return update_option('espresso_db_update', $version_history);
629
-    }
630
-
631
-
632
-
633
-    /**
634
-     * Detects if the current version indicated in the has existed in the list of
635
-     * previously-installed versions of EE (espresso_db_update). Does NOT modify it (ie, no side-effect)
636
-     *
637
-     * @param array $espresso_db_update array from the wp option stored under the name 'espresso_db_update'.
638
-     *                                  If not supplied, fetches it from the options table.
639
-     *                                  Also, caches its result so later parts of the code can also know whether
640
-     *                                  there's been an update or not. This way we can add the current version to
641
-     *                                  espresso_db_update, but still know if this is a new install or not
642
-     * @return int one of the constants on EE_System::req_type_
643
-     */
644
-    public function detect_req_type($espresso_db_update = null)
645
-    {
646
-        if ($this->_req_type === null) {
647
-            $espresso_db_update          = ! empty($espresso_db_update)
648
-                ? $espresso_db_update
649
-                : $this->fix_espresso_db_upgrade_option();
650
-            $this->_req_type             = EE_System::detect_req_type_given_activation_history(
651
-                $espresso_db_update,
652
-                'ee_espresso_activation', espresso_version()
653
-            );
654
-            $this->_major_version_change = $this->_detect_major_version_change($espresso_db_update);
655
-            $this->request->setIsActivation($this->_req_type !== EE_System::req_type_normal);
656
-        }
657
-        return $this->_req_type;
658
-    }
659
-
660
-
661
-
662
-    /**
663
-     * Returns whether or not there was a non-micro version change (ie, change in either
664
-     * the first or second number in the version. Eg 4.9.0.rc.001 to 4.10.0.rc.000,
665
-     * but not 4.9.0.rc.0001 to 4.9.1.rc.0001
666
-     *
667
-     * @param $activation_history
668
-     * @return bool
669
-     */
670
-    private function _detect_major_version_change($activation_history)
671
-    {
672
-        $previous_version       = EE_System::_get_most_recently_active_version_from_activation_history($activation_history);
673
-        $previous_version_parts = explode('.', $previous_version);
674
-        $current_version_parts  = explode('.', espresso_version());
675
-        return isset($previous_version_parts[0], $previous_version_parts[1], $current_version_parts[0], $current_version_parts[1])
676
-               && ($previous_version_parts[0] !== $current_version_parts[0]
677
-                   || $previous_version_parts[1] !== $current_version_parts[1]
678
-               );
679
-    }
680
-
681
-
682
-
683
-    /**
684
-     * Returns true if either the major or minor version of EE changed during this request.
685
-     * Eg 4.9.0.rc.001 to 4.10.0.rc.000, but not 4.9.0.rc.0001 to 4.9.1.rc.0001
686
-     *
687
-     * @return bool
688
-     */
689
-    public function is_major_version_change()
690
-    {
691
-        return $this->_major_version_change;
692
-    }
693
-
694
-
695
-
696
-    /**
697
-     * Determines the request type for any ee addon, given three piece of info: the current array of activation
698
-     * histories (for core that' 'espresso_db_update' wp option); the name of the WordPress option which is temporarily
699
-     * set upon activation of the plugin (for core it's 'ee_espresso_activation'); and the version that this plugin was
700
-     * just activated to (for core that will always be espresso_version())
701
-     *
702
-     * @param array  $activation_history_for_addon     the option's value which stores the activation history for this
703
-     *                                                 ee plugin. for core that's 'espresso_db_update'
704
-     * @param string $activation_indicator_option_name the name of the WordPress option that is temporarily set to
705
-     *                                                 indicate that this plugin was just activated
706
-     * @param string $version_to_upgrade_to            the version that was just upgraded to (for core that will be
707
-     *                                                 espresso_version())
708
-     * @return int one of the constants on EE_System::req_type_*
709
-     */
710
-    public static function detect_req_type_given_activation_history(
711
-        $activation_history_for_addon,
712
-        $activation_indicator_option_name,
713
-        $version_to_upgrade_to
714
-    ) {
715
-        $version_is_higher = self::_new_version_is_higher($activation_history_for_addon, $version_to_upgrade_to);
716
-        if ($activation_history_for_addon) {
717
-            //it exists, so this isn't a completely new install
718
-            //check if this version already in that list of previously installed versions
719
-            if (! isset($activation_history_for_addon[ $version_to_upgrade_to ])) {
720
-                //it a version we haven't seen before
721
-                if ($version_is_higher === 1) {
722
-                    $req_type = EE_System::req_type_upgrade;
723
-                } else {
724
-                    $req_type = EE_System::req_type_downgrade;
725
-                }
726
-                delete_option($activation_indicator_option_name);
727
-            } else {
728
-                // its not an update. maybe a reactivation?
729
-                if (get_option($activation_indicator_option_name, false)) {
730
-                    if ($version_is_higher === -1) {
731
-                        $req_type = EE_System::req_type_downgrade;
732
-                    } elseif ($version_is_higher === 0) {
733
-                        //we've seen this version before, but it's an activation. must be a reactivation
734
-                        $req_type = EE_System::req_type_reactivation;
735
-                    } else {//$version_is_higher === 1
736
-                        $req_type = EE_System::req_type_upgrade;
737
-                    }
738
-                    delete_option($activation_indicator_option_name);
739
-                } else {
740
-                    //we've seen this version before and the activation indicate doesn't show it was just activated
741
-                    if ($version_is_higher === -1) {
742
-                        $req_type = EE_System::req_type_downgrade;
743
-                    } elseif ($version_is_higher === 0) {
744
-                        //we've seen this version before and it's not an activation. its normal request
745
-                        $req_type = EE_System::req_type_normal;
746
-                    } else {//$version_is_higher === 1
747
-                        $req_type = EE_System::req_type_upgrade;
748
-                    }
749
-                }
750
-            }
751
-        } else {
752
-            //brand new install
753
-            $req_type = EE_System::req_type_new_activation;
754
-            delete_option($activation_indicator_option_name);
755
-        }
756
-        return $req_type;
757
-    }
758
-
759
-
760
-
761
-    /**
762
-     * Detects if the $version_to_upgrade_to is higher than the most recent version in
763
-     * the $activation_history_for_addon
764
-     *
765
-     * @param array  $activation_history_for_addon (keys are versions, values are arrays of times activated,
766
-     *                                             sometimes containing 'unknown-date'
767
-     * @param string $version_to_upgrade_to        (current version)
768
-     * @return int results of version_compare( $version_to_upgrade_to, $most_recently_active_version ).
769
-     *                                             ie, -1 if $version_to_upgrade_to is LOWER (downgrade);
770
-     *                                             0 if $version_to_upgrade_to MATCHES (reactivation or normal request);
771
-     *                                             1 if $version_to_upgrade_to is HIGHER (upgrade) ;
772
-     */
773
-    private static function _new_version_is_higher($activation_history_for_addon, $version_to_upgrade_to)
774
-    {
775
-        //find the most recently-activated version
776
-        $most_recently_active_version =
777
-            EE_System::_get_most_recently_active_version_from_activation_history($activation_history_for_addon);
778
-        return version_compare($version_to_upgrade_to, $most_recently_active_version);
779
-    }
780
-
781
-
782
-
783
-    /**
784
-     * Gets the most recently active version listed in the activation history,
785
-     * and if none are found (ie, it's a brand new install) returns '0.0.0.dev.000'.
786
-     *
787
-     * @param array $activation_history  (keys are versions, values are arrays of times activated,
788
-     *                                   sometimes containing 'unknown-date'
789
-     * @return string
790
-     */
791
-    private static function _get_most_recently_active_version_from_activation_history($activation_history)
792
-    {
793
-        $most_recently_active_version_activation = '1970-01-01 00:00:00';
794
-        $most_recently_active_version            = '0.0.0.dev.000';
795
-        if (is_array($activation_history)) {
796
-            foreach ($activation_history as $version => $times_activated) {
797
-                //check there is a record of when this version was activated. Otherwise,
798
-                //mark it as unknown
799
-                if (! $times_activated) {
800
-                    $times_activated = array('unknown-date');
801
-                }
802
-                if (is_string($times_activated)) {
803
-                    $times_activated = array($times_activated);
804
-                }
805
-                foreach ($times_activated as $an_activation) {
806
-                    if ($an_activation !== 'unknown-date'
807
-                        && $an_activation
808
-                           > $most_recently_active_version_activation) {
809
-                        $most_recently_active_version            = $version;
810
-                        $most_recently_active_version_activation = $an_activation === 'unknown-date'
811
-                            ? '1970-01-01 00:00:00'
812
-                            : $an_activation;
813
-                    }
814
-                }
815
-            }
816
-        }
817
-        return $most_recently_active_version;
818
-    }
819
-
820
-
821
-
822
-    /**
823
-     * This redirects to the about EE page after activation
824
-     *
825
-     * @return void
826
-     */
827
-    public function redirect_to_about_ee()
828
-    {
829
-        $notices = EE_Error::get_notices(false);
830
-        //if current user is an admin and it's not an ajax or rest request
831
-        if (
832
-            ! isset($notices['errors'])
833
-            && $this->request->isAdmin()
834
-            && apply_filters(
835
-                'FHEE__EE_System__redirect_to_about_ee__do_redirect',
836
-                $this->capabilities->current_user_can('manage_options', 'espresso_about_default')
837
-            )
838
-        ) {
839
-            $query_params = array('page' => 'espresso_about');
840
-            if (EE_System::instance()->detect_req_type() === EE_System::req_type_new_activation) {
841
-                $query_params['new_activation'] = true;
842
-            }
843
-            if (EE_System::instance()->detect_req_type() === EE_System::req_type_reactivation) {
844
-                $query_params['reactivation'] = true;
845
-            }
846
-            $url = add_query_arg($query_params, admin_url('admin.php'));
847
-            wp_safe_redirect($url);
848
-            exit();
849
-        }
850
-    }
851
-
852
-
853
-
854
-    /**
855
-     * load_core_configuration
856
-     * this is hooked into 'AHEE__EE_Bootstrap__load_core_configuration'
857
-     * which runs during the WP 'plugins_loaded' action at priority 5
858
-     *
859
-     * @return void
860
-     * @throws ReflectionException
861
-     */
862
-    public function load_core_configuration()
863
-    {
864
-        do_action('AHEE__EE_System__load_core_configuration__begin', $this);
865
-        $this->loader->getShared('EE_Load_Textdomain');
866
-        //load textdomain
867
-        EE_Load_Textdomain::load_textdomain();
868
-        // load and setup EE_Config and EE_Network_Config
869
-        $config = $this->loader->getShared('EE_Config');
870
-        $this->loader->getShared('EE_Network_Config');
871
-        // setup autoloaders
872
-        // enable logging?
873
-        if ($config->admin->use_full_logging) {
874
-            $this->loader->getShared('EE_Log');
875
-        }
876
-        // check for activation errors
877
-        $activation_errors = get_option('ee_plugin_activation_errors', false);
878
-        if ($activation_errors) {
879
-            EE_Error::add_error($activation_errors, __FILE__, __FUNCTION__, __LINE__);
880
-            update_option('ee_plugin_activation_errors', false);
881
-        }
882
-        // get model names
883
-        $this->_parse_model_names();
884
-        //load caf stuff a chance to play during the activation process too.
885
-        $this->_maybe_brew_regular();
886
-        do_action('AHEE__EE_System__load_core_configuration__complete', $this);
887
-    }
888
-
889
-
890
-
891
-    /**
892
-     * cycles through all of the models/*.model.php files, and assembles an array of model names
893
-     *
894
-     * @return void
895
-     * @throws ReflectionException
896
-     */
897
-    private function _parse_model_names()
898
-    {
899
-        //get all the files in the EE_MODELS folder that end in .model.php
900
-        $models                 = glob(EE_MODELS . '*.model.php');
901
-        $model_names            = array();
902
-        $non_abstract_db_models = array();
903
-        foreach ($models as $model) {
904
-            // get model classname
905
-            $classname       = EEH_File::get_classname_from_filepath_with_standard_filename($model);
906
-            $short_name      = str_replace('EEM_', '', $classname);
907
-            $reflectionClass = new ReflectionClass($classname);
908
-            if ($reflectionClass->isSubclassOf('EEM_Base') && ! $reflectionClass->isAbstract()) {
909
-                $non_abstract_db_models[ $short_name ] = $classname;
910
-            }
911
-            $model_names[ $short_name ] = $classname;
912
-        }
913
-        $this->registry->models                 = apply_filters('FHEE__EE_System__parse_model_names', $model_names);
914
-        $this->registry->non_abstract_db_models = apply_filters(
915
-            'FHEE__EE_System__parse_implemented_model_names',
916
-            $non_abstract_db_models
917
-        );
918
-    }
919
-
920
-
921
-    /**
922
-     * The purpose of this method is to simply check for a file named "caffeinated/brewing_regular.php" for any hooks
923
-     * that need to be setup before our EE_System launches.
924
-     *
925
-     * @return void
926
-     * @throws DomainException
927
-     * @throws InvalidArgumentException
928
-     * @throws InvalidDataTypeException
929
-     * @throws InvalidInterfaceException
930
-     * @throws InvalidClassException
931
-     * @throws InvalidFilePathException
932
-     */
933
-    private function _maybe_brew_regular()
934
-    {
935
-        /** @var Domain $domain */
936
-        $domain = DomainFactory::getShared(
937
-            new FullyQualifiedName(
938
-                'EventEspresso\core\domain\Domain'
939
-            ),
940
-            array(
941
-                new FilePath(EVENT_ESPRESSO_MAIN_FILE),
942
-                Version::fromString(espresso_version())
943
-            )
944
-        );
945
-        if ($domain->isCaffeinated()) {
946
-            require_once EE_CAFF_PATH . 'brewing_regular.php';
947
-        }
948
-    }
949
-
950
-
951
-
952
-    /**
953
-     * register_shortcodes_modules_and_widgets
954
-     * generate lists of shortcodes and modules, then verify paths and classes
955
-     * This is hooked into 'AHEE__EE_Bootstrap__register_shortcodes_modules_and_widgets'
956
-     * which runs during the WP 'plugins_loaded' action at priority 7
957
-     *
958
-     * @access public
959
-     * @return void
960
-     * @throws Exception
961
-     */
962
-    public function register_shortcodes_modules_and_widgets()
963
-    {
964
-        try {
965
-            // load, register, and add shortcodes the new way
966
-            if ($this->request->isFrontend() || $this->request->isIframe()) {
967
-                $this->loader->getShared(
968
-                    'EventEspresso\core\services\shortcodes\ShortcodesManager',
969
-                    array(
970
-                        // and the old way, but we'll put it under control of the new system
971
-                        EE_Config::getLegacyShortcodesManager(),
972
-                    )
973
-                );
974
-            }
975
-            if (function_exists('register_block_type')) {
976
-                // or the even newer newer new way
977
-                if ($this->request->isFrontend() || $this->request->isIframe() || $this->request->isAdmin()) {
978
-                    $this->loader->getShared(
979
-                        'EventEspresso\core\services\editor\BlockRegistrationManager'
980
-                    );
981
-                }
982
-            }
983
-        } catch (Exception $exception) {
984
-            new ExceptionStackTraceDisplay($exception);
985
-        }
986
-        do_action('AHEE__EE_System__register_shortcodes_modules_and_widgets');
987
-        // check for addons using old hook point
988
-        if (has_action('AHEE__EE_System__register_shortcodes_modules_and_addons')) {
989
-            $this->_incompatible_addon_error();
990
-        }
991
-    }
992
-
993
-
994
-
995
-    /**
996
-     * _incompatible_addon_error
997
-     *
998
-     * @access public
999
-     * @return void
1000
-     */
1001
-    private function _incompatible_addon_error()
1002
-    {
1003
-        // get array of classes hooking into here
1004
-        $class_names = EEH_Class_Tools::get_class_names_for_all_callbacks_on_hook(
1005
-            'AHEE__EE_System__register_shortcodes_modules_and_addons'
1006
-        );
1007
-        if (! empty($class_names)) {
1008
-            $msg = __(
1009
-                'The following plugins, addons, or modules appear to be incompatible with this version of Event Espresso and were automatically deactivated to avoid fatal errors:',
1010
-                'event_espresso'
1011
-            );
1012
-            $msg .= '<ul>';
1013
-            foreach ($class_names as $class_name) {
1014
-                $msg .= '<li><b>Event Espresso - ' . str_replace(
1015
-                        array('EE_', 'EEM_', 'EED_', 'EES_', 'EEW_'), '',
1016
-                        $class_name
1017
-                    ) . '</b></li>';
1018
-            }
1019
-            $msg .= '</ul>';
1020
-            $msg .= __(
1021
-                'Compatibility issues can be avoided and/or resolved by keeping addons and plugins updated to the latest version.',
1022
-                'event_espresso'
1023
-            );
1024
-            // save list of incompatible addons to wp-options for later use
1025
-            add_option('ee_incompatible_addons', $class_names, '', 'no');
1026
-            if (is_admin()) {
1027
-                EE_Error::add_error($msg, __FILE__, __FUNCTION__, __LINE__);
1028
-            }
1029
-        }
1030
-    }
1031
-
1032
-
1033
-
1034
-    /**
1035
-     * brew_espresso
1036
-     * begins the process of setting hooks for initializing EE in the correct order
1037
-     * This is happening on the 'AHEE__EE_Bootstrap__brew_espresso' hook point
1038
-     * which runs during the WP 'plugins_loaded' action at priority 9
1039
-     *
1040
-     * @return void
1041
-     */
1042
-    public function brew_espresso()
1043
-    {
1044
-        do_action('AHEE__EE_System__brew_espresso__begin', $this);
1045
-        // load some final core systems
1046
-        add_action('init', array($this, 'set_hooks_for_core'), 1);
1047
-        add_action('init', array($this, 'perform_activations_upgrades_and_migrations'), 3);
1048
-        add_action('init', array($this, 'load_CPTs_and_session'), 5);
1049
-        add_action('init', array($this, 'load_controllers'), 7);
1050
-        add_action('init', array($this, 'core_loaded_and_ready'), 9);
1051
-        add_action('init', array($this, 'initialize'), 10);
1052
-        add_action('init', array($this, 'initialize_last'), 100);
1053
-        if (is_admin() && apply_filters('FHEE__EE_System__brew_espresso__load_pue', true)) {
1054
-            // pew pew pew
1055
-            $this->loader->getShared('EventEspresso\core\services\licensing\LicenseService');
1056
-            do_action('AHEE__EE_System__brew_espresso__after_pue_init');
1057
-        }
1058
-        do_action('AHEE__EE_System__brew_espresso__complete', $this);
1059
-    }
1060
-
1061
-
1062
-
1063
-    /**
1064
-     *    set_hooks_for_core
1065
-     *
1066
-     * @access public
1067
-     * @return    void
1068
-     * @throws EE_Error
1069
-     */
1070
-    public function set_hooks_for_core()
1071
-    {
1072
-        $this->_deactivate_incompatible_addons();
1073
-        do_action('AHEE__EE_System__set_hooks_for_core');
1074
-        $this->loader->getShared('EventEspresso\core\domain\values\session\SessionLifespan');
1075
-        //caps need to be initialized on every request so that capability maps are set.
1076
-        //@see https://events.codebasehq.com/projects/event-espresso/tickets/8674
1077
-        $this->registry->CAP->init_caps();
1078
-    }
1079
-
1080
-
1081
-
1082
-    /**
1083
-     * Using the information gathered in EE_System::_incompatible_addon_error,
1084
-     * deactivates any addons considered incompatible with the current version of EE
1085
-     */
1086
-    private function _deactivate_incompatible_addons()
1087
-    {
1088
-        $incompatible_addons = get_option('ee_incompatible_addons', array());
1089
-        if (! empty($incompatible_addons)) {
1090
-            $active_plugins = get_option('active_plugins', array());
1091
-            foreach ($active_plugins as $active_plugin) {
1092
-                foreach ($incompatible_addons as $incompatible_addon) {
1093
-                    if (strpos($active_plugin, $incompatible_addon) !== false) {
1094
-                        unset($_GET['activate']);
1095
-                        espresso_deactivate_plugin($active_plugin);
1096
-                    }
1097
-                }
1098
-            }
1099
-        }
1100
-    }
1101
-
1102
-
1103
-
1104
-    /**
1105
-     *    perform_activations_upgrades_and_migrations
1106
-     *
1107
-     * @access public
1108
-     * @return    void
1109
-     */
1110
-    public function perform_activations_upgrades_and_migrations()
1111
-    {
1112
-        do_action('AHEE__EE_System__perform_activations_upgrades_and_migrations');
1113
-    }
1114
-
1115
-
1116
-
1117
-    /**
1118
-     *    load_CPTs_and_session
1119
-     *
1120
-     * @access public
1121
-     * @return    void
1122
-     */
1123
-    public function load_CPTs_and_session()
1124
-    {
1125
-        do_action('AHEE__EE_System__load_CPTs_and_session__start');
1126
-        // register Custom Post Types
1127
-        $this->loader->getShared('EE_Register_CPTs');
1128
-        do_action('AHEE__EE_System__load_CPTs_and_session__complete');
1129
-    }
1130
-
1131
-
1132
-
1133
-    /**
1134
-     * load_controllers
1135
-     * this is the best place to load any additional controllers that needs access to EE core.
1136
-     * it is expected that all basic core EE systems, that are not dependant on the current request are loaded at this
1137
-     * time
1138
-     *
1139
-     * @access public
1140
-     * @return void
1141
-     */
1142
-    public function load_controllers()
1143
-    {
1144
-        do_action('AHEE__EE_System__load_controllers__start');
1145
-        // let's get it started
1146
-        if (
1147
-            ! $this->maintenance_mode->level()
1148
-            && ($this->request->isFrontend() || $this->request->isFrontAjax())
1149
-        ) {
1150
-            do_action('AHEE__EE_System__load_controllers__load_front_controllers');
1151
-            $this->loader->getShared('EE_Front_Controller');
1152
-        } elseif ($this->request->isAdmin() || $this->request->isAdminAjax()) {
1153
-            do_action('AHEE__EE_System__load_controllers__load_admin_controllers');
1154
-            $this->loader->getShared('EE_Admin');
1155
-        }
1156
-        do_action('AHEE__EE_System__load_controllers__complete');
1157
-    }
1158
-
1159
-
1160
-
1161
-    /**
1162
-     * core_loaded_and_ready
1163
-     * all of the basic EE core should be loaded at this point and available regardless of M-Mode
1164
-     *
1165
-     * @access public
1166
-     * @return void
1167
-     */
1168
-    public function core_loaded_and_ready()
1169
-    {
1170
-        if (
1171
-            $this->request->isAdmin()
1172
-            || $this->request->isEeAjax()
1173
-            || $this->request->isFrontend()
1174
-        ) {
1175
-            $this->loader->getShared('EE_Session');
1176
-        }
1177
-        do_action('AHEE__EE_System__core_loaded_and_ready');
1178
-        // load_espresso_template_tags
1179
-        if (
1180
-            is_readable(EE_PUBLIC . 'template_tags.php')
1181
-            && (
1182
-                $this->request->isFrontend()
1183
-                || $this->request->isAdmin()
1184
-                || $this->request->isIframe()
1185
-                || $this->request->isFeed()
1186
-            )
1187
-        ) {
1188
-            require_once EE_PUBLIC . 'template_tags.php';
1189
-        }
1190
-        do_action('AHEE__EE_System__set_hooks_for_shortcodes_modules_and_addons');
1191
-        if ($this->request->isAdmin() || $this->request->isFrontend() || $this->request->isIframe()) {
1192
-            $this->loader->getShared('EventEspresso\core\services\assets\Registry');
1193
-        }
1194
-    }
1195
-
1196
-
1197
-
1198
-    /**
1199
-     * initialize
1200
-     * this is the best place to begin initializing client code
1201
-     *
1202
-     * @access public
1203
-     * @return void
1204
-     */
1205
-    public function initialize()
1206
-    {
1207
-        do_action('AHEE__EE_System__initialize');
1208
-    }
1209
-
1210
-
1211
-
1212
-    /**
1213
-     * initialize_last
1214
-     * this is run really late during the WP init hook point, and ensures that mostly everything else that needs to
1215
-     * initialize has done so
1216
-     *
1217
-     * @access public
1218
-     * @return void
1219
-     */
1220
-    public function initialize_last()
1221
-    {
1222
-        do_action('AHEE__EE_System__initialize_last');
1223
-        add_action('admin_bar_init', array($this, 'addEspressoToolbar'));
1224
-    }
1225
-
1226
-
1227
-
1228
-    /**
1229
-     * @return void
1230
-     * @throws EE_Error
1231
-     */
1232
-    public function addEspressoToolbar()
1233
-    {
1234
-        $this->loader->getShared(
1235
-            'EventEspresso\core\domain\services\admin\AdminToolBar',
1236
-            array($this->registry->CAP)
1237
-        );
1238
-    }
1239
-
1240
-
1241
-
1242
-    /**
1243
-     * do_not_cache
1244
-     * sets no cache headers and defines no cache constants for WP plugins
1245
-     *
1246
-     * @access public
1247
-     * @return void
1248
-     */
1249
-    public static function do_not_cache()
1250
-    {
1251
-        // set no cache constants
1252
-        if (! defined('DONOTCACHEPAGE')) {
1253
-            define('DONOTCACHEPAGE', true);
1254
-        }
1255
-        if (! defined('DONOTCACHCEOBJECT')) {
1256
-            define('DONOTCACHCEOBJECT', true);
1257
-        }
1258
-        if (! defined('DONOTCACHEDB')) {
1259
-            define('DONOTCACHEDB', true);
1260
-        }
1261
-        // add no cache headers
1262
-        add_action('send_headers', array('EE_System', 'nocache_headers'), 10);
1263
-        // plus a little extra for nginx and Google Chrome
1264
-        add_filter('nocache_headers', array('EE_System', 'extra_nocache_headers'), 10, 1);
1265
-        // prevent browsers from prefetching of the rel='next' link, because it may contain content that interferes with the registration process
1266
-        remove_action('wp_head', 'adjacent_posts_rel_link_wp_head');
1267
-    }
1268
-
1269
-
1270
-
1271
-    /**
1272
-     *    extra_nocache_headers
1273
-     *
1274
-     * @access    public
1275
-     * @param $headers
1276
-     * @return    array
1277
-     */
1278
-    public static function extra_nocache_headers($headers)
1279
-    {
1280
-        // for NGINX
1281
-        $headers['X-Accel-Expires'] = 0;
1282
-        // plus extra for Google Chrome since it doesn't seem to respect "no-cache", but WILL respect "no-store"
1283
-        $headers['Cache-Control'] = 'no-store, no-cache, must-revalidate, max-age=0';
1284
-        return $headers;
1285
-    }
1286
-
1287
-
1288
-
1289
-    /**
1290
-     *    nocache_headers
1291
-     *
1292
-     * @access    public
1293
-     * @return    void
1294
-     */
1295
-    public static function nocache_headers()
1296
-    {
1297
-        nocache_headers();
1298
-    }
1299
-
1300
-
1301
-
1302
-    /**
1303
-     * simply hooks into "wp_list_pages_exclude" filter (for wp_list_pages method) and makes sure EE critical pages are
1304
-     * never returned with the function.
1305
-     *
1306
-     * @param  array $exclude_array any existing pages being excluded are in this array.
1307
-     * @return array
1308
-     */
1309
-    public function remove_pages_from_wp_list_pages($exclude_array)
1310
-    {
1311
-        return array_merge($exclude_array, $this->registry->CFG->core->get_critical_pages_array());
1312
-    }
35
+	/**
36
+	 * indicates this is a 'normal' request. Ie, not activation, nor upgrade, nor activation.
37
+	 * So examples of this would be a normal GET request on the frontend or backend, or a POST, etc
38
+	 */
39
+	const req_type_normal = 0;
40
+
41
+	/**
42
+	 * Indicates this is a brand new installation of EE so we should install
43
+	 * tables and default data etc
44
+	 */
45
+	const req_type_new_activation = 1;
46
+
47
+	/**
48
+	 * we've detected that EE has been reactivated (or EE was activated during maintenance mode,
49
+	 * and we just exited maintenance mode). We MUST check the database is setup properly
50
+	 * and that default data is setup too
51
+	 */
52
+	const req_type_reactivation = 2;
53
+
54
+	/**
55
+	 * indicates that EE has been upgraded since its previous request.
56
+	 * We may have data migration scripts to call and will want to trigger maintenance mode
57
+	 */
58
+	const req_type_upgrade = 3;
59
+
60
+	/**
61
+	 * TODO  will detect that EE has been DOWNGRADED. We probably don't want to run in this case...
62
+	 */
63
+	const req_type_downgrade = 4;
64
+
65
+	/**
66
+	 * @deprecated since version 4.6.0.dev.006
67
+	 * Now whenever a new_activation is detected the request type is still just
68
+	 * new_activation (same for reactivation, upgrade, downgrade etc), but if we'r ein maintenance mode
69
+	 * EE_System::initialize_db_if_no_migrations_required and EE_Addon::initialize_db_if_no_migrations_required
70
+	 * will instead enqueue that EE plugin's db initialization for when we're taken out of maintenance mode.
71
+	 * (Specifically, when the migration manager indicates migrations are finished
72
+	 * EE_Data_Migration_Manager::initialize_db_for_enqueued_ee_plugins() will be called)
73
+	 */
74
+	const req_type_activation_but_not_installed = 5;
75
+
76
+	/**
77
+	 * option prefix for recording the activation history (like core's "espresso_db_update") of addons
78
+	 */
79
+	const addon_activation_history_option_prefix = 'ee_addon_activation_history_';
80
+
81
+
82
+	/**
83
+	 * @var EE_System $_instance
84
+	 */
85
+	private static $_instance;
86
+
87
+	/**
88
+	 * @var EE_Registry $registry
89
+	 */
90
+	private $registry;
91
+
92
+	/**
93
+	 * @var LoaderInterface $loader
94
+	 */
95
+	private $loader;
96
+
97
+	/**
98
+	 * @var EE_Capabilities $capabilities
99
+	 */
100
+	private $capabilities;
101
+
102
+	/**
103
+	 * @var RequestInterface $request
104
+	 */
105
+	private $request;
106
+
107
+	/**
108
+	 * @var EE_Maintenance_Mode $maintenance_mode
109
+	 */
110
+	private $maintenance_mode;
111
+
112
+	/**
113
+	 * Stores which type of request this is, options being one of the constants on EE_System starting with req_type_*.
114
+	 * It can be a brand-new activation, a reactivation, an upgrade, a downgrade, or a normal request.
115
+	 *
116
+	 * @var int $_req_type
117
+	 */
118
+	private $_req_type;
119
+
120
+	/**
121
+	 * Whether or not there was a non-micro version change in EE core version during this request
122
+	 *
123
+	 * @var boolean $_major_version_change
124
+	 */
125
+	private $_major_version_change = false;
126
+
127
+	/**
128
+	 * A Context DTO dedicated solely to identifying the current request type.
129
+	 *
130
+	 * @var RequestTypeContextCheckerInterface $request_type
131
+	 */
132
+	private $request_type;
133
+
134
+
135
+
136
+	/**
137
+	 * @singleton method used to instantiate class object
138
+	 * @param EE_Registry|null         $registry
139
+	 * @param LoaderInterface|null     $loader
140
+	 * @param RequestInterface|null          $request
141
+	 * @param EE_Maintenance_Mode|null $maintenance_mode
142
+	 * @return EE_System
143
+	 */
144
+	public static function instance(
145
+		EE_Registry $registry = null,
146
+		LoaderInterface $loader = null,
147
+		RequestInterface $request = null,
148
+		EE_Maintenance_Mode $maintenance_mode = null
149
+	) {
150
+		// check if class object is instantiated
151
+		if (! self::$_instance instanceof EE_System) {
152
+			self::$_instance = new self($registry, $loader, $request, $maintenance_mode);
153
+		}
154
+		return self::$_instance;
155
+	}
156
+
157
+
158
+
159
+	/**
160
+	 * resets the instance and returns it
161
+	 *
162
+	 * @return EE_System
163
+	 */
164
+	public static function reset()
165
+	{
166
+		self::$_instance->_req_type = null;
167
+		//make sure none of the old hooks are left hanging around
168
+		remove_all_actions('AHEE__EE_System__perform_activations_upgrades_and_migrations');
169
+		//we need to reset the migration manager in order for it to detect DMSs properly
170
+		EE_Data_Migration_Manager::reset();
171
+		self::instance()->detect_activations_or_upgrades();
172
+		self::instance()->perform_activations_upgrades_and_migrations();
173
+		return self::instance();
174
+	}
175
+
176
+
177
+
178
+	/**
179
+	 * sets hooks for running rest of system
180
+	 * provides "AHEE__EE_System__construct__complete" hook for EE Addons to use as their starting point
181
+	 * starting EE Addons from any other point may lead to problems
182
+	 *
183
+	 * @param EE_Registry         $registry
184
+	 * @param LoaderInterface     $loader
185
+	 * @param RequestInterface          $request
186
+	 * @param EE_Maintenance_Mode $maintenance_mode
187
+	 */
188
+	private function __construct(
189
+		EE_Registry $registry,
190
+		LoaderInterface $loader,
191
+		RequestInterface $request,
192
+		EE_Maintenance_Mode $maintenance_mode
193
+	) {
194
+		$this->registry         = $registry;
195
+		$this->loader           = $loader;
196
+		$this->request          = $request;
197
+		$this->maintenance_mode = $maintenance_mode;
198
+		do_action('AHEE__EE_System__construct__begin', $this);
199
+		add_action(
200
+			'AHEE__EE_Bootstrap__load_espresso_addons',
201
+			array($this, 'loadCapabilities'),
202
+			5
203
+		);
204
+		add_action(
205
+			'AHEE__EE_Bootstrap__load_espresso_addons',
206
+			array($this, 'loadCommandBus'),
207
+			7
208
+		);
209
+		add_action(
210
+			'AHEE__EE_Bootstrap__load_espresso_addons',
211
+			array($this, 'loadPluginApi'),
212
+			9
213
+		);
214
+		// allow addons to load first so that they can register autoloaders, set hooks for running DMS's, etc
215
+		add_action(
216
+			'AHEE__EE_Bootstrap__load_espresso_addons',
217
+			array($this, 'load_espresso_addons')
218
+		);
219
+		// when an ee addon is activated, we want to call the core hook(s) again
220
+		// because the newly-activated addon didn't get a chance to run at all
221
+		add_action('activate_plugin', array($this, 'load_espresso_addons'), 1);
222
+		// detect whether install or upgrade
223
+		add_action(
224
+			'AHEE__EE_Bootstrap__detect_activations_or_upgrades',
225
+			array($this, 'detect_activations_or_upgrades'),
226
+			3
227
+		);
228
+		// load EE_Config, EE_Textdomain, etc
229
+		add_action(
230
+			'AHEE__EE_Bootstrap__load_core_configuration',
231
+			array($this, 'load_core_configuration'),
232
+			5
233
+		);
234
+		// load EE_Config, EE_Textdomain, etc
235
+		add_action(
236
+			'AHEE__EE_Bootstrap__register_shortcodes_modules_and_widgets',
237
+			array($this, 'register_shortcodes_modules_and_widgets'),
238
+			7
239
+		);
240
+		// you wanna get going? I wanna get going... let's get going!
241
+		add_action(
242
+			'AHEE__EE_Bootstrap__brew_espresso',
243
+			array($this, 'brew_espresso'),
244
+			9
245
+		);
246
+		//other housekeeping
247
+		//exclude EE critical pages from wp_list_pages
248
+		add_filter(
249
+			'wp_list_pages_excludes',
250
+			array($this, 'remove_pages_from_wp_list_pages'),
251
+			10
252
+		);
253
+		// ALL EE Addons should use the following hook point to attach their initial setup too
254
+		// it's extremely important for EE Addons to register any class autoloaders so that they can be available when the EE_Config loads
255
+		do_action('AHEE__EE_System__construct__complete', $this);
256
+	}
257
+
258
+
259
+	/**
260
+	 * load and setup EE_Capabilities
261
+	 *
262
+	 * @return void
263
+	 * @throws EE_Error
264
+	 */
265
+	public function loadCapabilities()
266
+	{
267
+		$this->capabilities = $this->loader->getShared('EE_Capabilities');
268
+		add_action(
269
+			'AHEE__EE_Capabilities__init_caps__before_initialization',
270
+			function ()
271
+			{
272
+				LoaderFactory::getLoader()->getShared('EE_Payment_Method_Manager');
273
+			}
274
+		);
275
+	}
276
+
277
+
278
+
279
+	/**
280
+	 * create and cache the CommandBus, and also add middleware
281
+	 * The CapChecker middleware requires the use of EE_Capabilities
282
+	 * which is why we need to load the CommandBus after Caps are set up
283
+	 *
284
+	 * @return void
285
+	 * @throws EE_Error
286
+	 */
287
+	public function loadCommandBus()
288
+	{
289
+		$this->loader->getShared(
290
+			'CommandBusInterface',
291
+			array(
292
+				null,
293
+				apply_filters(
294
+					'FHEE__EE_Load_Espresso_Core__handle_request__CommandBus_middleware',
295
+					array(
296
+						$this->loader->getShared('EventEspresso\core\services\commands\middleware\CapChecker'),
297
+						$this->loader->getShared('EventEspresso\core\services\commands\middleware\AddActionHook'),
298
+					)
299
+				),
300
+			)
301
+		);
302
+	}
303
+
304
+
305
+
306
+	/**
307
+	 * @return void
308
+	 * @throws EE_Error
309
+	 */
310
+	public function loadPluginApi()
311
+	{
312
+		// set autoloaders for all of the classes implementing EEI_Plugin_API
313
+		// which provide helpers for EE plugin authors to more easily register certain components with EE.
314
+		EEH_Autoloader::instance()->register_autoloaders_for_each_file_in_folder(EE_LIBRARIES . 'plugin_api');
315
+		$this->loader->getShared('EE_Request_Handler');
316
+	}
317
+
318
+
319
+	/**
320
+	 * @param string $addon_name
321
+	 * @param string $version_constant
322
+	 * @param string $min_version_required
323
+	 * @param string $load_callback
324
+	 * @param string $plugin_file_constant
325
+	 * @return void
326
+	 */
327
+	private function deactivateIncompatibleAddon(
328
+		$addon_name,
329
+		$version_constant,
330
+		$min_version_required,
331
+		$load_callback,
332
+		$plugin_file_constant
333
+	) {
334
+		if (! defined($version_constant)) {
335
+			return;
336
+		}
337
+		$addon_version = constant($version_constant);
338
+		if ($addon_version && version_compare($addon_version, $min_version_required, '<')) {
339
+			remove_action('AHEE__EE_System__load_espresso_addons', $load_callback);
340
+			if (! function_exists('deactivate_plugins')) {
341
+				require_once ABSPATH . 'wp-admin/includes/plugin.php';
342
+			}
343
+			deactivate_plugins(plugin_basename(constant($plugin_file_constant)));
344
+			unset($_GET['activate'], $_REQUEST['activate'], $_GET['activate-multi'], $_REQUEST['activate-multi']);
345
+			EE_Error::add_error(
346
+				sprintf(
347
+					esc_html__(
348
+						'We\'re sorry, but the Event Espresso %1$s addon was deactivated because version %2$s or higher is required with this version of Event Espresso core.',
349
+						'event_espresso'
350
+					),
351
+					$addon_name,
352
+					$min_version_required
353
+				),
354
+				__FILE__, __FUNCTION__ . "({$addon_name})", __LINE__
355
+			);
356
+			EE_Error::get_notices(false, true);
357
+		}
358
+	}
359
+
360
+
361
+	/**
362
+	 * load_espresso_addons
363
+	 * allow addons to load first so that they can set hooks for running DMS's, etc
364
+	 * this is hooked into both:
365
+	 *    'AHEE__EE_Bootstrap__load_core_configuration'
366
+	 *        which runs during the WP 'plugins_loaded' action at priority 5
367
+	 *    and the WP 'activate_plugin' hook point
368
+	 *
369
+	 * @access public
370
+	 * @return void
371
+	 */
372
+	public function load_espresso_addons()
373
+	{
374
+		$this->deactivateIncompatibleAddon(
375
+			'Wait Lists',
376
+			'EE_WAIT_LISTS_VERSION',
377
+			'1.0.0.beta.074',
378
+			'load_espresso_wait_lists',
379
+			'EE_WAIT_LISTS_PLUGIN_FILE'
380
+		);
381
+		$this->deactivateIncompatibleAddon(
382
+			'Automated Upcoming Event Notifications',
383
+			'EE_AUTOMATED_UPCOMING_EVENT_NOTIFICATION_VERSION',
384
+			'1.0.0.beta.091',
385
+			'load_espresso_automated_upcoming_event_notification',
386
+			'EE_AUTOMATED_UPCOMING_EVENT_NOTIFICATION_PLUGIN_FILE'
387
+		);
388
+		do_action('AHEE__EE_System__load_espresso_addons');
389
+		//if the WP API basic auth plugin isn't already loaded, load it now.
390
+		//We want it for mobile apps. Just include the entire plugin
391
+		//also, don't load the basic auth when a plugin is getting activated, because
392
+		//it could be the basic auth plugin, and it doesn't check if its methods are already defined
393
+		//and causes a fatal error
394
+		if (
395
+			$this->request->getRequestParam('activate') !== 'true'
396
+			&& ! function_exists('json_basic_auth_handler')
397
+			&& ! function_exists('json_basic_auth_error')
398
+			&& ! in_array(
399
+				$this->request->getRequestParam('action'),
400
+				array('activate', 'activate-selected'),
401
+				true
402
+			)
403
+		) {
404
+			include_once EE_THIRD_PARTY . 'wp-api-basic-auth' . DS . 'basic-auth.php';
405
+		}
406
+		do_action('AHEE__EE_System__load_espresso_addons__complete');
407
+	}
408
+
409
+
410
+
411
+	/**
412
+	 * detect_activations_or_upgrades
413
+	 * Checks for activation or upgrade of core first;
414
+	 * then also checks if any registered addons have been activated or upgraded
415
+	 * This is hooked into 'AHEE__EE_Bootstrap__detect_activations_or_upgrades'
416
+	 * which runs during the WP 'plugins_loaded' action at priority 3
417
+	 *
418
+	 * @access public
419
+	 * @return void
420
+	 */
421
+	public function detect_activations_or_upgrades()
422
+	{
423
+		//first off: let's make sure to handle core
424
+		$this->detect_if_activation_or_upgrade();
425
+		foreach ($this->registry->addons as $addon) {
426
+			if ($addon instanceof EE_Addon) {
427
+				//detect teh request type for that addon
428
+				$addon->detect_activation_or_upgrade();
429
+			}
430
+		}
431
+	}
432
+
433
+
434
+
435
+	/**
436
+	 * detect_if_activation_or_upgrade
437
+	 * Takes care of detecting whether this is a brand new install or code upgrade,
438
+	 * and either setting up the DB or setting up maintenance mode etc.
439
+	 *
440
+	 * @access public
441
+	 * @return void
442
+	 */
443
+	public function detect_if_activation_or_upgrade()
444
+	{
445
+		do_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin');
446
+		// check if db has been updated, or if its a brand-new installation
447
+		$espresso_db_update = $this->fix_espresso_db_upgrade_option();
448
+		$request_type       = $this->detect_req_type($espresso_db_update);
449
+		//EEH_Debug_Tools::printr( $request_type, '$request_type', __FILE__, __LINE__ );
450
+		switch ($request_type) {
451
+			case EE_System::req_type_new_activation:
452
+				do_action('AHEE__EE_System__detect_if_activation_or_upgrade__new_activation');
453
+				$this->_handle_core_version_change($espresso_db_update);
454
+				break;
455
+			case EE_System::req_type_reactivation:
456
+				do_action('AHEE__EE_System__detect_if_activation_or_upgrade__reactivation');
457
+				$this->_handle_core_version_change($espresso_db_update);
458
+				break;
459
+			case EE_System::req_type_upgrade:
460
+				do_action('AHEE__EE_System__detect_if_activation_or_upgrade__upgrade');
461
+				//migrations may be required now that we've upgraded
462
+				$this->maintenance_mode->set_maintenance_mode_if_db_old();
463
+				$this->_handle_core_version_change($espresso_db_update);
464
+				//				echo "done upgrade";die;
465
+				break;
466
+			case EE_System::req_type_downgrade:
467
+				do_action('AHEE__EE_System__detect_if_activation_or_upgrade__downgrade');
468
+				//its possible migrations are no longer required
469
+				$this->maintenance_mode->set_maintenance_mode_if_db_old();
470
+				$this->_handle_core_version_change($espresso_db_update);
471
+				break;
472
+			case EE_System::req_type_normal:
473
+			default:
474
+				break;
475
+		}
476
+		do_action('AHEE__EE_System__detect_if_activation_or_upgrade__complete');
477
+	}
478
+
479
+
480
+
481
+	/**
482
+	 * Updates the list of installed versions and sets hooks for
483
+	 * initializing the database later during the request
484
+	 *
485
+	 * @param array $espresso_db_update
486
+	 */
487
+	private function _handle_core_version_change($espresso_db_update)
488
+	{
489
+		$this->update_list_of_installed_versions($espresso_db_update);
490
+		//get ready to verify the DB is ok (provided we aren't in maintenance mode, of course)
491
+		add_action(
492
+			'AHEE__EE_System__perform_activations_upgrades_and_migrations',
493
+			array($this, 'initialize_db_if_no_migrations_required')
494
+		);
495
+	}
496
+
497
+
498
+
499
+	/**
500
+	 * standardizes the wp option 'espresso_db_upgrade' which actually stores
501
+	 * information about what versions of EE have been installed and activated,
502
+	 * NOT necessarily the state of the database
503
+	 *
504
+	 * @param mixed $espresso_db_update           the value of the WordPress option.
505
+	 *                                            If not supplied, fetches it from the options table
506
+	 * @return array the correct value of 'espresso_db_upgrade', after saving it, if it needed correction
507
+	 */
508
+	private function fix_espresso_db_upgrade_option($espresso_db_update = null)
509
+	{
510
+		do_action('FHEE__EE_System__manage_fix_espresso_db_upgrade_option__begin', $espresso_db_update);
511
+		if (! $espresso_db_update) {
512
+			$espresso_db_update = get_option('espresso_db_update');
513
+		}
514
+		// check that option is an array
515
+		if (! is_array($espresso_db_update)) {
516
+			// if option is FALSE, then it never existed
517
+			if ($espresso_db_update === false) {
518
+				// make $espresso_db_update an array and save option with autoload OFF
519
+				$espresso_db_update = array();
520
+				add_option('espresso_db_update', $espresso_db_update, '', 'no');
521
+			} else {
522
+				// option is NOT FALSE but also is NOT an array, so make it an array and save it
523
+				$espresso_db_update = array($espresso_db_update => array());
524
+				update_option('espresso_db_update', $espresso_db_update);
525
+			}
526
+		} else {
527
+			$corrected_db_update = array();
528
+			//if IS an array, but is it an array where KEYS are version numbers, and values are arrays?
529
+			foreach ($espresso_db_update as $should_be_version_string => $should_be_array) {
530
+				if (is_int($should_be_version_string) && ! is_array($should_be_array)) {
531
+					//the key is an int, and the value IS NOT an array
532
+					//so it must be numerically-indexed, where values are versions installed...
533
+					//fix it!
534
+					$version_string                         = $should_be_array;
535
+					$corrected_db_update[ $version_string ] = array('unknown-date');
536
+				} else {
537
+					//ok it checks out
538
+					$corrected_db_update[ $should_be_version_string ] = $should_be_array;
539
+				}
540
+			}
541
+			$espresso_db_update = $corrected_db_update;
542
+			update_option('espresso_db_update', $espresso_db_update);
543
+		}
544
+		do_action('FHEE__EE_System__manage_fix_espresso_db_upgrade_option__complete', $espresso_db_update);
545
+		return $espresso_db_update;
546
+	}
547
+
548
+
549
+
550
+	/**
551
+	 * Does the traditional work of setting up the plugin's database and adding default data.
552
+	 * If migration script/process did not exist, this is what would happen on every activation/reactivation/upgrade.
553
+	 * NOTE: if we're in maintenance mode (which would be the case if we detect there are data
554
+	 * migration scripts that need to be run and a version change happens), enqueues core for database initialization,
555
+	 * so that it will be done when migrations are finished
556
+	 *
557
+	 * @param boolean $initialize_addons_too if true, we double-check addons' database tables etc too;
558
+	 * @param boolean $verify_schema         if true will re-check the database tables have the correct schema.
559
+	 *                                       This is a resource-intensive job
560
+	 *                                       so we prefer to only do it when necessary
561
+	 * @return void
562
+	 * @throws EE_Error
563
+	 */
564
+	public function initialize_db_if_no_migrations_required($initialize_addons_too = false, $verify_schema = true)
565
+	{
566
+		$request_type = $this->detect_req_type();
567
+		//only initialize system if we're not in maintenance mode.
568
+		if ($this->maintenance_mode->level() !== EE_Maintenance_Mode::level_2_complete_maintenance) {
569
+			update_option('ee_flush_rewrite_rules', true);
570
+			if ($verify_schema) {
571
+				EEH_Activation::initialize_db_and_folders();
572
+			}
573
+			EEH_Activation::initialize_db_content();
574
+			EEH_Activation::system_initialization();
575
+			if ($initialize_addons_too) {
576
+				$this->initialize_addons();
577
+			}
578
+		} else {
579
+			EE_Data_Migration_Manager::instance()->enqueue_db_initialization_for('Core');
580
+		}
581
+		if ($request_type === EE_System::req_type_new_activation
582
+			|| $request_type === EE_System::req_type_reactivation
583
+			|| (
584
+				$request_type === EE_System::req_type_upgrade
585
+				&& $this->is_major_version_change()
586
+			)
587
+		) {
588
+			add_action('AHEE__EE_System__initialize_last', array($this, 'redirect_to_about_ee'), 9);
589
+		}
590
+	}
591
+
592
+
593
+
594
+	/**
595
+	 * Initializes the db for all registered addons
596
+	 *
597
+	 * @throws EE_Error
598
+	 */
599
+	public function initialize_addons()
600
+	{
601
+		//foreach registered addon, make sure its db is up-to-date too
602
+		foreach ($this->registry->addons as $addon) {
603
+			if ($addon instanceof EE_Addon) {
604
+				$addon->initialize_db_if_no_migrations_required();
605
+			}
606
+		}
607
+	}
608
+
609
+
610
+
611
+	/**
612
+	 * Adds the current code version to the saved wp option which stores a list of all ee versions ever installed.
613
+	 *
614
+	 * @param    array  $version_history
615
+	 * @param    string $current_version_to_add version to be added to the version history
616
+	 * @return    boolean success as to whether or not this option was changed
617
+	 */
618
+	public function update_list_of_installed_versions($version_history = null, $current_version_to_add = null)
619
+	{
620
+		if (! $version_history) {
621
+			$version_history = $this->fix_espresso_db_upgrade_option($version_history);
622
+		}
623
+		if ($current_version_to_add === null) {
624
+			$current_version_to_add = espresso_version();
625
+		}
626
+		$version_history[ $current_version_to_add ][] = date('Y-m-d H:i:s', time());
627
+		// re-save
628
+		return update_option('espresso_db_update', $version_history);
629
+	}
630
+
631
+
632
+
633
+	/**
634
+	 * Detects if the current version indicated in the has existed in the list of
635
+	 * previously-installed versions of EE (espresso_db_update). Does NOT modify it (ie, no side-effect)
636
+	 *
637
+	 * @param array $espresso_db_update array from the wp option stored under the name 'espresso_db_update'.
638
+	 *                                  If not supplied, fetches it from the options table.
639
+	 *                                  Also, caches its result so later parts of the code can also know whether
640
+	 *                                  there's been an update or not. This way we can add the current version to
641
+	 *                                  espresso_db_update, but still know if this is a new install or not
642
+	 * @return int one of the constants on EE_System::req_type_
643
+	 */
644
+	public function detect_req_type($espresso_db_update = null)
645
+	{
646
+		if ($this->_req_type === null) {
647
+			$espresso_db_update          = ! empty($espresso_db_update)
648
+				? $espresso_db_update
649
+				: $this->fix_espresso_db_upgrade_option();
650
+			$this->_req_type             = EE_System::detect_req_type_given_activation_history(
651
+				$espresso_db_update,
652
+				'ee_espresso_activation', espresso_version()
653
+			);
654
+			$this->_major_version_change = $this->_detect_major_version_change($espresso_db_update);
655
+			$this->request->setIsActivation($this->_req_type !== EE_System::req_type_normal);
656
+		}
657
+		return $this->_req_type;
658
+	}
659
+
660
+
661
+
662
+	/**
663
+	 * Returns whether or not there was a non-micro version change (ie, change in either
664
+	 * the first or second number in the version. Eg 4.9.0.rc.001 to 4.10.0.rc.000,
665
+	 * but not 4.9.0.rc.0001 to 4.9.1.rc.0001
666
+	 *
667
+	 * @param $activation_history
668
+	 * @return bool
669
+	 */
670
+	private function _detect_major_version_change($activation_history)
671
+	{
672
+		$previous_version       = EE_System::_get_most_recently_active_version_from_activation_history($activation_history);
673
+		$previous_version_parts = explode('.', $previous_version);
674
+		$current_version_parts  = explode('.', espresso_version());
675
+		return isset($previous_version_parts[0], $previous_version_parts[1], $current_version_parts[0], $current_version_parts[1])
676
+			   && ($previous_version_parts[0] !== $current_version_parts[0]
677
+				   || $previous_version_parts[1] !== $current_version_parts[1]
678
+			   );
679
+	}
680
+
681
+
682
+
683
+	/**
684
+	 * Returns true if either the major or minor version of EE changed during this request.
685
+	 * Eg 4.9.0.rc.001 to 4.10.0.rc.000, but not 4.9.0.rc.0001 to 4.9.1.rc.0001
686
+	 *
687
+	 * @return bool
688
+	 */
689
+	public function is_major_version_change()
690
+	{
691
+		return $this->_major_version_change;
692
+	}
693
+
694
+
695
+
696
+	/**
697
+	 * Determines the request type for any ee addon, given three piece of info: the current array of activation
698
+	 * histories (for core that' 'espresso_db_update' wp option); the name of the WordPress option which is temporarily
699
+	 * set upon activation of the plugin (for core it's 'ee_espresso_activation'); and the version that this plugin was
700
+	 * just activated to (for core that will always be espresso_version())
701
+	 *
702
+	 * @param array  $activation_history_for_addon     the option's value which stores the activation history for this
703
+	 *                                                 ee plugin. for core that's 'espresso_db_update'
704
+	 * @param string $activation_indicator_option_name the name of the WordPress option that is temporarily set to
705
+	 *                                                 indicate that this plugin was just activated
706
+	 * @param string $version_to_upgrade_to            the version that was just upgraded to (for core that will be
707
+	 *                                                 espresso_version())
708
+	 * @return int one of the constants on EE_System::req_type_*
709
+	 */
710
+	public static function detect_req_type_given_activation_history(
711
+		$activation_history_for_addon,
712
+		$activation_indicator_option_name,
713
+		$version_to_upgrade_to
714
+	) {
715
+		$version_is_higher = self::_new_version_is_higher($activation_history_for_addon, $version_to_upgrade_to);
716
+		if ($activation_history_for_addon) {
717
+			//it exists, so this isn't a completely new install
718
+			//check if this version already in that list of previously installed versions
719
+			if (! isset($activation_history_for_addon[ $version_to_upgrade_to ])) {
720
+				//it a version we haven't seen before
721
+				if ($version_is_higher === 1) {
722
+					$req_type = EE_System::req_type_upgrade;
723
+				} else {
724
+					$req_type = EE_System::req_type_downgrade;
725
+				}
726
+				delete_option($activation_indicator_option_name);
727
+			} else {
728
+				// its not an update. maybe a reactivation?
729
+				if (get_option($activation_indicator_option_name, false)) {
730
+					if ($version_is_higher === -1) {
731
+						$req_type = EE_System::req_type_downgrade;
732
+					} elseif ($version_is_higher === 0) {
733
+						//we've seen this version before, but it's an activation. must be a reactivation
734
+						$req_type = EE_System::req_type_reactivation;
735
+					} else {//$version_is_higher === 1
736
+						$req_type = EE_System::req_type_upgrade;
737
+					}
738
+					delete_option($activation_indicator_option_name);
739
+				} else {
740
+					//we've seen this version before and the activation indicate doesn't show it was just activated
741
+					if ($version_is_higher === -1) {
742
+						$req_type = EE_System::req_type_downgrade;
743
+					} elseif ($version_is_higher === 0) {
744
+						//we've seen this version before and it's not an activation. its normal request
745
+						$req_type = EE_System::req_type_normal;
746
+					} else {//$version_is_higher === 1
747
+						$req_type = EE_System::req_type_upgrade;
748
+					}
749
+				}
750
+			}
751
+		} else {
752
+			//brand new install
753
+			$req_type = EE_System::req_type_new_activation;
754
+			delete_option($activation_indicator_option_name);
755
+		}
756
+		return $req_type;
757
+	}
758
+
759
+
760
+
761
+	/**
762
+	 * Detects if the $version_to_upgrade_to is higher than the most recent version in
763
+	 * the $activation_history_for_addon
764
+	 *
765
+	 * @param array  $activation_history_for_addon (keys are versions, values are arrays of times activated,
766
+	 *                                             sometimes containing 'unknown-date'
767
+	 * @param string $version_to_upgrade_to        (current version)
768
+	 * @return int results of version_compare( $version_to_upgrade_to, $most_recently_active_version ).
769
+	 *                                             ie, -1 if $version_to_upgrade_to is LOWER (downgrade);
770
+	 *                                             0 if $version_to_upgrade_to MATCHES (reactivation or normal request);
771
+	 *                                             1 if $version_to_upgrade_to is HIGHER (upgrade) ;
772
+	 */
773
+	private static function _new_version_is_higher($activation_history_for_addon, $version_to_upgrade_to)
774
+	{
775
+		//find the most recently-activated version
776
+		$most_recently_active_version =
777
+			EE_System::_get_most_recently_active_version_from_activation_history($activation_history_for_addon);
778
+		return version_compare($version_to_upgrade_to, $most_recently_active_version);
779
+	}
780
+
781
+
782
+
783
+	/**
784
+	 * Gets the most recently active version listed in the activation history,
785
+	 * and if none are found (ie, it's a brand new install) returns '0.0.0.dev.000'.
786
+	 *
787
+	 * @param array $activation_history  (keys are versions, values are arrays of times activated,
788
+	 *                                   sometimes containing 'unknown-date'
789
+	 * @return string
790
+	 */
791
+	private static function _get_most_recently_active_version_from_activation_history($activation_history)
792
+	{
793
+		$most_recently_active_version_activation = '1970-01-01 00:00:00';
794
+		$most_recently_active_version            = '0.0.0.dev.000';
795
+		if (is_array($activation_history)) {
796
+			foreach ($activation_history as $version => $times_activated) {
797
+				//check there is a record of when this version was activated. Otherwise,
798
+				//mark it as unknown
799
+				if (! $times_activated) {
800
+					$times_activated = array('unknown-date');
801
+				}
802
+				if (is_string($times_activated)) {
803
+					$times_activated = array($times_activated);
804
+				}
805
+				foreach ($times_activated as $an_activation) {
806
+					if ($an_activation !== 'unknown-date'
807
+						&& $an_activation
808
+						   > $most_recently_active_version_activation) {
809
+						$most_recently_active_version            = $version;
810
+						$most_recently_active_version_activation = $an_activation === 'unknown-date'
811
+							? '1970-01-01 00:00:00'
812
+							: $an_activation;
813
+					}
814
+				}
815
+			}
816
+		}
817
+		return $most_recently_active_version;
818
+	}
819
+
820
+
821
+
822
+	/**
823
+	 * This redirects to the about EE page after activation
824
+	 *
825
+	 * @return void
826
+	 */
827
+	public function redirect_to_about_ee()
828
+	{
829
+		$notices = EE_Error::get_notices(false);
830
+		//if current user is an admin and it's not an ajax or rest request
831
+		if (
832
+			! isset($notices['errors'])
833
+			&& $this->request->isAdmin()
834
+			&& apply_filters(
835
+				'FHEE__EE_System__redirect_to_about_ee__do_redirect',
836
+				$this->capabilities->current_user_can('manage_options', 'espresso_about_default')
837
+			)
838
+		) {
839
+			$query_params = array('page' => 'espresso_about');
840
+			if (EE_System::instance()->detect_req_type() === EE_System::req_type_new_activation) {
841
+				$query_params['new_activation'] = true;
842
+			}
843
+			if (EE_System::instance()->detect_req_type() === EE_System::req_type_reactivation) {
844
+				$query_params['reactivation'] = true;
845
+			}
846
+			$url = add_query_arg($query_params, admin_url('admin.php'));
847
+			wp_safe_redirect($url);
848
+			exit();
849
+		}
850
+	}
851
+
852
+
853
+
854
+	/**
855
+	 * load_core_configuration
856
+	 * this is hooked into 'AHEE__EE_Bootstrap__load_core_configuration'
857
+	 * which runs during the WP 'plugins_loaded' action at priority 5
858
+	 *
859
+	 * @return void
860
+	 * @throws ReflectionException
861
+	 */
862
+	public function load_core_configuration()
863
+	{
864
+		do_action('AHEE__EE_System__load_core_configuration__begin', $this);
865
+		$this->loader->getShared('EE_Load_Textdomain');
866
+		//load textdomain
867
+		EE_Load_Textdomain::load_textdomain();
868
+		// load and setup EE_Config and EE_Network_Config
869
+		$config = $this->loader->getShared('EE_Config');
870
+		$this->loader->getShared('EE_Network_Config');
871
+		// setup autoloaders
872
+		// enable logging?
873
+		if ($config->admin->use_full_logging) {
874
+			$this->loader->getShared('EE_Log');
875
+		}
876
+		// check for activation errors
877
+		$activation_errors = get_option('ee_plugin_activation_errors', false);
878
+		if ($activation_errors) {
879
+			EE_Error::add_error($activation_errors, __FILE__, __FUNCTION__, __LINE__);
880
+			update_option('ee_plugin_activation_errors', false);
881
+		}
882
+		// get model names
883
+		$this->_parse_model_names();
884
+		//load caf stuff a chance to play during the activation process too.
885
+		$this->_maybe_brew_regular();
886
+		do_action('AHEE__EE_System__load_core_configuration__complete', $this);
887
+	}
888
+
889
+
890
+
891
+	/**
892
+	 * cycles through all of the models/*.model.php files, and assembles an array of model names
893
+	 *
894
+	 * @return void
895
+	 * @throws ReflectionException
896
+	 */
897
+	private function _parse_model_names()
898
+	{
899
+		//get all the files in the EE_MODELS folder that end in .model.php
900
+		$models                 = glob(EE_MODELS . '*.model.php');
901
+		$model_names            = array();
902
+		$non_abstract_db_models = array();
903
+		foreach ($models as $model) {
904
+			// get model classname
905
+			$classname       = EEH_File::get_classname_from_filepath_with_standard_filename($model);
906
+			$short_name      = str_replace('EEM_', '', $classname);
907
+			$reflectionClass = new ReflectionClass($classname);
908
+			if ($reflectionClass->isSubclassOf('EEM_Base') && ! $reflectionClass->isAbstract()) {
909
+				$non_abstract_db_models[ $short_name ] = $classname;
910
+			}
911
+			$model_names[ $short_name ] = $classname;
912
+		}
913
+		$this->registry->models                 = apply_filters('FHEE__EE_System__parse_model_names', $model_names);
914
+		$this->registry->non_abstract_db_models = apply_filters(
915
+			'FHEE__EE_System__parse_implemented_model_names',
916
+			$non_abstract_db_models
917
+		);
918
+	}
919
+
920
+
921
+	/**
922
+	 * The purpose of this method is to simply check for a file named "caffeinated/brewing_regular.php" for any hooks
923
+	 * that need to be setup before our EE_System launches.
924
+	 *
925
+	 * @return void
926
+	 * @throws DomainException
927
+	 * @throws InvalidArgumentException
928
+	 * @throws InvalidDataTypeException
929
+	 * @throws InvalidInterfaceException
930
+	 * @throws InvalidClassException
931
+	 * @throws InvalidFilePathException
932
+	 */
933
+	private function _maybe_brew_regular()
934
+	{
935
+		/** @var Domain $domain */
936
+		$domain = DomainFactory::getShared(
937
+			new FullyQualifiedName(
938
+				'EventEspresso\core\domain\Domain'
939
+			),
940
+			array(
941
+				new FilePath(EVENT_ESPRESSO_MAIN_FILE),
942
+				Version::fromString(espresso_version())
943
+			)
944
+		);
945
+		if ($domain->isCaffeinated()) {
946
+			require_once EE_CAFF_PATH . 'brewing_regular.php';
947
+		}
948
+	}
949
+
950
+
951
+
952
+	/**
953
+	 * register_shortcodes_modules_and_widgets
954
+	 * generate lists of shortcodes and modules, then verify paths and classes
955
+	 * This is hooked into 'AHEE__EE_Bootstrap__register_shortcodes_modules_and_widgets'
956
+	 * which runs during the WP 'plugins_loaded' action at priority 7
957
+	 *
958
+	 * @access public
959
+	 * @return void
960
+	 * @throws Exception
961
+	 */
962
+	public function register_shortcodes_modules_and_widgets()
963
+	{
964
+		try {
965
+			// load, register, and add shortcodes the new way
966
+			if ($this->request->isFrontend() || $this->request->isIframe()) {
967
+				$this->loader->getShared(
968
+					'EventEspresso\core\services\shortcodes\ShortcodesManager',
969
+					array(
970
+						// and the old way, but we'll put it under control of the new system
971
+						EE_Config::getLegacyShortcodesManager(),
972
+					)
973
+				);
974
+			}
975
+			if (function_exists('register_block_type')) {
976
+				// or the even newer newer new way
977
+				if ($this->request->isFrontend() || $this->request->isIframe() || $this->request->isAdmin()) {
978
+					$this->loader->getShared(
979
+						'EventEspresso\core\services\editor\BlockRegistrationManager'
980
+					);
981
+				}
982
+			}
983
+		} catch (Exception $exception) {
984
+			new ExceptionStackTraceDisplay($exception);
985
+		}
986
+		do_action('AHEE__EE_System__register_shortcodes_modules_and_widgets');
987
+		// check for addons using old hook point
988
+		if (has_action('AHEE__EE_System__register_shortcodes_modules_and_addons')) {
989
+			$this->_incompatible_addon_error();
990
+		}
991
+	}
992
+
993
+
994
+
995
+	/**
996
+	 * _incompatible_addon_error
997
+	 *
998
+	 * @access public
999
+	 * @return void
1000
+	 */
1001
+	private function _incompatible_addon_error()
1002
+	{
1003
+		// get array of classes hooking into here
1004
+		$class_names = EEH_Class_Tools::get_class_names_for_all_callbacks_on_hook(
1005
+			'AHEE__EE_System__register_shortcodes_modules_and_addons'
1006
+		);
1007
+		if (! empty($class_names)) {
1008
+			$msg = __(
1009
+				'The following plugins, addons, or modules appear to be incompatible with this version of Event Espresso and were automatically deactivated to avoid fatal errors:',
1010
+				'event_espresso'
1011
+			);
1012
+			$msg .= '<ul>';
1013
+			foreach ($class_names as $class_name) {
1014
+				$msg .= '<li><b>Event Espresso - ' . str_replace(
1015
+						array('EE_', 'EEM_', 'EED_', 'EES_', 'EEW_'), '',
1016
+						$class_name
1017
+					) . '</b></li>';
1018
+			}
1019
+			$msg .= '</ul>';
1020
+			$msg .= __(
1021
+				'Compatibility issues can be avoided and/or resolved by keeping addons and plugins updated to the latest version.',
1022
+				'event_espresso'
1023
+			);
1024
+			// save list of incompatible addons to wp-options for later use
1025
+			add_option('ee_incompatible_addons', $class_names, '', 'no');
1026
+			if (is_admin()) {
1027
+				EE_Error::add_error($msg, __FILE__, __FUNCTION__, __LINE__);
1028
+			}
1029
+		}
1030
+	}
1031
+
1032
+
1033
+
1034
+	/**
1035
+	 * brew_espresso
1036
+	 * begins the process of setting hooks for initializing EE in the correct order
1037
+	 * This is happening on the 'AHEE__EE_Bootstrap__brew_espresso' hook point
1038
+	 * which runs during the WP 'plugins_loaded' action at priority 9
1039
+	 *
1040
+	 * @return void
1041
+	 */
1042
+	public function brew_espresso()
1043
+	{
1044
+		do_action('AHEE__EE_System__brew_espresso__begin', $this);
1045
+		// load some final core systems
1046
+		add_action('init', array($this, 'set_hooks_for_core'), 1);
1047
+		add_action('init', array($this, 'perform_activations_upgrades_and_migrations'), 3);
1048
+		add_action('init', array($this, 'load_CPTs_and_session'), 5);
1049
+		add_action('init', array($this, 'load_controllers'), 7);
1050
+		add_action('init', array($this, 'core_loaded_and_ready'), 9);
1051
+		add_action('init', array($this, 'initialize'), 10);
1052
+		add_action('init', array($this, 'initialize_last'), 100);
1053
+		if (is_admin() && apply_filters('FHEE__EE_System__brew_espresso__load_pue', true)) {
1054
+			// pew pew pew
1055
+			$this->loader->getShared('EventEspresso\core\services\licensing\LicenseService');
1056
+			do_action('AHEE__EE_System__brew_espresso__after_pue_init');
1057
+		}
1058
+		do_action('AHEE__EE_System__brew_espresso__complete', $this);
1059
+	}
1060
+
1061
+
1062
+
1063
+	/**
1064
+	 *    set_hooks_for_core
1065
+	 *
1066
+	 * @access public
1067
+	 * @return    void
1068
+	 * @throws EE_Error
1069
+	 */
1070
+	public function set_hooks_for_core()
1071
+	{
1072
+		$this->_deactivate_incompatible_addons();
1073
+		do_action('AHEE__EE_System__set_hooks_for_core');
1074
+		$this->loader->getShared('EventEspresso\core\domain\values\session\SessionLifespan');
1075
+		//caps need to be initialized on every request so that capability maps are set.
1076
+		//@see https://events.codebasehq.com/projects/event-espresso/tickets/8674
1077
+		$this->registry->CAP->init_caps();
1078
+	}
1079
+
1080
+
1081
+
1082
+	/**
1083
+	 * Using the information gathered in EE_System::_incompatible_addon_error,
1084
+	 * deactivates any addons considered incompatible with the current version of EE
1085
+	 */
1086
+	private function _deactivate_incompatible_addons()
1087
+	{
1088
+		$incompatible_addons = get_option('ee_incompatible_addons', array());
1089
+		if (! empty($incompatible_addons)) {
1090
+			$active_plugins = get_option('active_plugins', array());
1091
+			foreach ($active_plugins as $active_plugin) {
1092
+				foreach ($incompatible_addons as $incompatible_addon) {
1093
+					if (strpos($active_plugin, $incompatible_addon) !== false) {
1094
+						unset($_GET['activate']);
1095
+						espresso_deactivate_plugin($active_plugin);
1096
+					}
1097
+				}
1098
+			}
1099
+		}
1100
+	}
1101
+
1102
+
1103
+
1104
+	/**
1105
+	 *    perform_activations_upgrades_and_migrations
1106
+	 *
1107
+	 * @access public
1108
+	 * @return    void
1109
+	 */
1110
+	public function perform_activations_upgrades_and_migrations()
1111
+	{
1112
+		do_action('AHEE__EE_System__perform_activations_upgrades_and_migrations');
1113
+	}
1114
+
1115
+
1116
+
1117
+	/**
1118
+	 *    load_CPTs_and_session
1119
+	 *
1120
+	 * @access public
1121
+	 * @return    void
1122
+	 */
1123
+	public function load_CPTs_and_session()
1124
+	{
1125
+		do_action('AHEE__EE_System__load_CPTs_and_session__start');
1126
+		// register Custom Post Types
1127
+		$this->loader->getShared('EE_Register_CPTs');
1128
+		do_action('AHEE__EE_System__load_CPTs_and_session__complete');
1129
+	}
1130
+
1131
+
1132
+
1133
+	/**
1134
+	 * load_controllers
1135
+	 * this is the best place to load any additional controllers that needs access to EE core.
1136
+	 * it is expected that all basic core EE systems, that are not dependant on the current request are loaded at this
1137
+	 * time
1138
+	 *
1139
+	 * @access public
1140
+	 * @return void
1141
+	 */
1142
+	public function load_controllers()
1143
+	{
1144
+		do_action('AHEE__EE_System__load_controllers__start');
1145
+		// let's get it started
1146
+		if (
1147
+			! $this->maintenance_mode->level()
1148
+			&& ($this->request->isFrontend() || $this->request->isFrontAjax())
1149
+		) {
1150
+			do_action('AHEE__EE_System__load_controllers__load_front_controllers');
1151
+			$this->loader->getShared('EE_Front_Controller');
1152
+		} elseif ($this->request->isAdmin() || $this->request->isAdminAjax()) {
1153
+			do_action('AHEE__EE_System__load_controllers__load_admin_controllers');
1154
+			$this->loader->getShared('EE_Admin');
1155
+		}
1156
+		do_action('AHEE__EE_System__load_controllers__complete');
1157
+	}
1158
+
1159
+
1160
+
1161
+	/**
1162
+	 * core_loaded_and_ready
1163
+	 * all of the basic EE core should be loaded at this point and available regardless of M-Mode
1164
+	 *
1165
+	 * @access public
1166
+	 * @return void
1167
+	 */
1168
+	public function core_loaded_and_ready()
1169
+	{
1170
+		if (
1171
+			$this->request->isAdmin()
1172
+			|| $this->request->isEeAjax()
1173
+			|| $this->request->isFrontend()
1174
+		) {
1175
+			$this->loader->getShared('EE_Session');
1176
+		}
1177
+		do_action('AHEE__EE_System__core_loaded_and_ready');
1178
+		// load_espresso_template_tags
1179
+		if (
1180
+			is_readable(EE_PUBLIC . 'template_tags.php')
1181
+			&& (
1182
+				$this->request->isFrontend()
1183
+				|| $this->request->isAdmin()
1184
+				|| $this->request->isIframe()
1185
+				|| $this->request->isFeed()
1186
+			)
1187
+		) {
1188
+			require_once EE_PUBLIC . 'template_tags.php';
1189
+		}
1190
+		do_action('AHEE__EE_System__set_hooks_for_shortcodes_modules_and_addons');
1191
+		if ($this->request->isAdmin() || $this->request->isFrontend() || $this->request->isIframe()) {
1192
+			$this->loader->getShared('EventEspresso\core\services\assets\Registry');
1193
+		}
1194
+	}
1195
+
1196
+
1197
+
1198
+	/**
1199
+	 * initialize
1200
+	 * this is the best place to begin initializing client code
1201
+	 *
1202
+	 * @access public
1203
+	 * @return void
1204
+	 */
1205
+	public function initialize()
1206
+	{
1207
+		do_action('AHEE__EE_System__initialize');
1208
+	}
1209
+
1210
+
1211
+
1212
+	/**
1213
+	 * initialize_last
1214
+	 * this is run really late during the WP init hook point, and ensures that mostly everything else that needs to
1215
+	 * initialize has done so
1216
+	 *
1217
+	 * @access public
1218
+	 * @return void
1219
+	 */
1220
+	public function initialize_last()
1221
+	{
1222
+		do_action('AHEE__EE_System__initialize_last');
1223
+		add_action('admin_bar_init', array($this, 'addEspressoToolbar'));
1224
+	}
1225
+
1226
+
1227
+
1228
+	/**
1229
+	 * @return void
1230
+	 * @throws EE_Error
1231
+	 */
1232
+	public function addEspressoToolbar()
1233
+	{
1234
+		$this->loader->getShared(
1235
+			'EventEspresso\core\domain\services\admin\AdminToolBar',
1236
+			array($this->registry->CAP)
1237
+		);
1238
+	}
1239
+
1240
+
1241
+
1242
+	/**
1243
+	 * do_not_cache
1244
+	 * sets no cache headers and defines no cache constants for WP plugins
1245
+	 *
1246
+	 * @access public
1247
+	 * @return void
1248
+	 */
1249
+	public static function do_not_cache()
1250
+	{
1251
+		// set no cache constants
1252
+		if (! defined('DONOTCACHEPAGE')) {
1253
+			define('DONOTCACHEPAGE', true);
1254
+		}
1255
+		if (! defined('DONOTCACHCEOBJECT')) {
1256
+			define('DONOTCACHCEOBJECT', true);
1257
+		}
1258
+		if (! defined('DONOTCACHEDB')) {
1259
+			define('DONOTCACHEDB', true);
1260
+		}
1261
+		// add no cache headers
1262
+		add_action('send_headers', array('EE_System', 'nocache_headers'), 10);
1263
+		// plus a little extra for nginx and Google Chrome
1264
+		add_filter('nocache_headers', array('EE_System', 'extra_nocache_headers'), 10, 1);
1265
+		// prevent browsers from prefetching of the rel='next' link, because it may contain content that interferes with the registration process
1266
+		remove_action('wp_head', 'adjacent_posts_rel_link_wp_head');
1267
+	}
1268
+
1269
+
1270
+
1271
+	/**
1272
+	 *    extra_nocache_headers
1273
+	 *
1274
+	 * @access    public
1275
+	 * @param $headers
1276
+	 * @return    array
1277
+	 */
1278
+	public static function extra_nocache_headers($headers)
1279
+	{
1280
+		// for NGINX
1281
+		$headers['X-Accel-Expires'] = 0;
1282
+		// plus extra for Google Chrome since it doesn't seem to respect "no-cache", but WILL respect "no-store"
1283
+		$headers['Cache-Control'] = 'no-store, no-cache, must-revalidate, max-age=0';
1284
+		return $headers;
1285
+	}
1286
+
1287
+
1288
+
1289
+	/**
1290
+	 *    nocache_headers
1291
+	 *
1292
+	 * @access    public
1293
+	 * @return    void
1294
+	 */
1295
+	public static function nocache_headers()
1296
+	{
1297
+		nocache_headers();
1298
+	}
1299
+
1300
+
1301
+
1302
+	/**
1303
+	 * simply hooks into "wp_list_pages_exclude" filter (for wp_list_pages method) and makes sure EE critical pages are
1304
+	 * never returned with the function.
1305
+	 *
1306
+	 * @param  array $exclude_array any existing pages being excluded are in this array.
1307
+	 * @return array
1308
+	 */
1309
+	public function remove_pages_from_wp_list_pages($exclude_array)
1310
+	{
1311
+		return array_merge($exclude_array, $this->registry->CFG->core->get_critical_pages_array());
1312
+	}
1313 1313
 
1314 1314
 
1315 1315
 
Please login to merge, or discard this patch.