Completed
Branch EDTR/master (8c09db)
by
unknown
09:27 queued 29s
created
core/libraries/plugin_api/EE_Register_Message_Type.lib.php 2 patches
Indentation   +445 added lines, -445 removed lines patch added patch discarded remove patch
@@ -12,475 +12,475 @@
 block discarded – undo
12 12
 {
13 13
 
14 14
 
15
-    /**
16
-     * Holds values for registered message types
17
-     *
18
-     * @var array
19
-     */
20
-    protected static $_ee_message_type_registry = array();
15
+	/**
16
+	 * Holds values for registered message types
17
+	 *
18
+	 * @var array
19
+	 */
20
+	protected static $_ee_message_type_registry = array();
21 21
 
22 22
 
23
-    /**
24
-     * Method for registering new message types in the EE_messages system.
25
-     * Note:  All message types must have the following files in order to work:
26
-     * Template files for default templates getting setup.
27
-     * See /core/libraries/messages/defaults/default/ for examples
28
-     * (note that template files match a specific naming schema).
29
-     * These templates will need to be registered with the default template pack.
30
-     * - EE_Messages_Validator extended class(es).  See /core/libraries/messages/validators/email/
31
-     *      for examples.  Note for any new message types, there will need to be a validator for each
32
-     *      messenger combo this message type can activate with.
33
-     * - And of course the main EE_{Message_Type_Name}_message_type class that defines the new
34
-     *      message type and its properties.
35
-     *
36
-     * @since    4.3.0
37
-     * @param string $mt_name       Whatever is defined for the $name property of
38
-     *                              the message type you are registering (eg.
39
-     *                              declined_registration). Required.
40
-     * @param  array $setup_args    An array of arguments provided for registering the message type.
41
-     * @see      inline docs in the register method for what can be passed in as arguments.
42
-     * @throws \EE_Error
43
-     *                              }
44
-     */
45
-    public static function register($mt_name = null, $setup_args = array())
46
-    {
47
-        // required fields MUST be present, so let's make sure they are.
48
-        if (! isset($mt_name)
49
-            || ! is_array($setup_args)
50
-            || empty($setup_args['mtfilename']) || empty($setup_args['autoloadpaths'])
51
-        ) {
52
-            throw new EE_Error(
53
-                __(
54
-                    'In order to register a message type with EE_Register_Message_Type::register, you must include a unique name for the message type, plus an array containing the following keys: "mtfilename", "autoloadpaths"',
55
-                    'event_espresso'
56
-                )
57
-            );
58
-        }
23
+	/**
24
+	 * Method for registering new message types in the EE_messages system.
25
+	 * Note:  All message types must have the following files in order to work:
26
+	 * Template files for default templates getting setup.
27
+	 * See /core/libraries/messages/defaults/default/ for examples
28
+	 * (note that template files match a specific naming schema).
29
+	 * These templates will need to be registered with the default template pack.
30
+	 * - EE_Messages_Validator extended class(es).  See /core/libraries/messages/validators/email/
31
+	 *      for examples.  Note for any new message types, there will need to be a validator for each
32
+	 *      messenger combo this message type can activate with.
33
+	 * - And of course the main EE_{Message_Type_Name}_message_type class that defines the new
34
+	 *      message type and its properties.
35
+	 *
36
+	 * @since    4.3.0
37
+	 * @param string $mt_name       Whatever is defined for the $name property of
38
+	 *                              the message type you are registering (eg.
39
+	 *                              declined_registration). Required.
40
+	 * @param  array $setup_args    An array of arguments provided for registering the message type.
41
+	 * @see      inline docs in the register method for what can be passed in as arguments.
42
+	 * @throws \EE_Error
43
+	 *                              }
44
+	 */
45
+	public static function register($mt_name = null, $setup_args = array())
46
+	{
47
+		// required fields MUST be present, so let's make sure they are.
48
+		if (! isset($mt_name)
49
+			|| ! is_array($setup_args)
50
+			|| empty($setup_args['mtfilename']) || empty($setup_args['autoloadpaths'])
51
+		) {
52
+			throw new EE_Error(
53
+				__(
54
+					'In order to register a message type with EE_Register_Message_Type::register, you must include a unique name for the message type, plus an array containing the following keys: "mtfilename", "autoloadpaths"',
55
+					'event_espresso'
56
+				)
57
+			);
58
+		}
59 59
 
60
-        // make sure we don't register twice
61
-        if (isset(self::$_ee_message_type_registry[ $mt_name ])) {
62
-            return;
63
-        }
60
+		// make sure we don't register twice
61
+		if (isset(self::$_ee_message_type_registry[ $mt_name ])) {
62
+			return;
63
+		}
64 64
 
65
-        // make sure this was called in the right place!
66
-        if (! did_action('EE_Brewing_Regular___messages_caf')
67
-            || did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
68
-        ) {
69
-            EE_Error::doing_it_wrong(
70
-                __METHOD__,
71
-                sprintf(
72
-                    __(
73
-                        'A message type named "%s" has been attempted to be registered with the EE Messages System.  It may or may not work because it should be only called on the "EE_Brewing_Regular___messages_caf" hook.',
74
-                        'event_espresso'
75
-                    ),
76
-                    $mt_name
77
-                ),
78
-                '4.3.0'
79
-            );
80
-        }
81
-        // setup $__ee_message_type_registry array from incoming values.
82
-        self::$_ee_message_type_registry[ $mt_name ] = array(
83
-            /**
84
-             * The file name for the message type being registered.
85
-             * Required.
86
-             *
87
-             * @type string
88
-             */
89
-            'mtfilename'                                       => (string) $setup_args['mtfilename'],
90
-            /**
91
-             * Autoload paths for classes used by the message type.
92
-             * Required.
93
-             *
94
-             * @type array
95
-             */
96
-            'autoloadpaths'                                    => (array) $setup_args['autoloadpaths'],
97
-            /**
98
-             * Messengers that the message type should be able to activate with.
99
-             * Use messenger slugs.
100
-             *
101
-             * @type array
102
-             */
103
-            'messengers_to_activate_with'                      => ! empty($setup_args['messengers_to_activate_with'])
104
-                ? (array) $setup_args['messengers_to_activate_with']
105
-                : array(),
106
-            /**
107
-             * Messengers that the message type should validate with.
108
-             * Use messenger slugs.
109
-             *
110
-             * @type array
111
-             */
112
-            'messengers_to_validate_with'                      => ! empty($setup_args['messengers_to_validate_with'])
113
-                ? (array) $setup_args['messengers_to_validate_with']
114
-                : array(),
115
-            /**
116
-             * Whether to force activate this message type the first time it is registered.
117
-             *
118
-             * @type bool   False means its not activated by default and left up to the end user to activate.
119
-             */
120
-            'force_activation'                                 => ! empty($setup_args['force_activation'])
121
-                ? (bool) $setup_args['force_activation']
122
-                : false,
123
-            /**
124
-             * What messengers this message type supports the default template pack for.
125
-             * Note: If you do not set this (or any of the following template pack/variation related arguments) to true,
126
-             * then it is expected that the message type being registered is doing its own custom default template
127
-             * pack/variation registration.
128
-             *
129
-             * If this is set and has values, then it is expected that the following arguments are also set in the incoming options
130
-             * $setup_arguments array as well:
131
-             * - 'base_path_for_default_templates'
132
-             *
133
-             * @type array   Expect an array of messengers this supports default template packs for.
134
-             */
135
-            'messengers_supporting_default_template_pack_with' => isset($setup_args['messengers_supporting_default_template_pack_with'])
136
-                ? (array) $setup_args['messengers_supporting_default_template_pack_with']
137
-                : array(),
138
-            /**
139
-             * The base path where the default templates for this message type can be found.
140
-             *
141
-             * @type string
142
-             */
143
-            'base_path_for_default_templates'                  => isset($setup_args['base_path_for_default_templates'])
144
-                ? $setup_args['base_path_for_default_templates']
145
-                : '',
146
-            /**
147
-             * The base path where the default variations for this message type can be found.
148
-             *
149
-             * @type string
150
-             */
151
-            'base_path_for_default_variation'                  => isset($setup_args['base_path_for_default_variation'])
152
-                ? $setup_args['base_path_for_default_variation']
153
-                : '',
154
-            /**
155
-             * The base url for the default variations for this message type.
156
-             *
157
-             * @type string
158
-             */
159
-            'base_url_for_default_variation'                   => isset($setup_args['base_url_for_default_variation'])
160
-                ? $setup_args['base_url_for_default_variation']
161
-                : '',
162
-        );
163
-        // add filters but only if they haven't already been set (these filters only need to be registered ONCE because
164
-        // the callback handles all registered message types.
165
-        if (false === has_filter(
166
-            'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
167
-            array('EE_Register_Message_Type', 'register_msgs_autoload_paths')
168
-        )) {
169
-            add_filter(
170
-                'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
171
-                array('EE_Register_Message_Type', 'register_msgs_autoload_paths'),
172
-                10
173
-            );
174
-            add_filter(
175
-                'FHEE__EE_messages__get_installed__messagetype_files',
176
-                array('EE_Register_Message_Type', 'register_messagetype_files'),
177
-                10,
178
-                1
179
-            );
180
-            add_filter(
181
-                'FHEE__EE_messenger__get_default_message_types__default_types',
182
-                array('EE_Register_Message_Type', 'register_messengers_to_activate_mt_with'),
183
-                10,
184
-                2
185
-            );
186
-            add_filter(
187
-                'FHEE__EE_messenger__get_valid_message_types__valid_types',
188
-                array('EE_Register_Message_Type', 'register_messengers_to_validate_mt_with'),
189
-                10,
190
-                2
191
-            );
192
-            // actions
193
-            add_action(
194
-                'AHEE__EE_Addon__initialize_default_data__begin',
195
-                array('EE_Register_Message_Type', 'set_defaults')
196
-            );
65
+		// make sure this was called in the right place!
66
+		if (! did_action('EE_Brewing_Regular___messages_caf')
67
+			|| did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
68
+		) {
69
+			EE_Error::doing_it_wrong(
70
+				__METHOD__,
71
+				sprintf(
72
+					__(
73
+						'A message type named "%s" has been attempted to be registered with the EE Messages System.  It may or may not work because it should be only called on the "EE_Brewing_Regular___messages_caf" hook.',
74
+						'event_espresso'
75
+					),
76
+					$mt_name
77
+				),
78
+				'4.3.0'
79
+			);
80
+		}
81
+		// setup $__ee_message_type_registry array from incoming values.
82
+		self::$_ee_message_type_registry[ $mt_name ] = array(
83
+			/**
84
+			 * The file name for the message type being registered.
85
+			 * Required.
86
+			 *
87
+			 * @type string
88
+			 */
89
+			'mtfilename'                                       => (string) $setup_args['mtfilename'],
90
+			/**
91
+			 * Autoload paths for classes used by the message type.
92
+			 * Required.
93
+			 *
94
+			 * @type array
95
+			 */
96
+			'autoloadpaths'                                    => (array) $setup_args['autoloadpaths'],
97
+			/**
98
+			 * Messengers that the message type should be able to activate with.
99
+			 * Use messenger slugs.
100
+			 *
101
+			 * @type array
102
+			 */
103
+			'messengers_to_activate_with'                      => ! empty($setup_args['messengers_to_activate_with'])
104
+				? (array) $setup_args['messengers_to_activate_with']
105
+				: array(),
106
+			/**
107
+			 * Messengers that the message type should validate with.
108
+			 * Use messenger slugs.
109
+			 *
110
+			 * @type array
111
+			 */
112
+			'messengers_to_validate_with'                      => ! empty($setup_args['messengers_to_validate_with'])
113
+				? (array) $setup_args['messengers_to_validate_with']
114
+				: array(),
115
+			/**
116
+			 * Whether to force activate this message type the first time it is registered.
117
+			 *
118
+			 * @type bool   False means its not activated by default and left up to the end user to activate.
119
+			 */
120
+			'force_activation'                                 => ! empty($setup_args['force_activation'])
121
+				? (bool) $setup_args['force_activation']
122
+				: false,
123
+			/**
124
+			 * What messengers this message type supports the default template pack for.
125
+			 * Note: If you do not set this (or any of the following template pack/variation related arguments) to true,
126
+			 * then it is expected that the message type being registered is doing its own custom default template
127
+			 * pack/variation registration.
128
+			 *
129
+			 * If this is set and has values, then it is expected that the following arguments are also set in the incoming options
130
+			 * $setup_arguments array as well:
131
+			 * - 'base_path_for_default_templates'
132
+			 *
133
+			 * @type array   Expect an array of messengers this supports default template packs for.
134
+			 */
135
+			'messengers_supporting_default_template_pack_with' => isset($setup_args['messengers_supporting_default_template_pack_with'])
136
+				? (array) $setup_args['messengers_supporting_default_template_pack_with']
137
+				: array(),
138
+			/**
139
+			 * The base path where the default templates for this message type can be found.
140
+			 *
141
+			 * @type string
142
+			 */
143
+			'base_path_for_default_templates'                  => isset($setup_args['base_path_for_default_templates'])
144
+				? $setup_args['base_path_for_default_templates']
145
+				: '',
146
+			/**
147
+			 * The base path where the default variations for this message type can be found.
148
+			 *
149
+			 * @type string
150
+			 */
151
+			'base_path_for_default_variation'                  => isset($setup_args['base_path_for_default_variation'])
152
+				? $setup_args['base_path_for_default_variation']
153
+				: '',
154
+			/**
155
+			 * The base url for the default variations for this message type.
156
+			 *
157
+			 * @type string
158
+			 */
159
+			'base_url_for_default_variation'                   => isset($setup_args['base_url_for_default_variation'])
160
+				? $setup_args['base_url_for_default_variation']
161
+				: '',
162
+		);
163
+		// add filters but only if they haven't already been set (these filters only need to be registered ONCE because
164
+		// the callback handles all registered message types.
165
+		if (false === has_filter(
166
+			'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
167
+			array('EE_Register_Message_Type', 'register_msgs_autoload_paths')
168
+		)) {
169
+			add_filter(
170
+				'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
171
+				array('EE_Register_Message_Type', 'register_msgs_autoload_paths'),
172
+				10
173
+			);
174
+			add_filter(
175
+				'FHEE__EE_messages__get_installed__messagetype_files',
176
+				array('EE_Register_Message_Type', 'register_messagetype_files'),
177
+				10,
178
+				1
179
+			);
180
+			add_filter(
181
+				'FHEE__EE_messenger__get_default_message_types__default_types',
182
+				array('EE_Register_Message_Type', 'register_messengers_to_activate_mt_with'),
183
+				10,
184
+				2
185
+			);
186
+			add_filter(
187
+				'FHEE__EE_messenger__get_valid_message_types__valid_types',
188
+				array('EE_Register_Message_Type', 'register_messengers_to_validate_mt_with'),
189
+				10,
190
+				2
191
+			);
192
+			// actions
193
+			add_action(
194
+				'AHEE__EE_Addon__initialize_default_data__begin',
195
+				array('EE_Register_Message_Type', 'set_defaults')
196
+			);
197 197
 
198
-            // default template packs and variations related
199
-            add_filter(
200
-                'FHEE__EE_Messages_Template_Pack_Default__get_supports',
201
-                array('EE_Register_Message_Type', 'register_default_template_pack_supports')
202
-            );
203
-            add_filter(
204
-                'FHEE__EE_Template_Pack___get_specific_template__filtered_base_path',
205
-                array('EE_Register_Message_Type', 'register_base_template_path'),
206
-                10,
207
-                6
208
-            );
209
-            add_filter(
210
-                'FHEE__EE_Messages_Template_Pack__get_variation__base_path_or_url',
211
-                array('EE_Register_Message_Type', 'register_variation_base_path_or_url'),
212
-                10,
213
-                8
214
-            );
215
-            add_filter(
216
-                'FHEE__EE_Messages_Template_Pack__get_variation__base_path',
217
-                array('EE_Register_Message_Type', 'register_variation_base_path_or_url'),
218
-                10,
219
-                8
220
-            );
221
-        }
222
-    }
198
+			// default template packs and variations related
199
+			add_filter(
200
+				'FHEE__EE_Messages_Template_Pack_Default__get_supports',
201
+				array('EE_Register_Message_Type', 'register_default_template_pack_supports')
202
+			);
203
+			add_filter(
204
+				'FHEE__EE_Template_Pack___get_specific_template__filtered_base_path',
205
+				array('EE_Register_Message_Type', 'register_base_template_path'),
206
+				10,
207
+				6
208
+			);
209
+			add_filter(
210
+				'FHEE__EE_Messages_Template_Pack__get_variation__base_path_or_url',
211
+				array('EE_Register_Message_Type', 'register_variation_base_path_or_url'),
212
+				10,
213
+				8
214
+			);
215
+			add_filter(
216
+				'FHEE__EE_Messages_Template_Pack__get_variation__base_path',
217
+				array('EE_Register_Message_Type', 'register_variation_base_path_or_url'),
218
+				10,
219
+				8
220
+			);
221
+		}
222
+	}
223 223
 
224 224
 
225
-    /**
226
-     * This just ensures that when an addon registers a message type that on initial activation/reactivation the
227
-     * defaults the addon sets are taken care of.
228
-     */
229
-    public static function set_defaults()
230
-    {
231
-        /** @type EE_Message_Resource_Manager $message_resource_manager */
232
-        $message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
225
+	/**
226
+	 * This just ensures that when an addon registers a message type that on initial activation/reactivation the
227
+	 * defaults the addon sets are taken care of.
228
+	 */
229
+	public static function set_defaults()
230
+	{
231
+		/** @type EE_Message_Resource_Manager $message_resource_manager */
232
+		$message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
233 233
 
234
-        // for any message types with force activation, let's ensure they are activated
235
-        foreach (self::$_ee_message_type_registry as $message_type_name => $settings) {
236
-            if ($settings['force_activation']) {
237
-                foreach ($settings['messengers_to_activate_with'] as $messenger) {
238
-                    // DO not force activation if this message type has already been activated in the system
239
-                    if (! $message_resource_manager->has_message_type_been_activated_for_messenger(
240
-                        $message_type_name,
241
-                        $messenger
242
-                    )
243
-                    ) {
244
-                        $message_resource_manager->ensure_message_type_is_active($message_type_name, $messenger);
245
-                    }
246
-                }
247
-            }
248
-        }
249
-    }
234
+		// for any message types with force activation, let's ensure they are activated
235
+		foreach (self::$_ee_message_type_registry as $message_type_name => $settings) {
236
+			if ($settings['force_activation']) {
237
+				foreach ($settings['messengers_to_activate_with'] as $messenger) {
238
+					// DO not force activation if this message type has already been activated in the system
239
+					if (! $message_resource_manager->has_message_type_been_activated_for_messenger(
240
+						$message_type_name,
241
+						$messenger
242
+					)
243
+					) {
244
+						$message_resource_manager->ensure_message_type_is_active($message_type_name, $messenger);
245
+					}
246
+				}
247
+			}
248
+		}
249
+	}
250 250
 
251 251
 
252
-    /**
253
-     * This deregisters a message type that was previously registered with a specific message_type_name.
254
-     *
255
-     * @since    4.3.0
256
-     * @param string $message_type_name the name for the message type that was previously registered
257
-     * @return void
258
-     */
259
-    public static function deregister($message_type_name = null)
260
-    {
261
-        if (! empty(self::$_ee_message_type_registry[ $message_type_name ])) {
262
-            // let's make sure that we remove any place this message type was made active
263
-            /** @var EE_Message_Resource_Manager $Message_Resource_Manager */
264
-            $Message_Resource_Manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
265
-            // ensures that if this message type is registered again that it retains its previous active state vs
266
-            // remaining inactive.
267
-            $Message_Resource_Manager->remove_message_type_has_been_activated_from_all_messengers(
268
-                $message_type_name,
269
-                true
270
-            );
271
-            $Message_Resource_Manager->deactivate_message_type($message_type_name, false);
272
-            unset(self::$_ee_message_type_registry[ $message_type_name ]);
273
-        }
274
-    }
252
+	/**
253
+	 * This deregisters a message type that was previously registered with a specific message_type_name.
254
+	 *
255
+	 * @since    4.3.0
256
+	 * @param string $message_type_name the name for the message type that was previously registered
257
+	 * @return void
258
+	 */
259
+	public static function deregister($message_type_name = null)
260
+	{
261
+		if (! empty(self::$_ee_message_type_registry[ $message_type_name ])) {
262
+			// let's make sure that we remove any place this message type was made active
263
+			/** @var EE_Message_Resource_Manager $Message_Resource_Manager */
264
+			$Message_Resource_Manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
265
+			// ensures that if this message type is registered again that it retains its previous active state vs
266
+			// remaining inactive.
267
+			$Message_Resource_Manager->remove_message_type_has_been_activated_from_all_messengers(
268
+				$message_type_name,
269
+				true
270
+			);
271
+			$Message_Resource_Manager->deactivate_message_type($message_type_name, false);
272
+			unset(self::$_ee_message_type_registry[ $message_type_name ]);
273
+		}
274
+	}
275 275
 
276 276
 
277
-    /**
278
-     * callback for FHEE__EE_messages__get_installed__messagetype_files filter.
279
-     *
280
-     * @since   4.3.0
281
-     * @param  array $messagetype_files The current array of message type file names
282
-     * @return  array                                 Array of message type file names
283
-     */
284
-    public static function register_messagetype_files($messagetype_files)
285
-    {
286
-        if (empty(self::$_ee_message_type_registry)) {
287
-            return $messagetype_files;
288
-        }
289
-        foreach (self::$_ee_message_type_registry as $mt_reg) {
290
-            if (empty($mt_reg['mtfilename'])) {
291
-                continue;
292
-            }
293
-            $messagetype_files[] = $mt_reg['mtfilename'];
294
-        }
295
-        return $messagetype_files;
296
-    }
277
+	/**
278
+	 * callback for FHEE__EE_messages__get_installed__messagetype_files filter.
279
+	 *
280
+	 * @since   4.3.0
281
+	 * @param  array $messagetype_files The current array of message type file names
282
+	 * @return  array                                 Array of message type file names
283
+	 */
284
+	public static function register_messagetype_files($messagetype_files)
285
+	{
286
+		if (empty(self::$_ee_message_type_registry)) {
287
+			return $messagetype_files;
288
+		}
289
+		foreach (self::$_ee_message_type_registry as $mt_reg) {
290
+			if (empty($mt_reg['mtfilename'])) {
291
+				continue;
292
+			}
293
+			$messagetype_files[] = $mt_reg['mtfilename'];
294
+		}
295
+		return $messagetype_files;
296
+	}
297 297
 
298 298
 
299
-    /**
300
-     * callback for FHEE__EED_Messages___set_messages_paths___MSG_PATHS filter.
301
-     *
302
-     * @since    4.3.0
303
-     * @param array $paths array of paths to be checked by EE_messages autoloader.
304
-     * @return array
305
-     */
306
-    public static function register_msgs_autoload_paths($paths)
307
-    {
308
-        if (! empty(self::$_ee_message_type_registry)) {
309
-            foreach (self::$_ee_message_type_registry as $mt_reg) {
310
-                if (empty($mt_reg['autoloadpaths'])) {
311
-                    continue;
312
-                }
313
-                $paths = array_merge($paths, $mt_reg['autoloadpaths']);
314
-            }
315
-        }
316
-        return $paths;
317
-    }
299
+	/**
300
+	 * callback for FHEE__EED_Messages___set_messages_paths___MSG_PATHS filter.
301
+	 *
302
+	 * @since    4.3.0
303
+	 * @param array $paths array of paths to be checked by EE_messages autoloader.
304
+	 * @return array
305
+	 */
306
+	public static function register_msgs_autoload_paths($paths)
307
+	{
308
+		if (! empty(self::$_ee_message_type_registry)) {
309
+			foreach (self::$_ee_message_type_registry as $mt_reg) {
310
+				if (empty($mt_reg['autoloadpaths'])) {
311
+					continue;
312
+				}
313
+				$paths = array_merge($paths, $mt_reg['autoloadpaths']);
314
+			}
315
+		}
316
+		return $paths;
317
+	}
318 318
 
319 319
 
320
-    /**
321
-     * callback for FHEE__EE_messenger__get_default_message_types__default_types filter.
322
-     *
323
-     * @since  4.3.0
324
-     * @param  array        $default_types  array of message types activated with messenger (
325
-     *                                      corresponds to the $name property of message type)
326
-     * @param  EE_messenger $messenger      The EE_messenger the filter is called from.
327
-     * @return array
328
-     */
329
-    public static function register_messengers_to_activate_mt_with($default_types, EE_messenger $messenger)
330
-    {
331
-        if (empty(self::$_ee_message_type_registry)) {
332
-            return $default_types;
333
-        }
334
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
335
-            if (empty($mt_reg['messengers_to_activate_with']) || empty($mt_reg['mtfilename'])) {
336
-                continue;
337
-            }
338
-            // loop through each of the messengers and if it matches the loaded class
339
-            // then we add this message type to the
340
-            foreach ($mt_reg['messengers_to_activate_with'] as $msgr) {
341
-                if ($messenger->name == $msgr) {
342
-                    $default_types[] = $message_type_name;
343
-                }
344
-            }
345
-        }
320
+	/**
321
+	 * callback for FHEE__EE_messenger__get_default_message_types__default_types filter.
322
+	 *
323
+	 * @since  4.3.0
324
+	 * @param  array        $default_types  array of message types activated with messenger (
325
+	 *                                      corresponds to the $name property of message type)
326
+	 * @param  EE_messenger $messenger      The EE_messenger the filter is called from.
327
+	 * @return array
328
+	 */
329
+	public static function register_messengers_to_activate_mt_with($default_types, EE_messenger $messenger)
330
+	{
331
+		if (empty(self::$_ee_message_type_registry)) {
332
+			return $default_types;
333
+		}
334
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
335
+			if (empty($mt_reg['messengers_to_activate_with']) || empty($mt_reg['mtfilename'])) {
336
+				continue;
337
+			}
338
+			// loop through each of the messengers and if it matches the loaded class
339
+			// then we add this message type to the
340
+			foreach ($mt_reg['messengers_to_activate_with'] as $msgr) {
341
+				if ($messenger->name == $msgr) {
342
+					$default_types[] = $message_type_name;
343
+				}
344
+			}
345
+		}
346 346
 
347
-        return $default_types;
348
-    }
347
+		return $default_types;
348
+	}
349 349
 
350 350
 
351
-    /**
352
-     * callback for FHEE__EE_messenger__get_valid_message_types__default_types filter.
353
-     *
354
-     * @since   4.3.0
355
-     * @param  array        $valid_types    array of message types valid with messenger (
356
-     *                                      corresponds to the $name property of message type)
357
-     * @param  EE_messenger $messenger      The EE_messenger the filter is called from.
358
-     * @return  array
359
-     */
360
-    public static function register_messengers_to_validate_mt_with($valid_types, EE_messenger $messenger)
361
-    {
362
-        if (empty(self::$_ee_message_type_registry)) {
363
-            return $valid_types;
364
-        }
365
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
366
-            if (empty($mt_reg['messengers_to_validate_with']) || empty($mt_reg['mtfilename'])) {
367
-                continue;
368
-            }
369
-            // loop through each of the messengers and if it matches the loaded class
370
-            // then we add this message type to the
371
-            foreach ($mt_reg['messengers_to_validate_with'] as $msgr) {
372
-                if ($messenger->name == $msgr) {
373
-                    $valid_types[] = $message_type_name;
374
-                }
375
-            }
376
-        }
351
+	/**
352
+	 * callback for FHEE__EE_messenger__get_valid_message_types__default_types filter.
353
+	 *
354
+	 * @since   4.3.0
355
+	 * @param  array        $valid_types    array of message types valid with messenger (
356
+	 *                                      corresponds to the $name property of message type)
357
+	 * @param  EE_messenger $messenger      The EE_messenger the filter is called from.
358
+	 * @return  array
359
+	 */
360
+	public static function register_messengers_to_validate_mt_with($valid_types, EE_messenger $messenger)
361
+	{
362
+		if (empty(self::$_ee_message_type_registry)) {
363
+			return $valid_types;
364
+		}
365
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
366
+			if (empty($mt_reg['messengers_to_validate_with']) || empty($mt_reg['mtfilename'])) {
367
+				continue;
368
+			}
369
+			// loop through each of the messengers and if it matches the loaded class
370
+			// then we add this message type to the
371
+			foreach ($mt_reg['messengers_to_validate_with'] as $msgr) {
372
+				if ($messenger->name == $msgr) {
373
+					$valid_types[] = $message_type_name;
374
+				}
375
+			}
376
+		}
377 377
 
378
-        return $valid_types;
379
-    }
378
+		return $valid_types;
379
+	}
380 380
 
381 381
 
382
-    /**
383
-     * Callback for `FHEE__EE_Messages_Template_Pack_Default__get_supports` filter to register this message type as
384
-     * supporting the default template pack
385
-     *
386
-     * @param array $supports
387
-     *
388
-     * @return array
389
-     */
390
-    public static function register_default_template_pack_supports($supports)
391
-    {
392
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
393
-            if (empty($mt_reg['messengers_supporting_default_template_pack_with'])) {
394
-                continue;
395
-            }
396
-            foreach ($mt_reg['messengers_supporting_default_template_pack_with'] as $messenger_slug) {
397
-                $supports[ $messenger_slug ][] = $message_type_name;
398
-            }
399
-        }
400
-        return $supports;
401
-    }
382
+	/**
383
+	 * Callback for `FHEE__EE_Messages_Template_Pack_Default__get_supports` filter to register this message type as
384
+	 * supporting the default template pack
385
+	 *
386
+	 * @param array $supports
387
+	 *
388
+	 * @return array
389
+	 */
390
+	public static function register_default_template_pack_supports($supports)
391
+	{
392
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
393
+			if (empty($mt_reg['messengers_supporting_default_template_pack_with'])) {
394
+				continue;
395
+			}
396
+			foreach ($mt_reg['messengers_supporting_default_template_pack_with'] as $messenger_slug) {
397
+				$supports[ $messenger_slug ][] = $message_type_name;
398
+			}
399
+		}
400
+		return $supports;
401
+	}
402 402
 
403 403
 
404
-    /**
405
-     * Callback for FHEE__EE_Template_Pack___get_specific_template__filtered_base_path
406
-     *
407
-     * @param string                    $base_path The original base path for message templates
408
-     * @param EE_messenger              $messenger
409
-     * @param EE_message_type           $message_type
410
-     * @param string                    $field     The field requesting a template
411
-     * @param string                    $context   The context requesting a template
412
-     * @param EE_Messages_Template_Pack $template_pack
413
-     *
414
-     * @return string
415
-     */
416
-    public static function register_base_template_path(
417
-        $base_path,
418
-        $messenger,
419
-        $message_type,
420
-        $field,
421
-        $context,
422
-        $template_pack
423
-    ) {
424
-        if (! $template_pack instanceof EE_Messages_Template_Pack_Default
425
-            || ! $message_type instanceof EE_message_type
426
-        ) {
427
-            return $base_path;
428
-        }
429
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
430
-            if ($message_type->name === $message_type_name
431
-                && ! empty($mt_reg['base_path_for_default_templates'])
432
-            ) {
433
-                return $mt_reg['base_path_for_default_templates'];
434
-            }
435
-        }
436
-        return $base_path;
437
-    }
404
+	/**
405
+	 * Callback for FHEE__EE_Template_Pack___get_specific_template__filtered_base_path
406
+	 *
407
+	 * @param string                    $base_path The original base path for message templates
408
+	 * @param EE_messenger              $messenger
409
+	 * @param EE_message_type           $message_type
410
+	 * @param string                    $field     The field requesting a template
411
+	 * @param string                    $context   The context requesting a template
412
+	 * @param EE_Messages_Template_Pack $template_pack
413
+	 *
414
+	 * @return string
415
+	 */
416
+	public static function register_base_template_path(
417
+		$base_path,
418
+		$messenger,
419
+		$message_type,
420
+		$field,
421
+		$context,
422
+		$template_pack
423
+	) {
424
+		if (! $template_pack instanceof EE_Messages_Template_Pack_Default
425
+			|| ! $message_type instanceof EE_message_type
426
+		) {
427
+			return $base_path;
428
+		}
429
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
430
+			if ($message_type->name === $message_type_name
431
+				&& ! empty($mt_reg['base_path_for_default_templates'])
432
+			) {
433
+				return $mt_reg['base_path_for_default_templates'];
434
+			}
435
+		}
436
+		return $base_path;
437
+	}
438 438
 
439 439
 
440
-    /**
441
-     * Callback for FHEE__EE_Messages_Template_Pack__get_variation__base_path and
442
-     * FHEE__EE_Messages_Template_Pack__get_variation__base_path_or_url hooks
443
-     *
444
-     * @param string                    $base_path_or_url  The original incoming base url or path
445
-     * @param string                    $messenger_slug    The slug of the messenger the template is being generated
446
-     *                                                     for.
447
-     * @param string                    $message_type_slug The slug of the message type the template is being generated
448
-     *                                                     for.
449
-     * @param string                    $type              The "type" of css being requested.
450
-     * @param string                    $variation         The variation being requested.
451
-     * @param string                    $file_extension    What file extension is expected for the variation file.
452
-     * @param bool                      $url               whether a url or path is being requested.
453
-     * @param EE_Messages_Template_Pack $template_pack
454
-     *
455
-     * @return string
456
-     */
457
-    public static function register_variation_base_path_or_url(
458
-        $base_path_or_url,
459
-        $messenger_slug,
460
-        $message_type_slug,
461
-        $type,
462
-        $variation,
463
-        $url,
464
-        $file_extension,
465
-        $template_pack
466
-    ) {
467
-        if (! $template_pack instanceof EE_Messages_Template_Pack_Default) {
468
-            return $base_path_or_url;
469
-        }
470
-        foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
471
-            if ($message_type_name === $message_type_slug
472
-            ) {
473
-                if ($url
474
-                    && ! empty($mt_reg['base_url_for_default_variation'])
475
-                ) {
476
-                    return $mt_reg['base_url_for_default_variation'];
477
-                } elseif (! $url
478
-                          && ! empty($mt_reg['base_path_for_default_variation'])
479
-                ) {
480
-                    return $mt_reg['base_path_for_default_variation'];
481
-                }
482
-            }
483
-        }
484
-        return $base_path_or_url;
485
-    }
440
+	/**
441
+	 * Callback for FHEE__EE_Messages_Template_Pack__get_variation__base_path and
442
+	 * FHEE__EE_Messages_Template_Pack__get_variation__base_path_or_url hooks
443
+	 *
444
+	 * @param string                    $base_path_or_url  The original incoming base url or path
445
+	 * @param string                    $messenger_slug    The slug of the messenger the template is being generated
446
+	 *                                                     for.
447
+	 * @param string                    $message_type_slug The slug of the message type the template is being generated
448
+	 *                                                     for.
449
+	 * @param string                    $type              The "type" of css being requested.
450
+	 * @param string                    $variation         The variation being requested.
451
+	 * @param string                    $file_extension    What file extension is expected for the variation file.
452
+	 * @param bool                      $url               whether a url or path is being requested.
453
+	 * @param EE_Messages_Template_Pack $template_pack
454
+	 *
455
+	 * @return string
456
+	 */
457
+	public static function register_variation_base_path_or_url(
458
+		$base_path_or_url,
459
+		$messenger_slug,
460
+		$message_type_slug,
461
+		$type,
462
+		$variation,
463
+		$url,
464
+		$file_extension,
465
+		$template_pack
466
+	) {
467
+		if (! $template_pack instanceof EE_Messages_Template_Pack_Default) {
468
+			return $base_path_or_url;
469
+		}
470
+		foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
471
+			if ($message_type_name === $message_type_slug
472
+			) {
473
+				if ($url
474
+					&& ! empty($mt_reg['base_url_for_default_variation'])
475
+				) {
476
+					return $mt_reg['base_url_for_default_variation'];
477
+				} elseif (! $url
478
+						  && ! empty($mt_reg['base_path_for_default_variation'])
479
+				) {
480
+					return $mt_reg['base_path_for_default_variation'];
481
+				}
482
+			}
483
+		}
484
+		return $base_path_or_url;
485
+	}
486 486
 }
Please login to merge, or discard this patch.
Spacing   +12 added lines, -12 removed lines patch added patch discarded remove patch
@@ -45,7 +45,7 @@  discard block
 block discarded – undo
45 45
     public static function register($mt_name = null, $setup_args = array())
46 46
     {
47 47
         // required fields MUST be present, so let's make sure they are.
48
-        if (! isset($mt_name)
48
+        if ( ! isset($mt_name)
49 49
             || ! is_array($setup_args)
50 50
             || empty($setup_args['mtfilename']) || empty($setup_args['autoloadpaths'])
51 51
         ) {
@@ -58,12 +58,12 @@  discard block
 block discarded – undo
58 58
         }
59 59
 
60 60
         // make sure we don't register twice
61
-        if (isset(self::$_ee_message_type_registry[ $mt_name ])) {
61
+        if (isset(self::$_ee_message_type_registry[$mt_name])) {
62 62
             return;
63 63
         }
64 64
 
65 65
         // make sure this was called in the right place!
66
-        if (! did_action('EE_Brewing_Regular___messages_caf')
66
+        if ( ! did_action('EE_Brewing_Regular___messages_caf')
67 67
             || did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
68 68
         ) {
69 69
             EE_Error::doing_it_wrong(
@@ -79,7 +79,7 @@  discard block
 block discarded – undo
79 79
             );
80 80
         }
81 81
         // setup $__ee_message_type_registry array from incoming values.
82
-        self::$_ee_message_type_registry[ $mt_name ] = array(
82
+        self::$_ee_message_type_registry[$mt_name] = array(
83 83
             /**
84 84
              * The file name for the message type being registered.
85 85
              * Required.
@@ -236,7 +236,7 @@  discard block
 block discarded – undo
236 236
             if ($settings['force_activation']) {
237 237
                 foreach ($settings['messengers_to_activate_with'] as $messenger) {
238 238
                     // DO not force activation if this message type has already been activated in the system
239
-                    if (! $message_resource_manager->has_message_type_been_activated_for_messenger(
239
+                    if ( ! $message_resource_manager->has_message_type_been_activated_for_messenger(
240 240
                         $message_type_name,
241 241
                         $messenger
242 242
                     )
@@ -258,7 +258,7 @@  discard block
 block discarded – undo
258 258
      */
259 259
     public static function deregister($message_type_name = null)
260 260
     {
261
-        if (! empty(self::$_ee_message_type_registry[ $message_type_name ])) {
261
+        if ( ! empty(self::$_ee_message_type_registry[$message_type_name])) {
262 262
             // let's make sure that we remove any place this message type was made active
263 263
             /** @var EE_Message_Resource_Manager $Message_Resource_Manager */
264 264
             $Message_Resource_Manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
@@ -269,7 +269,7 @@  discard block
 block discarded – undo
269 269
                 true
270 270
             );
271 271
             $Message_Resource_Manager->deactivate_message_type($message_type_name, false);
272
-            unset(self::$_ee_message_type_registry[ $message_type_name ]);
272
+            unset(self::$_ee_message_type_registry[$message_type_name]);
273 273
         }
274 274
     }
275 275
 
@@ -305,7 +305,7 @@  discard block
 block discarded – undo
305 305
      */
306 306
     public static function register_msgs_autoload_paths($paths)
307 307
     {
308
-        if (! empty(self::$_ee_message_type_registry)) {
308
+        if ( ! empty(self::$_ee_message_type_registry)) {
309 309
             foreach (self::$_ee_message_type_registry as $mt_reg) {
310 310
                 if (empty($mt_reg['autoloadpaths'])) {
311 311
                     continue;
@@ -394,7 +394,7 @@  discard block
 block discarded – undo
394 394
                 continue;
395 395
             }
396 396
             foreach ($mt_reg['messengers_supporting_default_template_pack_with'] as $messenger_slug) {
397
-                $supports[ $messenger_slug ][] = $message_type_name;
397
+                $supports[$messenger_slug][] = $message_type_name;
398 398
             }
399 399
         }
400 400
         return $supports;
@@ -421,7 +421,7 @@  discard block
 block discarded – undo
421 421
         $context,
422 422
         $template_pack
423 423
     ) {
424
-        if (! $template_pack instanceof EE_Messages_Template_Pack_Default
424
+        if ( ! $template_pack instanceof EE_Messages_Template_Pack_Default
425 425
             || ! $message_type instanceof EE_message_type
426 426
         ) {
427 427
             return $base_path;
@@ -464,7 +464,7 @@  discard block
 block discarded – undo
464 464
         $file_extension,
465 465
         $template_pack
466 466
     ) {
467
-        if (! $template_pack instanceof EE_Messages_Template_Pack_Default) {
467
+        if ( ! $template_pack instanceof EE_Messages_Template_Pack_Default) {
468 468
             return $base_path_or_url;
469 469
         }
470 470
         foreach (self::$_ee_message_type_registry as $message_type_name => $mt_reg) {
@@ -474,7 +474,7 @@  discard block
 block discarded – undo
474 474
                     && ! empty($mt_reg['base_url_for_default_variation'])
475 475
                 ) {
476 476
                     return $mt_reg['base_url_for_default_variation'];
477
-                } elseif (! $url
477
+                } elseif ( ! $url
478 478
                           && ! empty($mt_reg['base_path_for_default_variation'])
479 479
                 ) {
480 480
                     return $mt_reg['base_path_for_default_variation'];
Please login to merge, or discard this patch.
core/libraries/plugin_api/EE_Register_Messages_Template_Variations.lib.php 2 patches
Indentation   +298 added lines, -298 removed lines patch added patch discarded remove patch
@@ -11,326 +11,326 @@
 block discarded – undo
11 11
 class EE_Register_Messages_Template_Variations implements EEI_Plugin_API
12 12
 {
13 13
 
14
-    /**
15
-     * Holds values for registered variations
16
-     *
17
-     * @since 4.5.0
18
-     *
19
-     * @var array
20
-     */
21
-    protected static $_registry = array();
14
+	/**
15
+	 * Holds values for registered variations
16
+	 *
17
+	 * @since 4.5.0
18
+	 *
19
+	 * @var array
20
+	 */
21
+	protected static $_registry = array();
22 22
 
23 23
 
24
-    /**
25
-     * Used to register new variations
26
-     *
27
-     * Variations are attached to template packs and do not typically change any structural layout but merely tweak the
28
-     * style of the layout.  The most commonly known variation is css.  CSS does not affect html structure just the
29
-     * style of existing structure.
30
-     *
31
-     * It's important to remember that when variation files are loaded, the file structure looked for is:
32
-     * '{$messenger}_{$messenger_variation_type}_{$variation_slug}.{$extension}'.
33
-     *
34
-     *    - Every variation applies to specific messengers.  That's why the variation file includes the messenger name
35
-     *    it.   This ensures that if a template pack the variation is registered with supports multiple variations that
36
-     *    you can have the correct variation loaded.
37
-     *    - EE_messengers also implicitly define variation "types" which typically are the context in which a specific
38
-     *    variation is loaded.  For instance the email messenger has: 'inline', which is the css added inline to the
39
-     *    email templates; 'preview', which is the same css only customized for when emails are previewed; and
40
-     *    'wpeditor', which is the same css only customized so that it works with the wpeditor fields for templates to
41
-     *    give a accurate representation of the style in the wysiwyg editor.  This means that for each variation, if
42
-     *    you want it to be accurately represented in various temlpate contexts you need to have that relevant
43
-     *    variation file available.
44
-     *    - $variation_slug  is simply the variation slug for that variation.
45
-     *    - $extension = whatever the extension is for the variation used for the messenger calling it.  In MOST cases
46
-     *    messenger variations are .css files. Note: if your file names are not formatted correctly then they will NOT
47
-     *    be loaded.  The EE messages template pack system will fallback to corresponding default template pack for the
48
-     *    given messenger or as a last resort (i.e. no default variation for the given messenger) will not load any
49
-     *    variation (so the template pack would be unstyled)
50
-     *
51
-     * @see /core/libraries/messages/defaults/default/variations/* for example variation files for the email and html
52
-     *      messengers.
53
-     *
54
-     * @param string $variation_ref                   unique reference used to describe this variation registry. If
55
-     *                                                this ISN'T unique then this method will make it unique (and it
56
-     *                                                becomes harder to deregister).
57
-     * @param array  $setup_args                      {
58
-     *                                                an array of required values for registering the variations.
59
-     * @type array   $variations                      {
60
-     *                                                An array indexed by template_pack->dbref. and values are an array
61
-     *                                                indexed by messenger name and values are an array indexed by
62
-     *                                                message_type and values are an array indexed by variation_slug
63
-     *                                                and value  is the localized label for the variation.  Note this
64
-     *                                                api reserves the "default" variation name for the default
65
-     *                                                template pack so you can't register a default variation.  Also,
66
-     *                                                try to use unique variation slugs to reference your variations
67
-     *                                                because this api checks if any existing varations are in place
68
-     *                                                with that name.  If there are then subsequent variations for that
69
-     *                                                template pack with that same name will fail to register with a
70
-     *                                                persistent notice put up for the user. Required.
71
-     *                                                'default' => array(
72
-     *                                                'email' => array(
73
-     *                                                'registration_approved' => array(
74
-     *                                                my_ee_addon_blue_lagoon' => __('Blue Lagoon',
75
-     *                                                'text_domain'),
76
-     *                                                'my_ee_addon_red_sunset' => __('Red Sunset',
77
-     *                                                'text_domain')
78
-     *                                                )
79
-     *                                                )
80
-     *                                                )
81
-     *                                                }
82
-     * @type string  $base_path                       The base path for where all your variations are found.  Although
83
-     *       the full path to your variation files should include '/variations/' in it, do not include the
84
-     *       'variations/' in this. Required.
85
-     * @type string  $base_url                        The base url for where all your variations are found. See note
86
-     *       above about the 'variations/' string. Required.
87
-     *                                                }
88
-     *                                                }
89
-     *
90
-     * @throws EE_Error
91
-     * @return void
92
-     */
93
-    public static function register($variation_ref = null, $setup_args = array())
94
-    {
24
+	/**
25
+	 * Used to register new variations
26
+	 *
27
+	 * Variations are attached to template packs and do not typically change any structural layout but merely tweak the
28
+	 * style of the layout.  The most commonly known variation is css.  CSS does not affect html structure just the
29
+	 * style of existing structure.
30
+	 *
31
+	 * It's important to remember that when variation files are loaded, the file structure looked for is:
32
+	 * '{$messenger}_{$messenger_variation_type}_{$variation_slug}.{$extension}'.
33
+	 *
34
+	 *    - Every variation applies to specific messengers.  That's why the variation file includes the messenger name
35
+	 *    it.   This ensures that if a template pack the variation is registered with supports multiple variations that
36
+	 *    you can have the correct variation loaded.
37
+	 *    - EE_messengers also implicitly define variation "types" which typically are the context in which a specific
38
+	 *    variation is loaded.  For instance the email messenger has: 'inline', which is the css added inline to the
39
+	 *    email templates; 'preview', which is the same css only customized for when emails are previewed; and
40
+	 *    'wpeditor', which is the same css only customized so that it works with the wpeditor fields for templates to
41
+	 *    give a accurate representation of the style in the wysiwyg editor.  This means that for each variation, if
42
+	 *    you want it to be accurately represented in various temlpate contexts you need to have that relevant
43
+	 *    variation file available.
44
+	 *    - $variation_slug  is simply the variation slug for that variation.
45
+	 *    - $extension = whatever the extension is for the variation used for the messenger calling it.  In MOST cases
46
+	 *    messenger variations are .css files. Note: if your file names are not formatted correctly then they will NOT
47
+	 *    be loaded.  The EE messages template pack system will fallback to corresponding default template pack for the
48
+	 *    given messenger or as a last resort (i.e. no default variation for the given messenger) will not load any
49
+	 *    variation (so the template pack would be unstyled)
50
+	 *
51
+	 * @see /core/libraries/messages/defaults/default/variations/* for example variation files for the email and html
52
+	 *      messengers.
53
+	 *
54
+	 * @param string $variation_ref                   unique reference used to describe this variation registry. If
55
+	 *                                                this ISN'T unique then this method will make it unique (and it
56
+	 *                                                becomes harder to deregister).
57
+	 * @param array  $setup_args                      {
58
+	 *                                                an array of required values for registering the variations.
59
+	 * @type array   $variations                      {
60
+	 *                                                An array indexed by template_pack->dbref. and values are an array
61
+	 *                                                indexed by messenger name and values are an array indexed by
62
+	 *                                                message_type and values are an array indexed by variation_slug
63
+	 *                                                and value  is the localized label for the variation.  Note this
64
+	 *                                                api reserves the "default" variation name for the default
65
+	 *                                                template pack so you can't register a default variation.  Also,
66
+	 *                                                try to use unique variation slugs to reference your variations
67
+	 *                                                because this api checks if any existing varations are in place
68
+	 *                                                with that name.  If there are then subsequent variations for that
69
+	 *                                                template pack with that same name will fail to register with a
70
+	 *                                                persistent notice put up for the user. Required.
71
+	 *                                                'default' => array(
72
+	 *                                                'email' => array(
73
+	 *                                                'registration_approved' => array(
74
+	 *                                                my_ee_addon_blue_lagoon' => __('Blue Lagoon',
75
+	 *                                                'text_domain'),
76
+	 *                                                'my_ee_addon_red_sunset' => __('Red Sunset',
77
+	 *                                                'text_domain')
78
+	 *                                                )
79
+	 *                                                )
80
+	 *                                                )
81
+	 *                                                }
82
+	 * @type string  $base_path                       The base path for where all your variations are found.  Although
83
+	 *       the full path to your variation files should include '/variations/' in it, do not include the
84
+	 *       'variations/' in this. Required.
85
+	 * @type string  $base_url                        The base url for where all your variations are found. See note
86
+	 *       above about the 'variations/' string. Required.
87
+	 *                                                }
88
+	 *                                                }
89
+	 *
90
+	 * @throws EE_Error
91
+	 * @return void
92
+	 */
93
+	public static function register($variation_ref = null, $setup_args = array())
94
+	{
95 95
 
96
-        // check for required params
97
-        if (empty($variation_ref)) {
98
-            throw new EE_Error(
99
-                __(
100
-                    'In order to register variations for a EE_Message_Template_Pack, you must include a value to reference the variations being registered',
101
-                    'event_espresso'
102
-                )
103
-            );
104
-        }
96
+		// check for required params
97
+		if (empty($variation_ref)) {
98
+			throw new EE_Error(
99
+				__(
100
+					'In order to register variations for a EE_Message_Template_Pack, you must include a value to reference the variations being registered',
101
+					'event_espresso'
102
+				)
103
+			);
104
+		}
105 105
 
106
-        if (! is_array($setup_args)
107
-            || empty($setup_args['variations'])
108
-            || empty($setup_args['base_path'])
109
-            || empty($setup_args['base_url'])
110
-        ) {
111
-            throw new EE_Error(
112
-                __(
113
-                    'In order to register variations for a EE_Message_Template_Pack, you must include an array containing the following keys: "variations", "base_path", "base_url", "extension"',
114
-                    'event_espresso'
115
-                )
116
-            );
117
-        }
106
+		if (! is_array($setup_args)
107
+			|| empty($setup_args['variations'])
108
+			|| empty($setup_args['base_path'])
109
+			|| empty($setup_args['base_url'])
110
+		) {
111
+			throw new EE_Error(
112
+				__(
113
+					'In order to register variations for a EE_Message_Template_Pack, you must include an array containing the following keys: "variations", "base_path", "base_url", "extension"',
114
+					'event_espresso'
115
+				)
116
+			);
117
+		}
118 118
 
119
-        // make sure we don't register twice
120
-        if (isset(self::$_registry[ $variation_ref ])) {
121
-            return;
122
-        }
119
+		// make sure we don't register twice
120
+		if (isset(self::$_registry[ $variation_ref ])) {
121
+			return;
122
+		}
123 123
 
124
-        // make sure variation ref is unique.
125
-        if (isset(self::$_registry[ $variation_ref ])) {
126
-            $variation_ref = uniqid() . '_' . $variation_ref;
127
-        }
124
+		// make sure variation ref is unique.
125
+		if (isset(self::$_registry[ $variation_ref ])) {
126
+			$variation_ref = uniqid() . '_' . $variation_ref;
127
+		}
128 128
 
129 129
 
130
-        // make sure this was called in the right place!
131
-        if (! did_action('EE_Brewing_Regular___messages_caf')
132
-            || did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
133
-        ) {
134
-            EE_Error::doing_it_wrong(
135
-                __METHOD__,
136
-                sprintf(
137
-                    __(
138
-                        'Messages Templates Variations given the reference "%s" has been attempted to be registered with the EE Messages Template Pack System.  It may or may not work because it should be only called on the "EE_Brewing_Regular__messages_caf" hook.',
139
-                        'event_espresso'
140
-                    ),
141
-                    $variation_ref
142
-                ),
143
-                '4.5.0'
144
-            );
145
-        }
130
+		// make sure this was called in the right place!
131
+		if (! did_action('EE_Brewing_Regular___messages_caf')
132
+			|| did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
133
+		) {
134
+			EE_Error::doing_it_wrong(
135
+				__METHOD__,
136
+				sprintf(
137
+					__(
138
+						'Messages Templates Variations given the reference "%s" has been attempted to be registered with the EE Messages Template Pack System.  It may or may not work because it should be only called on the "EE_Brewing_Regular__messages_caf" hook.',
139
+						'event_espresso'
140
+					),
141
+					$variation_ref
142
+				),
143
+				'4.5.0'
144
+			);
145
+		}
146 146
 
147
-        // validate/sanitize incoming args.
148
-        $validated = array(
149
-            'variations' => (array) $setup_args['variations'],
150
-            'base_path'  => (string) $setup_args['base_path'],
151
-            'base_url'   => (string) $setup_args['base_url'],
152
-        );
147
+		// validate/sanitize incoming args.
148
+		$validated = array(
149
+			'variations' => (array) $setup_args['variations'],
150
+			'base_path'  => (string) $setup_args['base_path'],
151
+			'base_url'   => (string) $setup_args['base_url'],
152
+		);
153 153
 
154 154
 
155
-        // check that no reserved variation names are in use and also checks if there are already existing variation names for a given template pack.  The former will throw an error.  The latter will remove the conflicting variation name but still register the others and will add EE_Error notice.
156
-        $validated = self::_verify_variations($variation_ref, $validated);
157
-        self::$_registry[ $variation_ref ] = $validated;
155
+		// check that no reserved variation names are in use and also checks if there are already existing variation names for a given template pack.  The former will throw an error.  The latter will remove the conflicting variation name but still register the others and will add EE_Error notice.
156
+		$validated = self::_verify_variations($variation_ref, $validated);
157
+		self::$_registry[ $variation_ref ] = $validated;
158 158
 
159
-        add_filter(
160
-            'FHEE__EE_Messages_Template_Pack__get_variations',
161
-            array('EE_Register_Messages_Template_Variations', 'get_variations'),
162
-            10,
163
-            4
164
-        );
165
-        add_filter(
166
-            'FHEE__EE_Messages_Template_Pack__get_variation',
167
-            array('EE_Register_Messages_Template_Variations', 'get_variation'),
168
-            10,
169
-            8
170
-        );
171
-    }
159
+		add_filter(
160
+			'FHEE__EE_Messages_Template_Pack__get_variations',
161
+			array('EE_Register_Messages_Template_Variations', 'get_variations'),
162
+			10,
163
+			4
164
+		);
165
+		add_filter(
166
+			'FHEE__EE_Messages_Template_Pack__get_variation',
167
+			array('EE_Register_Messages_Template_Variations', 'get_variation'),
168
+			10,
169
+			8
170
+		);
171
+	}
172 172
 
173 173
 
174
-    /**
175
-     * Cycles through the variations registered and makes sure there are no reserved variations being registered which
176
-     * throws an error.  Also checks if there is already a
177
-     *
178
-     * @since  4.5.0
179
-     *
180
-     * @param string $variation_ref        the reference for the variations being registered
181
-     * @param array  $validated_variations The variations setup array that's being registered (and verified).
182
-     * @throws EE_Error
183
-     * @return bool
184
-     */
185
-    private static function _verify_variations($variation_ref, $validated_variations)
186
-    {
187
-        foreach (self::$_registry as $variation_ref => $settings) {
188
-            foreach ($settings['variations'] as $template_pack => $messenger) {
189
-                foreach ($messenger as $all_variations) {
190
-                    if (isset($all_variations['default'])) {
191
-                        throw new EE_Error(
192
-                            sprintf(
193
-                                __(
194
-                                    'Variations registered through the EE_Register_Messages_Template_Variations api cannot override the default variation for the default template.  Please check the code registering variations with this reference, "%s" and modify.',
195
-                                    'event_espresso'
196
-                                ),
197
-                                $variation_ref
198
-                            )
199
-                        );
200
-                    }
201
-                }
202
-            }
203
-        }
174
+	/**
175
+	 * Cycles through the variations registered and makes sure there are no reserved variations being registered which
176
+	 * throws an error.  Also checks if there is already a
177
+	 *
178
+	 * @since  4.5.0
179
+	 *
180
+	 * @param string $variation_ref        the reference for the variations being registered
181
+	 * @param array  $validated_variations The variations setup array that's being registered (and verified).
182
+	 * @throws EE_Error
183
+	 * @return bool
184
+	 */
185
+	private static function _verify_variations($variation_ref, $validated_variations)
186
+	{
187
+		foreach (self::$_registry as $variation_ref => $settings) {
188
+			foreach ($settings['variations'] as $template_pack => $messenger) {
189
+				foreach ($messenger as $all_variations) {
190
+					if (isset($all_variations['default'])) {
191
+						throw new EE_Error(
192
+							sprintf(
193
+								__(
194
+									'Variations registered through the EE_Register_Messages_Template_Variations api cannot override the default variation for the default template.  Please check the code registering variations with this reference, "%s" and modify.',
195
+									'event_espresso'
196
+								),
197
+								$variation_ref
198
+							)
199
+						);
200
+					}
201
+				}
202
+			}
203
+		}
204 204
 
205
-        // is there already a variation registered with a given variation slug?
206
-        foreach ($validated_variations['variations'] as $template_pack => $messenger) {
207
-            foreach ($messenger as $message_type => $variations) {
208
-                foreach ($variations as $slug => $label) {
209
-                    foreach (self::$_registry as $registered_var => $reg_settings) {
210
-                        if (isset($reg_settings['variations'][ $template_pack ][ $messenger ][ $message_type ][ $slug ])) {
211
-                            unset($validated_variations['variations'][ $template_pack ][ $messenger ][ $message_type ][ $slug ]);
212
-                            EE_Error::add_error(
213
-                                sprintf(
214
-                                    __(
215
-                                        'Unable to register the %s variation for the %s template pack with the %s messenger and %s message_type because a variation with this slug was already registered for this template pack and messenger and message type by an addon using this key %s.',
216
-                                        'event_espresso'
217
-                                    ),
218
-                                    $label,
219
-                                    $template_pack,
220
-                                    $messenger,
221
-                                    $message_type,
222
-                                    $registered_var
223
-                                )
224
-                            );
225
-                        }
226
-                    }
227
-                }
228
-            }
229
-        }
230
-        return $validated_variations;
231
-    }
205
+		// is there already a variation registered with a given variation slug?
206
+		foreach ($validated_variations['variations'] as $template_pack => $messenger) {
207
+			foreach ($messenger as $message_type => $variations) {
208
+				foreach ($variations as $slug => $label) {
209
+					foreach (self::$_registry as $registered_var => $reg_settings) {
210
+						if (isset($reg_settings['variations'][ $template_pack ][ $messenger ][ $message_type ][ $slug ])) {
211
+							unset($validated_variations['variations'][ $template_pack ][ $messenger ][ $message_type ][ $slug ]);
212
+							EE_Error::add_error(
213
+								sprintf(
214
+									__(
215
+										'Unable to register the %s variation for the %s template pack with the %s messenger and %s message_type because a variation with this slug was already registered for this template pack and messenger and message type by an addon using this key %s.',
216
+										'event_espresso'
217
+									),
218
+									$label,
219
+									$template_pack,
220
+									$messenger,
221
+									$message_type,
222
+									$registered_var
223
+								)
224
+							);
225
+						}
226
+					}
227
+				}
228
+			}
229
+		}
230
+		return $validated_variations;
231
+	}
232 232
 
233 233
 
234
-    /**
235
-     * Callback for the FHEE__EE_Messages_Template_Pack__get_variation filter to ensure registered variations are used.
236
-     *
237
-     * @since 4.5.0
238
-     *
239
-     * @param string                    $variation_path The path generated for the current variation
240
-     * @param string                    $messenger      The messenger the variation is for
241
-     * @param string                    $message_type   EE_message_type->name
242
-     * @param string                    $type           The type of variation being requested
243
-     * @param string                    $variation      The slug for the variation being requested
244
-     * @param string                    $file_extension What the file extension is for the variation
245
-     * @param bool                      $url            Whether url or path is being returned.
246
-     * @param EE_Messages_Template_Pack $template_pack
247
-     *
248
-     * @return string                    The path to the requested variation.
249
-     */
250
-    public static function get_variation(
251
-        $variation_path,
252
-        $messenger,
253
-        $message_type,
254
-        $type,
255
-        $variation,
256
-        $file_extension,
257
-        $url,
258
-        EE_Messages_Template_Pack $template_pack
259
-    ) {
234
+	/**
235
+	 * Callback for the FHEE__EE_Messages_Template_Pack__get_variation filter to ensure registered variations are used.
236
+	 *
237
+	 * @since 4.5.0
238
+	 *
239
+	 * @param string                    $variation_path The path generated for the current variation
240
+	 * @param string                    $messenger      The messenger the variation is for
241
+	 * @param string                    $message_type   EE_message_type->name
242
+	 * @param string                    $type           The type of variation being requested
243
+	 * @param string                    $variation      The slug for the variation being requested
244
+	 * @param string                    $file_extension What the file extension is for the variation
245
+	 * @param bool                      $url            Whether url or path is being returned.
246
+	 * @param EE_Messages_Template_Pack $template_pack
247
+	 *
248
+	 * @return string                    The path to the requested variation.
249
+	 */
250
+	public static function get_variation(
251
+		$variation_path,
252
+		$messenger,
253
+		$message_type,
254
+		$type,
255
+		$variation,
256
+		$file_extension,
257
+		$url,
258
+		EE_Messages_Template_Pack $template_pack
259
+	) {
260 260
 
261
-        // so let's loop through our registered variations and then pull any details matching the request.
262
-        foreach (self::$_registry as $registry_slug => $registry_settings) {
263
-            $base = $url ? $registry_settings['base_url'] : $registry_settings['base_path'];
264
-            $file_string = $messenger . '_' . $type . '_' . $variation . $file_extension;
265
-            // see if this file exists
266
-            if (is_readable($registry_settings['base_path'] . $file_string)) {
267
-                return $base . $file_string;
268
-            }
269
-        }
261
+		// so let's loop through our registered variations and then pull any details matching the request.
262
+		foreach (self::$_registry as $registry_slug => $registry_settings) {
263
+			$base = $url ? $registry_settings['base_url'] : $registry_settings['base_path'];
264
+			$file_string = $messenger . '_' . $type . '_' . $variation . $file_extension;
265
+			// see if this file exists
266
+			if (is_readable($registry_settings['base_path'] . $file_string)) {
267
+				return $base . $file_string;
268
+			}
269
+		}
270 270
 
271
-        // no match
272
-        return $variation_path;
273
-    }
271
+		// no match
272
+		return $variation_path;
273
+	}
274 274
 
275 275
 
276
-    /**
277
-     * callback for the FHEE__EE_Messages_Template_Pack__get_variations filter.
278
-     *
279
-     *
280
-     * @since 4.5.0
281
-     *
282
-     * @param array                     $variations The original contents for the template pack variations property.
283
-     *                                              @see $_variation property definition in EE_Messages_Template_Pack
284
-     * @param string                    $messenger  The messenger requesting the variations.
285
-     * @param EE_Messages_Template_Pack $template_pack
286
-     *
287
-     * @return array                   new variations array (or existing one if nothing registered)
288
-     */
289
-    public static function get_variations(
290
-        $variations,
291
-        $messenger,
292
-        $message_type,
293
-        EE_Messages_Template_Pack $template_pack
294
-    ) {
295
-        // first let's check if we even have registered variations and get out early.
296
-        if (empty(self::$_registry)) {
297
-            return $variations;
298
-        }
276
+	/**
277
+	 * callback for the FHEE__EE_Messages_Template_Pack__get_variations filter.
278
+	 *
279
+	 *
280
+	 * @since 4.5.0
281
+	 *
282
+	 * @param array                     $variations The original contents for the template pack variations property.
283
+	 *                                              @see $_variation property definition in EE_Messages_Template_Pack
284
+	 * @param string                    $messenger  The messenger requesting the variations.
285
+	 * @param EE_Messages_Template_Pack $template_pack
286
+	 *
287
+	 * @return array                   new variations array (or existing one if nothing registered)
288
+	 */
289
+	public static function get_variations(
290
+		$variations,
291
+		$messenger,
292
+		$message_type,
293
+		EE_Messages_Template_Pack $template_pack
294
+	) {
295
+		// first let's check if we even have registered variations and get out early.
296
+		if (empty(self::$_registry)) {
297
+			return $variations;
298
+		}
299 299
 
300
-        // do we have any new variations for the given messenger, $message_type, and template packs
301
-        foreach (self::$_registry as $registry_slug => $registry_settings) {
302
-            // allow for different conditions.
303
-            if (empty($messenger)) {
304
-                $variations = array_merge($registry_settings['variations'], $variations);
305
-            } elseif (! empty($messenger) && empty($message_type) && ! empty($registry_settings['variations'][ $template_pack->dbref ][ $messenger ])) {
306
-                $variations = array_merge(
307
-                    $registry_settings['variations'][ $template_pack->dbref ][ $messenger ],
308
-                    $variations
309
-                );
310
-            } elseif (! empty($messenger) && ! empty($message_type) && ! empty($registry_settings['variations'][ $template_pack->dbref ][ $messenger ][ $message_type ])) {
311
-                $variations = array_merge(
312
-                    $registry_settings['variations'][ $template_pack->dbref ][ $messenger ][ $message_type ],
313
-                    $variations
314
-                );
315
-            }
316
-        }
317
-        return $variations;
318
-    }
300
+		// do we have any new variations for the given messenger, $message_type, and template packs
301
+		foreach (self::$_registry as $registry_slug => $registry_settings) {
302
+			// allow for different conditions.
303
+			if (empty($messenger)) {
304
+				$variations = array_merge($registry_settings['variations'], $variations);
305
+			} elseif (! empty($messenger) && empty($message_type) && ! empty($registry_settings['variations'][ $template_pack->dbref ][ $messenger ])) {
306
+				$variations = array_merge(
307
+					$registry_settings['variations'][ $template_pack->dbref ][ $messenger ],
308
+					$variations
309
+				);
310
+			} elseif (! empty($messenger) && ! empty($message_type) && ! empty($registry_settings['variations'][ $template_pack->dbref ][ $messenger ][ $message_type ])) {
311
+				$variations = array_merge(
312
+					$registry_settings['variations'][ $template_pack->dbref ][ $messenger ][ $message_type ],
313
+					$variations
314
+				);
315
+			}
316
+		}
317
+		return $variations;
318
+	}
319 319
 
320 320
 
321
-    /**
322
-     * This deregisters a variation set that was previously registered with the given slug.
323
-     *
324
-     * @since 4.5.0
325
-     *
326
-     * @param string $variation_ref The name for the variation set that was previously registered.
327
-     *
328
-     * @return void
329
-     */
330
-    public static function deregister($variation_ref = null)
331
-    {
332
-        if (! empty(self::$_registry[ $variation_ref ])) {
333
-            unset(self::$_registry[ $variation_ref ]);
334
-        }
335
-    }
321
+	/**
322
+	 * This deregisters a variation set that was previously registered with the given slug.
323
+	 *
324
+	 * @since 4.5.0
325
+	 *
326
+	 * @param string $variation_ref The name for the variation set that was previously registered.
327
+	 *
328
+	 * @return void
329
+	 */
330
+	public static function deregister($variation_ref = null)
331
+	{
332
+		if (! empty(self::$_registry[ $variation_ref ])) {
333
+			unset(self::$_registry[ $variation_ref ]);
334
+		}
335
+	}
336 336
 }
Please login to merge, or discard this patch.
Spacing   +17 added lines, -17 removed lines patch added patch discarded remove patch
@@ -103,7 +103,7 @@  discard block
 block discarded – undo
103 103
             );
104 104
         }
105 105
 
106
-        if (! is_array($setup_args)
106
+        if ( ! is_array($setup_args)
107 107
             || empty($setup_args['variations'])
108 108
             || empty($setup_args['base_path'])
109 109
             || empty($setup_args['base_url'])
@@ -117,18 +117,18 @@  discard block
 block discarded – undo
117 117
         }
118 118
 
119 119
         // make sure we don't register twice
120
-        if (isset(self::$_registry[ $variation_ref ])) {
120
+        if (isset(self::$_registry[$variation_ref])) {
121 121
             return;
122 122
         }
123 123
 
124 124
         // make sure variation ref is unique.
125
-        if (isset(self::$_registry[ $variation_ref ])) {
126
-            $variation_ref = uniqid() . '_' . $variation_ref;
125
+        if (isset(self::$_registry[$variation_ref])) {
126
+            $variation_ref = uniqid().'_'.$variation_ref;
127 127
         }
128 128
 
129 129
 
130 130
         // make sure this was called in the right place!
131
-        if (! did_action('EE_Brewing_Regular___messages_caf')
131
+        if ( ! did_action('EE_Brewing_Regular___messages_caf')
132 132
             || did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
133 133
         ) {
134 134
             EE_Error::doing_it_wrong(
@@ -154,7 +154,7 @@  discard block
 block discarded – undo
154 154
 
155 155
         // check that no reserved variation names are in use and also checks if there are already existing variation names for a given template pack.  The former will throw an error.  The latter will remove the conflicting variation name but still register the others and will add EE_Error notice.
156 156
         $validated = self::_verify_variations($variation_ref, $validated);
157
-        self::$_registry[ $variation_ref ] = $validated;
157
+        self::$_registry[$variation_ref] = $validated;
158 158
 
159 159
         add_filter(
160 160
             'FHEE__EE_Messages_Template_Pack__get_variations',
@@ -207,8 +207,8 @@  discard block
 block discarded – undo
207 207
             foreach ($messenger as $message_type => $variations) {
208 208
                 foreach ($variations as $slug => $label) {
209 209
                     foreach (self::$_registry as $registered_var => $reg_settings) {
210
-                        if (isset($reg_settings['variations'][ $template_pack ][ $messenger ][ $message_type ][ $slug ])) {
211
-                            unset($validated_variations['variations'][ $template_pack ][ $messenger ][ $message_type ][ $slug ]);
210
+                        if (isset($reg_settings['variations'][$template_pack][$messenger][$message_type][$slug])) {
211
+                            unset($validated_variations['variations'][$template_pack][$messenger][$message_type][$slug]);
212 212
                             EE_Error::add_error(
213 213
                                 sprintf(
214 214
                                     __(
@@ -261,10 +261,10 @@  discard block
 block discarded – undo
261 261
         // so let's loop through our registered variations and then pull any details matching the request.
262 262
         foreach (self::$_registry as $registry_slug => $registry_settings) {
263 263
             $base = $url ? $registry_settings['base_url'] : $registry_settings['base_path'];
264
-            $file_string = $messenger . '_' . $type . '_' . $variation . $file_extension;
264
+            $file_string = $messenger.'_'.$type.'_'.$variation.$file_extension;
265 265
             // see if this file exists
266
-            if (is_readable($registry_settings['base_path'] . $file_string)) {
267
-                return $base . $file_string;
266
+            if (is_readable($registry_settings['base_path'].$file_string)) {
267
+                return $base.$file_string;
268 268
             }
269 269
         }
270 270
 
@@ -302,14 +302,14 @@  discard block
 block discarded – undo
302 302
             // allow for different conditions.
303 303
             if (empty($messenger)) {
304 304
                 $variations = array_merge($registry_settings['variations'], $variations);
305
-            } elseif (! empty($messenger) && empty($message_type) && ! empty($registry_settings['variations'][ $template_pack->dbref ][ $messenger ])) {
305
+            } elseif ( ! empty($messenger) && empty($message_type) && ! empty($registry_settings['variations'][$template_pack->dbref][$messenger])) {
306 306
                 $variations = array_merge(
307
-                    $registry_settings['variations'][ $template_pack->dbref ][ $messenger ],
307
+                    $registry_settings['variations'][$template_pack->dbref][$messenger],
308 308
                     $variations
309 309
                 );
310
-            } elseif (! empty($messenger) && ! empty($message_type) && ! empty($registry_settings['variations'][ $template_pack->dbref ][ $messenger ][ $message_type ])) {
310
+            } elseif ( ! empty($messenger) && ! empty($message_type) && ! empty($registry_settings['variations'][$template_pack->dbref][$messenger][$message_type])) {
311 311
                 $variations = array_merge(
312
-                    $registry_settings['variations'][ $template_pack->dbref ][ $messenger ][ $message_type ],
312
+                    $registry_settings['variations'][$template_pack->dbref][$messenger][$message_type],
313 313
                     $variations
314 314
                 );
315 315
             }
@@ -329,8 +329,8 @@  discard block
 block discarded – undo
329 329
      */
330 330
     public static function deregister($variation_ref = null)
331 331
     {
332
-        if (! empty(self::$_registry[ $variation_ref ])) {
333
-            unset(self::$_registry[ $variation_ref ]);
332
+        if ( ! empty(self::$_registry[$variation_ref])) {
333
+            unset(self::$_registry[$variation_ref]);
334 334
         }
335 335
     }
336 336
 }
Please login to merge, or discard this patch.
core/libraries/plugin_api/EE_Register_Config.lib.php 2 patches
Indentation   +100 added lines, -100 removed lines patch added patch discarded remove patch
@@ -12,116 +12,116 @@
 block discarded – undo
12 12
 class EE_Register_Config implements EEI_Plugin_API
13 13
 {
14 14
 
15
-    /**
16
-     * Holds registered EE_Config items
17
-     *
18
-     * @var array
19
-     */
20
-    protected static $_ee_config_registry = array();
15
+	/**
16
+	 * Holds registered EE_Config items
17
+	 *
18
+	 * @var array
19
+	 */
20
+	protected static $_ee_config_registry = array();
21 21
 
22 22
 
23
-    /**
24
-     * Handles registering the new config with the EE_Config::instance()->addons property
25
-     *
26
-     * @since    4.3.0
27
-     * @throws EE_Error
28
-     *
29
-     * @param  string $config_class The name of the Config class being registered.
30
-     *                                                    Note this class must extend EE_Config Base and must have
31
-     *                                                    already been registered with an autoloader.
32
-     * @param  array  $setup_args {
33
-     *
34
-     * @type  string  $config_name Optional.  by default the new config will be registered to
35
-     *        EE_Config::instance()->addons->{config_class}, but supplying a "config_name" will set the property name
36
-     *        that this variable is accessible by. ie: EE_Config::instance()->addons->{config_name}
37
-     *                            }
38
-     * @return void
39
-     */
40
-    public static function register($config_class = null, $setup_args = array())
41
-    {
23
+	/**
24
+	 * Handles registering the new config with the EE_Config::instance()->addons property
25
+	 *
26
+	 * @since    4.3.0
27
+	 * @throws EE_Error
28
+	 *
29
+	 * @param  string $config_class The name of the Config class being registered.
30
+	 *                                                    Note this class must extend EE_Config Base and must have
31
+	 *                                                    already been registered with an autoloader.
32
+	 * @param  array  $setup_args {
33
+	 *
34
+	 * @type  string  $config_name Optional.  by default the new config will be registered to
35
+	 *        EE_Config::instance()->addons->{config_class}, but supplying a "config_name" will set the property name
36
+	 *        that this variable is accessible by. ie: EE_Config::instance()->addons->{config_name}
37
+	 *                            }
38
+	 * @return void
39
+	 */
40
+	public static function register($config_class = null, $setup_args = array())
41
+	{
42 42
 
43
-        $setup_args['config_name'] = isset($setup_args['config_name']) && ! empty($setup_args['config_name'])
44
-            ? $setup_args['config_name'] : $config_class;
45
-        $setup_args['config_section'] = isset($setup_args['config_section']) && ! empty($setup_args['config_section'])
46
-            ? $setup_args['config_section'] : 'addons';
43
+		$setup_args['config_name'] = isset($setup_args['config_name']) && ! empty($setup_args['config_name'])
44
+			? $setup_args['config_name'] : $config_class;
45
+		$setup_args['config_section'] = isset($setup_args['config_section']) && ! empty($setup_args['config_section'])
46
+			? $setup_args['config_section'] : 'addons';
47 47
 
48
-        // required fields MUST be present, so let's make sure they are.
49
-        if (empty($config_class) || ! is_array($setup_args) || empty($setup_args['config_name'])) {
50
-            throw new EE_Error(
51
-                __(
52
-                    'In order to register a Config Class with EE_Register_Config::register(), you must include a "config_class" (the actual class name for this config class). As well, you can supply an array containing the following keys: "config_section" the main section of the config object the settings will be saved under (by default the new config will be registered under EE_Config::instance()->modules or EE_Config::instance()->addons depending on what type of class is calling this), "config_name" (by default the new config will be registered to EE_Config::instance()->{config_section}->{config_class}, but supplying a "config_name" will set the property name that this variable is accessible by. ie: EE_Config::instance()->{config_section}->{config_name})',
53
-                    'event_espresso'
54
-                )
55
-            );
56
-        }
48
+		// required fields MUST be present, so let's make sure they are.
49
+		if (empty($config_class) || ! is_array($setup_args) || empty($setup_args['config_name'])) {
50
+			throw new EE_Error(
51
+				__(
52
+					'In order to register a Config Class with EE_Register_Config::register(), you must include a "config_class" (the actual class name for this config class). As well, you can supply an array containing the following keys: "config_section" the main section of the config object the settings will be saved under (by default the new config will be registered under EE_Config::instance()->modules or EE_Config::instance()->addons depending on what type of class is calling this), "config_name" (by default the new config will be registered to EE_Config::instance()->{config_section}->{config_class}, but supplying a "config_name" will set the property name that this variable is accessible by. ie: EE_Config::instance()->{config_section}->{config_name})',
53
+					'event_espresso'
54
+				)
55
+			);
56
+		}
57 57
 
58
-        // make sure we don't register twice
59
-        if (isset(self::$_ee_config_registry[ $config_class ])) {
60
-            return;
61
-        }
58
+		// make sure we don't register twice
59
+		if (isset(self::$_ee_config_registry[ $config_class ])) {
60
+			return;
61
+		}
62 62
 
63 63
 
64
-        // first find out if this happened too late.
65
-        if (did_action('AHEE__EE_System__load_core_configuration__begin')) {
66
-            EE_Error::doing_it_wrong(
67
-                __METHOD__,
68
-                sprintf(
69
-                    __(
70
-                        'An attempt to register "%s" as an EE_Config object has failed because it was not registered at the correct hookpoint.  Please register before the "AHEE__EE_System__load_core_configuration__begin" hook has fired',
71
-                        'event_espresso'
72
-                    ),
73
-                    $setup_args['config_name']
74
-                ),
75
-                '4.3'
76
-            );
77
-        }
78
-        // add incoming stuff to our registry property
79
-        self::$_ee_config_registry[ $config_class ] = array(
80
-            'section' => $setup_args['config_section'],
81
-            'name'    => $setup_args['config_name'],
82
-        );
64
+		// first find out if this happened too late.
65
+		if (did_action('AHEE__EE_System__load_core_configuration__begin')) {
66
+			EE_Error::doing_it_wrong(
67
+				__METHOD__,
68
+				sprintf(
69
+					__(
70
+						'An attempt to register "%s" as an EE_Config object has failed because it was not registered at the correct hookpoint.  Please register before the "AHEE__EE_System__load_core_configuration__begin" hook has fired',
71
+						'event_espresso'
72
+					),
73
+					$setup_args['config_name']
74
+				),
75
+				'4.3'
76
+			);
77
+		}
78
+		// add incoming stuff to our registry property
79
+		self::$_ee_config_registry[ $config_class ] = array(
80
+			'section' => $setup_args['config_section'],
81
+			'name'    => $setup_args['config_name'],
82
+		);
83 83
 
84
-        add_action('AHEE__EE_Config___load_core_config__end', array('EE_Register_Config', 'set_config'), 15, 1);
85
-        add_action('AHEE__EE_Config__update_espresso_config__end', array('EE_Register_Config', 'set_config'), 15, 1);
86
-    }
84
+		add_action('AHEE__EE_Config___load_core_config__end', array('EE_Register_Config', 'set_config'), 15, 1);
85
+		add_action('AHEE__EE_Config__update_espresso_config__end', array('EE_Register_Config', 'set_config'), 15, 1);
86
+	}
87 87
 
88 88
 
89
-    /**
90
-     * Callback for the AHEE__EE_Config___load_core_config__end hook.
91
-     * basically just calls EE_Config->get_config() which will take care of loading or creating our config object for us
92
-     *
93
-     * @since    4.3.0
94
-     * @throws EE_Error
95
-     * @param \EE_Config $EE_Config
96
-     * @return \StdClass
97
-     */
98
-    public static function set_config(EE_Config $EE_Config)
99
-    {
100
-        foreach (self::$_ee_config_registry as $config_class => $settings) {
101
-            // first some validation of our incoming class_name.  We'll throw an error early if its' not registered correctly
102
-            if (! class_exists($config_class)) {
103
-                throw new EE_Error(
104
-                    sprintf(
105
-                        __(
106
-                            'The "%s" config class can not be registered with EE_Config because it does not exist.  Verify that an autoloader has been set for this class',
107
-                            'event_espresso'
108
-                        ),
109
-                        $config_class
110
-                    )
111
-                );
112
-            }
113
-            $EE_Config->get_config($settings['section'], $settings['name'], $config_class);
114
-        }
115
-    }
89
+	/**
90
+	 * Callback for the AHEE__EE_Config___load_core_config__end hook.
91
+	 * basically just calls EE_Config->get_config() which will take care of loading or creating our config object for us
92
+	 *
93
+	 * @since    4.3.0
94
+	 * @throws EE_Error
95
+	 * @param \EE_Config $EE_Config
96
+	 * @return \StdClass
97
+	 */
98
+	public static function set_config(EE_Config $EE_Config)
99
+	{
100
+		foreach (self::$_ee_config_registry as $config_class => $settings) {
101
+			// first some validation of our incoming class_name.  We'll throw an error early if its' not registered correctly
102
+			if (! class_exists($config_class)) {
103
+				throw new EE_Error(
104
+					sprintf(
105
+						__(
106
+							'The "%s" config class can not be registered with EE_Config because it does not exist.  Verify that an autoloader has been set for this class',
107
+							'event_espresso'
108
+						),
109
+						$config_class
110
+					)
111
+				);
112
+			}
113
+			$EE_Config->get_config($settings['section'], $settings['name'], $config_class);
114
+		}
115
+	}
116 116
 
117 117
 
118
-    /**
119
-     * @param mixed $config_class_name
120
-     */
121
-    public static function deregister($config_class_name = null)
122
-    {
123
-        if (! empty(self::$_ee_config_registry[ $config_class_name ])) {
124
-            unset(self::$_ee_config_registry[ $config_class_name ]);
125
-        }
126
-    }
118
+	/**
119
+	 * @param mixed $config_class_name
120
+	 */
121
+	public static function deregister($config_class_name = null)
122
+	{
123
+		if (! empty(self::$_ee_config_registry[ $config_class_name ])) {
124
+			unset(self::$_ee_config_registry[ $config_class_name ]);
125
+		}
126
+	}
127 127
 }
Please login to merge, or discard this patch.
Spacing   +5 added lines, -5 removed lines patch added patch discarded remove patch
@@ -56,7 +56,7 @@  discard block
 block discarded – undo
56 56
         }
57 57
 
58 58
         // make sure we don't register twice
59
-        if (isset(self::$_ee_config_registry[ $config_class ])) {
59
+        if (isset(self::$_ee_config_registry[$config_class])) {
60 60
             return;
61 61
         }
62 62
 
@@ -76,7 +76,7 @@  discard block
 block discarded – undo
76 76
             );
77 77
         }
78 78
         // add incoming stuff to our registry property
79
-        self::$_ee_config_registry[ $config_class ] = array(
79
+        self::$_ee_config_registry[$config_class] = array(
80 80
             'section' => $setup_args['config_section'],
81 81
             'name'    => $setup_args['config_name'],
82 82
         );
@@ -99,7 +99,7 @@  discard block
 block discarded – undo
99 99
     {
100 100
         foreach (self::$_ee_config_registry as $config_class => $settings) {
101 101
             // first some validation of our incoming class_name.  We'll throw an error early if its' not registered correctly
102
-            if (! class_exists($config_class)) {
102
+            if ( ! class_exists($config_class)) {
103 103
                 throw new EE_Error(
104 104
                     sprintf(
105 105
                         __(
@@ -120,8 +120,8 @@  discard block
 block discarded – undo
120 120
      */
121 121
     public static function deregister($config_class_name = null)
122 122
     {
123
-        if (! empty(self::$_ee_config_registry[ $config_class_name ])) {
124
-            unset(self::$_ee_config_registry[ $config_class_name ]);
123
+        if ( ! empty(self::$_ee_config_registry[$config_class_name])) {
124
+            unset(self::$_ee_config_registry[$config_class_name]);
125 125
         }
126 126
     }
127 127
 }
Please login to merge, or discard this patch.
core/libraries/plugin_api/EE_Register_Capabilities.lib.php 2 patches
Indentation   +201 added lines, -201 removed lines patch added patch discarded remove patch
@@ -13,216 +13,216 @@
 block discarded – undo
13 13
 class EE_Register_Capabilities implements EEI_Plugin_API
14 14
 {
15 15
 
16
-    /**
17
-     * Holds the settings for a specific registration.
18
-     *
19
-     * @var array
20
-     */
21
-    protected static $_registry = array();
16
+	/**
17
+	 * Holds the settings for a specific registration.
18
+	 *
19
+	 * @var array
20
+	 */
21
+	protected static $_registry = array();
22 22
 
23 23
 
24
-    /**
25
-     * Used to register capability items with EE core.
26
-     *
27
-     * @since 4.5.0
28
-     * @param string $cap_reference                                                       usually will be a class name
29
-     *                                                                                    that references capability
30
-     *                                                                                    related items setup for
31
-     *                                                                                    something.
32
-     * @param array  $setup_args                                                          {
33
-     *                                                                                    An array of items related to
34
-     *                                                                                    registering capabilities.
35
-     * @type array   $capabilities                                                        An array mapping capability
36
-     *                                                                                    strings to core WP Role.
37
-     *                                                                                    Something like: array(
38
-     *                                                                                    'administrator'    => array(
39
-     *                                                                                    'read_cap', 'edit_cap',
40
-     *                                                                                    'delete_cap'),
41
-     *                                                                                    'author'                =>
42
-     *                                                                                    array( 'read_cap' )
43
-     *                                                                                    ).
44
-     * @type array   $capability_maps                                                     EE_Meta_Capability_Map[]
45
-     * @see   EE_Capabilities.php for php docs on these objects.
46
-     *                                                                                    Should be indexed by the
47
-     *                                                                                    classname for the capability
48
-     *                                                                                    map and values representing
49
-     *                                                                                    the arguments for the map.
50
-     *                                                                                    }
51
-     * @throws EE_Error
52
-     * @return void
53
-     */
54
-    public static function register($cap_reference = null, $setup_args = array())
55
-    {
56
-        // required fields MUST be present, so let's make sure they are.
57
-        if ($cap_reference === null || ! is_array($setup_args) || empty($setup_args['capabilities'])) {
58
-            throw new EE_Error(
59
-                __(
60
-                    'In order to register capabilities with EE_Register_Capabilities::register, you must include a unique name to reference the capabilities being registered, plus an array containing the following keys: "capabilities".',
61
-                    'event_espresso'
62
-                )
63
-            );
64
-        }
65
-        // make sure we don't register twice
66
-        if (isset(self::$_registry[ $cap_reference ])) {
67
-            return;
68
-        }
69
-        // make sure this is not registered too late or too early.
70
-        if (! did_action('AHEE__EE_System__load_espresso_addons')
71
-            || did_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin')
72
-        ) {
73
-            EE_Error::doing_it_wrong(
74
-                __METHOD__,
75
-                sprintf(
76
-                    __(
77
-                        '%s has been registered too late.  Please ensure that EE_Register_Capabilities::register has been called at some point before the "AHEE__EE_System___detect_if_activation_or_upgrade__begin" action hook has been called.',
78
-                        'event_espresso'
79
-                    ),
80
-                    $cap_reference
81
-                ),
82
-                '4.5.0'
83
-            );
84
-        }
85
-        // some preliminary sanitization and setting to the $_registry property
86
-        self::$_registry[ $cap_reference ] = array(
87
-            'caps'     => isset($setup_args['capabilities']) && is_array($setup_args['capabilities'])
88
-                ? $setup_args['capabilities']
89
-                : array(),
90
-            'cap_maps' => isset($setup_args['capability_maps'])
91
-                ? $setup_args['capability_maps']
92
-                : array(),
93
-        );
94
-        // set initial caps (note that EE_Capabilities takes care of making sure that the caps get added only once)
95
-        add_filter(
96
-            'FHEE__EE_Capabilities__addCaps__capabilities_to_add',
97
-            array('EE_Register_Capabilities', 'register_capabilities')
98
-        );
99
-        // add filter for cap maps
100
-        add_filter(
101
-            'FHEE__EE_Capabilities___set_meta_caps__meta_caps',
102
-            array('EE_Register_Capabilities', 'register_cap_maps')
103
-        );
104
-    }
24
+	/**
25
+	 * Used to register capability items with EE core.
26
+	 *
27
+	 * @since 4.5.0
28
+	 * @param string $cap_reference                                                       usually will be a class name
29
+	 *                                                                                    that references capability
30
+	 *                                                                                    related items setup for
31
+	 *                                                                                    something.
32
+	 * @param array  $setup_args                                                          {
33
+	 *                                                                                    An array of items related to
34
+	 *                                                                                    registering capabilities.
35
+	 * @type array   $capabilities                                                        An array mapping capability
36
+	 *                                                                                    strings to core WP Role.
37
+	 *                                                                                    Something like: array(
38
+	 *                                                                                    'administrator'    => array(
39
+	 *                                                                                    'read_cap', 'edit_cap',
40
+	 *                                                                                    'delete_cap'),
41
+	 *                                                                                    'author'                =>
42
+	 *                                                                                    array( 'read_cap' )
43
+	 *                                                                                    ).
44
+	 * @type array   $capability_maps                                                     EE_Meta_Capability_Map[]
45
+	 * @see   EE_Capabilities.php for php docs on these objects.
46
+	 *                                                                                    Should be indexed by the
47
+	 *                                                                                    classname for the capability
48
+	 *                                                                                    map and values representing
49
+	 *                                                                                    the arguments for the map.
50
+	 *                                                                                    }
51
+	 * @throws EE_Error
52
+	 * @return void
53
+	 */
54
+	public static function register($cap_reference = null, $setup_args = array())
55
+	{
56
+		// required fields MUST be present, so let's make sure they are.
57
+		if ($cap_reference === null || ! is_array($setup_args) || empty($setup_args['capabilities'])) {
58
+			throw new EE_Error(
59
+				__(
60
+					'In order to register capabilities with EE_Register_Capabilities::register, you must include a unique name to reference the capabilities being registered, plus an array containing the following keys: "capabilities".',
61
+					'event_espresso'
62
+				)
63
+			);
64
+		}
65
+		// make sure we don't register twice
66
+		if (isset(self::$_registry[ $cap_reference ])) {
67
+			return;
68
+		}
69
+		// make sure this is not registered too late or too early.
70
+		if (! did_action('AHEE__EE_System__load_espresso_addons')
71
+			|| did_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin')
72
+		) {
73
+			EE_Error::doing_it_wrong(
74
+				__METHOD__,
75
+				sprintf(
76
+					__(
77
+						'%s has been registered too late.  Please ensure that EE_Register_Capabilities::register has been called at some point before the "AHEE__EE_System___detect_if_activation_or_upgrade__begin" action hook has been called.',
78
+						'event_espresso'
79
+					),
80
+					$cap_reference
81
+				),
82
+				'4.5.0'
83
+			);
84
+		}
85
+		// some preliminary sanitization and setting to the $_registry property
86
+		self::$_registry[ $cap_reference ] = array(
87
+			'caps'     => isset($setup_args['capabilities']) && is_array($setup_args['capabilities'])
88
+				? $setup_args['capabilities']
89
+				: array(),
90
+			'cap_maps' => isset($setup_args['capability_maps'])
91
+				? $setup_args['capability_maps']
92
+				: array(),
93
+		);
94
+		// set initial caps (note that EE_Capabilities takes care of making sure that the caps get added only once)
95
+		add_filter(
96
+			'FHEE__EE_Capabilities__addCaps__capabilities_to_add',
97
+			array('EE_Register_Capabilities', 'register_capabilities')
98
+		);
99
+		// add filter for cap maps
100
+		add_filter(
101
+			'FHEE__EE_Capabilities___set_meta_caps__meta_caps',
102
+			array('EE_Register_Capabilities', 'register_cap_maps')
103
+		);
104
+	}
105 105
 
106 106
 
107
-    /**
108
-     * callback for FHEE__EE_Capabilities__init_caps_map__caps filter.
109
-     * Takes care of registering additional capabilities to the caps map.   Note, that this also on the initial
110
-     * registration ensures that new capabilities are added to existing roles.
111
-     *
112
-     * @param array $incoming_caps The original caps map.
113
-     * @return array merged in new caps.
114
-     */
115
-    public static function register_capabilities($incoming_caps)
116
-    {
117
-        foreach (self::$_registry as $cap_reference => $caps_and_cap_map) {
118
-            $incoming_caps = array_merge_recursive($incoming_caps, $caps_and_cap_map['caps']);
119
-        }
120
-        return $incoming_caps;
121
-    }
107
+	/**
108
+	 * callback for FHEE__EE_Capabilities__init_caps_map__caps filter.
109
+	 * Takes care of registering additional capabilities to the caps map.   Note, that this also on the initial
110
+	 * registration ensures that new capabilities are added to existing roles.
111
+	 *
112
+	 * @param array $incoming_caps The original caps map.
113
+	 * @return array merged in new caps.
114
+	 */
115
+	public static function register_capabilities($incoming_caps)
116
+	{
117
+		foreach (self::$_registry as $cap_reference => $caps_and_cap_map) {
118
+			$incoming_caps = array_merge_recursive($incoming_caps, $caps_and_cap_map['caps']);
119
+		}
120
+		return $incoming_caps;
121
+	}
122 122
 
123 123
 
124
-    /**
125
-     * Callback for the 'FHEE__EE_Capabilities___set_meta_caps__meta_caps' filter which registers an array of
126
-     * capability maps for the WP meta_caps filter called in EE_Capabilities.
127
-     *
128
-     * @since 4.5.0
129
-     * @param EE_Meta_Capability_Map[] $cap_maps The existing cap maps array.
130
-     * @return EE_Meta_Capability_Map[]
131
-     * @throws EE_Error
132
-     */
133
-    public static function register_cap_maps($cap_maps)
134
-    {
135
-        // loop through and instantiate cap maps.
136
-        foreach (self::$_registry as $cap_reference => $setup) {
137
-            if (! isset($setup['cap_maps'])) {
138
-                continue;
139
-            }
140
-            foreach ($setup['cap_maps'] as $cap_class => $args) {
124
+	/**
125
+	 * Callback for the 'FHEE__EE_Capabilities___set_meta_caps__meta_caps' filter which registers an array of
126
+	 * capability maps for the WP meta_caps filter called in EE_Capabilities.
127
+	 *
128
+	 * @since 4.5.0
129
+	 * @param EE_Meta_Capability_Map[] $cap_maps The existing cap maps array.
130
+	 * @return EE_Meta_Capability_Map[]
131
+	 * @throws EE_Error
132
+	 */
133
+	public static function register_cap_maps($cap_maps)
134
+	{
135
+		// loop through and instantiate cap maps.
136
+		foreach (self::$_registry as $cap_reference => $setup) {
137
+			if (! isset($setup['cap_maps'])) {
138
+				continue;
139
+			}
140
+			foreach ($setup['cap_maps'] as $cap_class => $args) {
141 141
 
142
-                /**
143
-                 * account for cases where capability maps may be indexed
144
-                 * numerically to allow for the same map class to be utilized
145
-                 * In those cases, maps will be setup in an array like:
146
-                 * array(
147
-                 *    0 => array( 'EE_Meta_Capability' => array(
148
-                 *        'ee_edit_cap', array( 'Object_Name',
149
-                 *        'ee_edit_published_cap',
150
-                 *        'ee_edit_others_cap', 'ee_edit_private_cap' )
151
-                 *        ) )
152
-                 *    1 => ...
153
-                 * )
154
-                 * instead of:
155
-                 * array(
156
-                 *    'EE_Meta_Capability' => array(
157
-                 *        'ee_edit_cap', array( 'Object_Name',
158
-                 *        'ee_edit_published_cap',
159
-                 *        'ee_edit_others_cap', 'ee_edit_private_cap' )
160
-                 *        ),
161
-                 *    ...
162
-                 * )
163
-                 */
164
-                if (is_numeric($cap_class)) {
165
-                    $cap_class = key($args);
166
-                    $args = $args[ $cap_class ];
167
-                }
142
+				/**
143
+				 * account for cases where capability maps may be indexed
144
+				 * numerically to allow for the same map class to be utilized
145
+				 * In those cases, maps will be setup in an array like:
146
+				 * array(
147
+				 *    0 => array( 'EE_Meta_Capability' => array(
148
+				 *        'ee_edit_cap', array( 'Object_Name',
149
+				 *        'ee_edit_published_cap',
150
+				 *        'ee_edit_others_cap', 'ee_edit_private_cap' )
151
+				 *        ) )
152
+				 *    1 => ...
153
+				 * )
154
+				 * instead of:
155
+				 * array(
156
+				 *    'EE_Meta_Capability' => array(
157
+				 *        'ee_edit_cap', array( 'Object_Name',
158
+				 *        'ee_edit_published_cap',
159
+				 *        'ee_edit_others_cap', 'ee_edit_private_cap' )
160
+				 *        ),
161
+				 *    ...
162
+				 * )
163
+				 */
164
+				if (is_numeric($cap_class)) {
165
+					$cap_class = key($args);
166
+					$args = $args[ $cap_class ];
167
+				}
168 168
 
169
-                if (! class_exists($cap_class)) {
170
-                    throw new EE_Error(
171
-                        sprintf(
172
-                            __(
173
-                                'An addon (%s) has tried to register a capability map improperly.  Capability map arrays must be indexed by capability map classname, and an array for the class arguments',
174
-                                'event_espresso'
175
-                            ),
176
-                            $cap_reference
177
-                        )
178
-                    );
179
-                }
169
+				if (! class_exists($cap_class)) {
170
+					throw new EE_Error(
171
+						sprintf(
172
+							__(
173
+								'An addon (%s) has tried to register a capability map improperly.  Capability map arrays must be indexed by capability map classname, and an array for the class arguments',
174
+								'event_espresso'
175
+							),
176
+							$cap_reference
177
+						)
178
+					);
179
+				}
180 180
 
181
-                if (count($args) !== 2) {
182
-                    throw new EE_Error(
183
-                        sprintf(
184
-                            __(
185
-                                'An addon (%s) has tried to register a capability map improperly.  Capability map arrays must be indexed by capability map classname, and an array for the class arguments.  The array should have two values the first being a string and the second an array.',
186
-                                'event_espresso'
187
-                            ),
188
-                            $cap_reference
189
-                        )
190
-                    );
191
-                }
192
-                $cap_maps[] = new $cap_class($args[0], $args[1]);
193
-            }
194
-        }
195
-        return $cap_maps;
196
-    }
181
+				if (count($args) !== 2) {
182
+					throw new EE_Error(
183
+						sprintf(
184
+							__(
185
+								'An addon (%s) has tried to register a capability map improperly.  Capability map arrays must be indexed by capability map classname, and an array for the class arguments.  The array should have two values the first being a string and the second an array.',
186
+								'event_espresso'
187
+							),
188
+							$cap_reference
189
+						)
190
+					);
191
+				}
192
+				$cap_maps[] = new $cap_class($args[0], $args[1]);
193
+			}
194
+		}
195
+		return $cap_maps;
196
+	}
197 197
 
198 198
 
199
-    /**
200
-     * @param string $cap_reference
201
-     * @throws EE_Error
202
-     * @throws \InvalidArgumentException
203
-     * @throws \EventEspresso\core\exceptions\InvalidDataTypeException
204
-     * @throws \EventEspresso\core\exceptions\InvalidInterfaceException
205
-     */
206
-    public static function deregister($cap_reference = '')
207
-    {
208
-        if (! empty(self::$_registry[ $cap_reference ])) {
209
-            if (! empty(self::$_registry[ $cap_reference ]['caps'])) {
210
-                // if it's too early to remove capabilities, wait to do this until core is loaded and ready
211
-                $caps_to_remove = self::$_registry[ $cap_reference ]['caps'];
212
-                if (did_action('AHEE__EE_System__core_loaded_and_ready')) {
213
-                    $capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
214
-                    $capabilities->removeCaps($caps_to_remove);
215
-                } else {
216
-                    add_action(
217
-                        'AHEE__EE_System__core_loaded_and_ready',
218
-                        function () use ($caps_to_remove) {
219
-                            $capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
220
-                            $capabilities->removeCaps($caps_to_remove);
221
-                        }
222
-                    );
223
-                }
224
-            }
225
-            unset(self::$_registry[ $cap_reference ]);
226
-        }
227
-    }
199
+	/**
200
+	 * @param string $cap_reference
201
+	 * @throws EE_Error
202
+	 * @throws \InvalidArgumentException
203
+	 * @throws \EventEspresso\core\exceptions\InvalidDataTypeException
204
+	 * @throws \EventEspresso\core\exceptions\InvalidInterfaceException
205
+	 */
206
+	public static function deregister($cap_reference = '')
207
+	{
208
+		if (! empty(self::$_registry[ $cap_reference ])) {
209
+			if (! empty(self::$_registry[ $cap_reference ]['caps'])) {
210
+				// if it's too early to remove capabilities, wait to do this until core is loaded and ready
211
+				$caps_to_remove = self::$_registry[ $cap_reference ]['caps'];
212
+				if (did_action('AHEE__EE_System__core_loaded_and_ready')) {
213
+					$capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
214
+					$capabilities->removeCaps($caps_to_remove);
215
+				} else {
216
+					add_action(
217
+						'AHEE__EE_System__core_loaded_and_ready',
218
+						function () use ($caps_to_remove) {
219
+							$capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
220
+							$capabilities->removeCaps($caps_to_remove);
221
+						}
222
+					);
223
+				}
224
+			}
225
+			unset(self::$_registry[ $cap_reference ]);
226
+		}
227
+	}
228 228
 }
Please login to merge, or discard this patch.
Spacing   +11 added lines, -11 removed lines patch added patch discarded remove patch
@@ -63,11 +63,11 @@  discard block
 block discarded – undo
63 63
             );
64 64
         }
65 65
         // make sure we don't register twice
66
-        if (isset(self::$_registry[ $cap_reference ])) {
66
+        if (isset(self::$_registry[$cap_reference])) {
67 67
             return;
68 68
         }
69 69
         // make sure this is not registered too late or too early.
70
-        if (! did_action('AHEE__EE_System__load_espresso_addons')
70
+        if ( ! did_action('AHEE__EE_System__load_espresso_addons')
71 71
             || did_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin')
72 72
         ) {
73 73
             EE_Error::doing_it_wrong(
@@ -83,7 +83,7 @@  discard block
 block discarded – undo
83 83
             );
84 84
         }
85 85
         // some preliminary sanitization and setting to the $_registry property
86
-        self::$_registry[ $cap_reference ] = array(
86
+        self::$_registry[$cap_reference] = array(
87 87
             'caps'     => isset($setup_args['capabilities']) && is_array($setup_args['capabilities'])
88 88
                 ? $setup_args['capabilities']
89 89
                 : array(),
@@ -134,7 +134,7 @@  discard block
 block discarded – undo
134 134
     {
135 135
         // loop through and instantiate cap maps.
136 136
         foreach (self::$_registry as $cap_reference => $setup) {
137
-            if (! isset($setup['cap_maps'])) {
137
+            if ( ! isset($setup['cap_maps'])) {
138 138
                 continue;
139 139
             }
140 140
             foreach ($setup['cap_maps'] as $cap_class => $args) {
@@ -163,10 +163,10 @@  discard block
 block discarded – undo
163 163
                  */
164 164
                 if (is_numeric($cap_class)) {
165 165
                     $cap_class = key($args);
166
-                    $args = $args[ $cap_class ];
166
+                    $args = $args[$cap_class];
167 167
                 }
168 168
 
169
-                if (! class_exists($cap_class)) {
169
+                if ( ! class_exists($cap_class)) {
170 170
                     throw new EE_Error(
171 171
                         sprintf(
172 172
                             __(
@@ -205,24 +205,24 @@  discard block
 block discarded – undo
205 205
      */
206 206
     public static function deregister($cap_reference = '')
207 207
     {
208
-        if (! empty(self::$_registry[ $cap_reference ])) {
209
-            if (! empty(self::$_registry[ $cap_reference ]['caps'])) {
208
+        if ( ! empty(self::$_registry[$cap_reference])) {
209
+            if ( ! empty(self::$_registry[$cap_reference]['caps'])) {
210 210
                 // if it's too early to remove capabilities, wait to do this until core is loaded and ready
211
-                $caps_to_remove = self::$_registry[ $cap_reference ]['caps'];
211
+                $caps_to_remove = self::$_registry[$cap_reference]['caps'];
212 212
                 if (did_action('AHEE__EE_System__core_loaded_and_ready')) {
213 213
                     $capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
214 214
                     $capabilities->removeCaps($caps_to_remove);
215 215
                 } else {
216 216
                     add_action(
217 217
                         'AHEE__EE_System__core_loaded_and_ready',
218
-                        function () use ($caps_to_remove) {
218
+                        function() use ($caps_to_remove) {
219 219
                             $capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
220 220
                             $capabilities->removeCaps($caps_to_remove);
221 221
                         }
222 222
                     );
223 223
                 }
224 224
             }
225
-            unset(self::$_registry[ $cap_reference ]);
225
+            unset(self::$_registry[$cap_reference]);
226 226
         }
227 227
     }
228 228
 }
Please login to merge, or discard this patch.
core/libraries/plugin_api/EE_Register_Data_Migration_Scripts.lib.php 2 patches
Indentation   +87 added lines, -87 removed lines patch added patch discarded remove patch
@@ -15,97 +15,97 @@
 block discarded – undo
15 15
 class EE_Register_Data_Migration_Scripts implements EEI_Plugin_API
16 16
 {
17 17
 
18
-    /**
19
-     * Holds values for registered DMSs
20
-     *
21
-     * @var array[][]
22
-     */
23
-    protected static $_settings = array();
18
+	/**
19
+	 * Holds values for registered DMSs
20
+	 *
21
+	 * @var array[][]
22
+	 */
23
+	protected static $_settings = array();
24 24
 
25 25
 
26
-    /**
27
-     * Method for registering new Data Migration Scripts
28
-     *
29
-     * @since 4.3.0
30
-     * @param string $addon_name EE_Addon class name that this set of data migration scripts belongs to
31
-     *                           If EE_Addon class is namespaced, then this needs to be the Fully Qualified Class Name
32
-     * @param array  $setup_args {
33
-     * @type string  $dms_paths  an array of full server paths to folders that contain data migration scripts
34
-     *                           }
35
-     * @throws EE_Error
36
-     * @return void
37
-     */
38
-    public static function register($addon_name = '', $setup_args = array())
39
-    {
40
-        // required fields MUST be present, so let's make sure they are.
41
-        if (empty($addon_name) || ! is_array($setup_args) || empty($setup_args['dms_paths'])) {
42
-            throw new EE_Error(
43
-                esc_html__(
44
-                    'In order to register Data Migration Scripts with EE_Register_Data_Migration_Scripts::register(), you must include the EE_Addon class name (used as a unique identifier for this set of data migration scripts), and an array containing the following keys: "dms_paths" (an array of full server paths to folders that contain data migration scripts)',
45
-                    'event_espresso'
46
-                )
47
-            );
48
-        }
49
-        // make sure we don't register twice
50
-        if (isset(self::$_settings[ $addon_name ])) {
51
-            return;
52
-        }
53
-        // make sure this was called in the right place!
54
-        if (! did_action('AHEE__EE_System__load_espresso_addons')
55
-            || did_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin')
56
-        ) {
57
-            EE_Error::doing_it_wrong(
58
-                __METHOD__,
59
-                esc_html__(
60
-                    'An attempt to register Data Migration Scripts has failed because it was not registered at the correct time.  Please use the "AHEE__EE_System__load_espresso_addons" hook to register Data Migration Scripts.',
61
-                    'event_espresso'
62
-                ),
63
-                '4.3.0'
64
-            );
65
-        }
66
-        // setup $_settings array from incoming values.
67
-        self::$_settings[ $addon_name ] = array(
68
-            'dms_paths' => (array) $setup_args['dms_paths'],
69
-        );
70
-        // setup DMS
71
-        add_filter(
72
-            'FHEE__EE_Data_Migration_Manager__get_data_migration_script_folders',
73
-            array('EE_Register_Data_Migration_Scripts', 'add_data_migration_script_folders')
74
-        );
75
-    }
26
+	/**
27
+	 * Method for registering new Data Migration Scripts
28
+	 *
29
+	 * @since 4.3.0
30
+	 * @param string $addon_name EE_Addon class name that this set of data migration scripts belongs to
31
+	 *                           If EE_Addon class is namespaced, then this needs to be the Fully Qualified Class Name
32
+	 * @param array  $setup_args {
33
+	 * @type string  $dms_paths  an array of full server paths to folders that contain data migration scripts
34
+	 *                           }
35
+	 * @throws EE_Error
36
+	 * @return void
37
+	 */
38
+	public static function register($addon_name = '', $setup_args = array())
39
+	{
40
+		// required fields MUST be present, so let's make sure they are.
41
+		if (empty($addon_name) || ! is_array($setup_args) || empty($setup_args['dms_paths'])) {
42
+			throw new EE_Error(
43
+				esc_html__(
44
+					'In order to register Data Migration Scripts with EE_Register_Data_Migration_Scripts::register(), you must include the EE_Addon class name (used as a unique identifier for this set of data migration scripts), and an array containing the following keys: "dms_paths" (an array of full server paths to folders that contain data migration scripts)',
45
+					'event_espresso'
46
+				)
47
+			);
48
+		}
49
+		// make sure we don't register twice
50
+		if (isset(self::$_settings[ $addon_name ])) {
51
+			return;
52
+		}
53
+		// make sure this was called in the right place!
54
+		if (! did_action('AHEE__EE_System__load_espresso_addons')
55
+			|| did_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin')
56
+		) {
57
+			EE_Error::doing_it_wrong(
58
+				__METHOD__,
59
+				esc_html__(
60
+					'An attempt to register Data Migration Scripts has failed because it was not registered at the correct time.  Please use the "AHEE__EE_System__load_espresso_addons" hook to register Data Migration Scripts.',
61
+					'event_espresso'
62
+				),
63
+				'4.3.0'
64
+			);
65
+		}
66
+		// setup $_settings array from incoming values.
67
+		self::$_settings[ $addon_name ] = array(
68
+			'dms_paths' => (array) $setup_args['dms_paths'],
69
+		);
70
+		// setup DMS
71
+		add_filter(
72
+			'FHEE__EE_Data_Migration_Manager__get_data_migration_script_folders',
73
+			array('EE_Register_Data_Migration_Scripts', 'add_data_migration_script_folders')
74
+		);
75
+	}
76 76
 
77 77
 
78
-    /**
79
-     * @param array $dms_paths
80
-     * @return array
81
-     */
82
-    public static function add_data_migration_script_folders($dms_paths = array())
83
-    {
84
-        foreach (self::$_settings as $addon_name => $settings) {
85
-            $wildcards = 0;
86
-            foreach ($settings['dms_paths'] as $dms_path) {
87
-                // since we are using the addon name for the array key
88
-                // we need to ensure that the key is unique,
89
-                // so if for some reason an addon has multiple dms paths,
90
-                // we append one or more * to the classname
91
-                // which will get stripped out later on
92
-                $dms_paths[ $addon_name . str_repeat('*', $wildcards) ] = $dms_path;
93
-                $wildcards++;
94
-            }
95
-        }
96
-        return $dms_paths;
97
-    }
78
+	/**
79
+	 * @param array $dms_paths
80
+	 * @return array
81
+	 */
82
+	public static function add_data_migration_script_folders($dms_paths = array())
83
+	{
84
+		foreach (self::$_settings as $addon_name => $settings) {
85
+			$wildcards = 0;
86
+			foreach ($settings['dms_paths'] as $dms_path) {
87
+				// since we are using the addon name for the array key
88
+				// we need to ensure that the key is unique,
89
+				// so if for some reason an addon has multiple dms paths,
90
+				// we append one or more * to the classname
91
+				// which will get stripped out later on
92
+				$dms_paths[ $addon_name . str_repeat('*', $wildcards) ] = $dms_path;
93
+				$wildcards++;
94
+			}
95
+		}
96
+		return $dms_paths;
97
+	}
98 98
 
99 99
 
100
-    /**
101
-     * This deregisters a set of Data Migration Scripts that were previously registered with a specific dms_id
102
-     *
103
-     * @since 4.3.0
104
-     * @param string $addon_name EE_Addon class name that this set of data migration scripts belongs to
105
-     * @return void
106
-     */
107
-    public static function deregister($addon_name = '')
108
-    {
109
-        unset(self::$_settings[ $addon_name ]);
110
-    }
100
+	/**
101
+	 * This deregisters a set of Data Migration Scripts that were previously registered with a specific dms_id
102
+	 *
103
+	 * @since 4.3.0
104
+	 * @param string $addon_name EE_Addon class name that this set of data migration scripts belongs to
105
+	 * @return void
106
+	 */
107
+	public static function deregister($addon_name = '')
108
+	{
109
+		unset(self::$_settings[ $addon_name ]);
110
+	}
111 111
 }
Please login to merge, or discard this patch.
Spacing   +5 added lines, -5 removed lines patch added patch discarded remove patch
@@ -47,11 +47,11 @@  discard block
 block discarded – undo
47 47
             );
48 48
         }
49 49
         // make sure we don't register twice
50
-        if (isset(self::$_settings[ $addon_name ])) {
50
+        if (isset(self::$_settings[$addon_name])) {
51 51
             return;
52 52
         }
53 53
         // make sure this was called in the right place!
54
-        if (! did_action('AHEE__EE_System__load_espresso_addons')
54
+        if ( ! did_action('AHEE__EE_System__load_espresso_addons')
55 55
             || did_action('AHEE__EE_System___detect_if_activation_or_upgrade__begin')
56 56
         ) {
57 57
             EE_Error::doing_it_wrong(
@@ -64,7 +64,7 @@  discard block
 block discarded – undo
64 64
             );
65 65
         }
66 66
         // setup $_settings array from incoming values.
67
-        self::$_settings[ $addon_name ] = array(
67
+        self::$_settings[$addon_name] = array(
68 68
             'dms_paths' => (array) $setup_args['dms_paths'],
69 69
         );
70 70
         // setup DMS
@@ -89,7 +89,7 @@  discard block
 block discarded – undo
89 89
                 // so if for some reason an addon has multiple dms paths,
90 90
                 // we append one or more * to the classname
91 91
                 // which will get stripped out later on
92
-                $dms_paths[ $addon_name . str_repeat('*', $wildcards) ] = $dms_path;
92
+                $dms_paths[$addon_name.str_repeat('*', $wildcards)] = $dms_path;
93 93
                 $wildcards++;
94 94
             }
95 95
         }
@@ -106,6 +106,6 @@  discard block
 block discarded – undo
106 106
      */
107 107
     public static function deregister($addon_name = '')
108 108
     {
109
-        unset(self::$_settings[ $addon_name ]);
109
+        unset(self::$_settings[$addon_name]);
110 110
     }
111 111
 }
Please login to merge, or discard this patch.
core/libraries/plugin_api/EE_Register_Payment_Method.lib.php 2 patches
Indentation   +154 added lines, -154 removed lines patch added patch discarded remove patch
@@ -19,166 +19,166 @@
 block discarded – undo
19 19
 class EE_Register_Payment_Method implements EEI_Plugin_API
20 20
 {
21 21
 
22
-    /**
23
-     * Holds values for registered payment methods
24
-     *
25
-     * @var array
26
-     */
27
-    protected static $_settings = array();
22
+	/**
23
+	 * Holds values for registered payment methods
24
+	 *
25
+	 * @var array
26
+	 */
27
+	protected static $_settings = array();
28 28
 
29 29
 
30
-    /**
31
-     * Method for registering new EE_PMT_Base children
32
-     *
33
-     * @since    4.5.0
34
-     * @param string  $payment_method_id    a unique identifier for this set of modules Required.
35
-     * @param  array  $setup_args           an array of arguments provided for registering modules Required.{
36
-     * @type string[] $payment_method_paths each element is the folder containing the EE_PMT_Base child class
37
-     *                                      (eg, 'public_html/wp-content/plugins/my_plugin/Payomatic/' which contains
38
-     *                                      the files EE_PMT_Payomatic.pm.php)
39
-     *                                      }
40
-     * @throws EE_Error
41
-     * @type array payment_method_paths    an array of full server paths to folders containing any EE_PMT_Base
42
-     *                                      children, or to the EED_Module files themselves
43
-     * @return void
44
-     * @throws InvalidDataTypeException
45
-     * @throws DomainException
46
-     * @throws InvalidArgumentException
47
-     * @throws InvalidInterfaceException
48
-     * @throws InvalidDataTypeException
49
-     */
50
-    public static function register($payment_method_id = null, $setup_args = array())
51
-    {
52
-        // required fields MUST be present, so let's make sure they are.
53
-        if (empty($payment_method_id) || ! is_array($setup_args) || empty($setup_args['payment_method_paths'])) {
54
-            throw new EE_Error(
55
-                esc_html__(
56
-                    'In order to register Payment Methods with EE_Register_Payment_Method::register(), you must include a "payment_method_id" (a unique identifier for this set of modules), and an array containing the following keys: "payment_method_paths" (an array of full server paths to folders that contain modules, or to the module files themselves)',
57
-                    'event_espresso'
58
-                )
59
-            );
60
-        }
61
-        // make sure we don't register twice
62
-        if (isset(self::$_settings[ $payment_method_id ])) {
63
-            return;
64
-        }
65
-        // make sure this was called in the right place!
66
-        if (! did_action('AHEE__EE_System__load_espresso_addons')
67
-            || did_action('AHEE__EE_System__register_shortcodes_modules_and_widgets')
68
-        ) {
69
-            EE_Error::doing_it_wrong(
70
-                __METHOD__,
71
-                esc_html__(
72
-                    'An attempt to register modules has failed because it was not registered at the correct time.  Please use the "AHEE__EE_System__register_shortcodes_modules_and_widgets" hook to register modules.',
73
-                    'event_espresso'
74
-                ),
75
-                '4.3.0'
76
-            );
77
-        }
78
-        // setup $_settings array from incoming values.
79
-        self::$_settings[ $payment_method_id ] = array(
80
-            // array of full server paths to any EE_PMT_Base children used
81
-            'payment_method_paths' => isset($setup_args['payment_method_paths'])
82
-                ? (array) $setup_args['payment_method_paths']
83
-                : array(),
84
-        );
85
-        // add to list of modules to be registered
86
-        add_filter(
87
-            'FHEE__EE_Payment_Method_Manager__register_payment_methods__payment_methods_to_register',
88
-            array('EE_Register_Payment_Method', 'add_payment_methods')
89
-        );
90
-        // If EE_Payment_Method_Manager::register_payment_methods has already been called,
91
-        // then we need to add our caps for this payment method manually
92
-        if (did_action('FHEE__EE_Payment_Method_Manager__register_payment_methods__registered_payment_methods')) {
93
-            $payment_method_manager = LoaderFactory::getLoader()->getShared('EE_Payment_Method_Manager');
94
-            // register payment methods directly
95
-            foreach (self::$_settings[ $payment_method_id ]['payment_method_paths'] as $payment_method_path) {
96
-                $payment_method_manager->register_payment_method($payment_method_path);
97
-            }
98
-            $capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
99
-            $capabilities->addCaps(
100
-                self::getPaymentMethodCapabilities(self::$_settings[ $payment_method_id ])
101
-            );
102
-        }
103
-    }
30
+	/**
31
+	 * Method for registering new EE_PMT_Base children
32
+	 *
33
+	 * @since    4.5.0
34
+	 * @param string  $payment_method_id    a unique identifier for this set of modules Required.
35
+	 * @param  array  $setup_args           an array of arguments provided for registering modules Required.{
36
+	 * @type string[] $payment_method_paths each element is the folder containing the EE_PMT_Base child class
37
+	 *                                      (eg, 'public_html/wp-content/plugins/my_plugin/Payomatic/' which contains
38
+	 *                                      the files EE_PMT_Payomatic.pm.php)
39
+	 *                                      }
40
+	 * @throws EE_Error
41
+	 * @type array payment_method_paths    an array of full server paths to folders containing any EE_PMT_Base
42
+	 *                                      children, or to the EED_Module files themselves
43
+	 * @return void
44
+	 * @throws InvalidDataTypeException
45
+	 * @throws DomainException
46
+	 * @throws InvalidArgumentException
47
+	 * @throws InvalidInterfaceException
48
+	 * @throws InvalidDataTypeException
49
+	 */
50
+	public static function register($payment_method_id = null, $setup_args = array())
51
+	{
52
+		// required fields MUST be present, so let's make sure they are.
53
+		if (empty($payment_method_id) || ! is_array($setup_args) || empty($setup_args['payment_method_paths'])) {
54
+			throw new EE_Error(
55
+				esc_html__(
56
+					'In order to register Payment Methods with EE_Register_Payment_Method::register(), you must include a "payment_method_id" (a unique identifier for this set of modules), and an array containing the following keys: "payment_method_paths" (an array of full server paths to folders that contain modules, or to the module files themselves)',
57
+					'event_espresso'
58
+				)
59
+			);
60
+		}
61
+		// make sure we don't register twice
62
+		if (isset(self::$_settings[ $payment_method_id ])) {
63
+			return;
64
+		}
65
+		// make sure this was called in the right place!
66
+		if (! did_action('AHEE__EE_System__load_espresso_addons')
67
+			|| did_action('AHEE__EE_System__register_shortcodes_modules_and_widgets')
68
+		) {
69
+			EE_Error::doing_it_wrong(
70
+				__METHOD__,
71
+				esc_html__(
72
+					'An attempt to register modules has failed because it was not registered at the correct time.  Please use the "AHEE__EE_System__register_shortcodes_modules_and_widgets" hook to register modules.',
73
+					'event_espresso'
74
+				),
75
+				'4.3.0'
76
+			);
77
+		}
78
+		// setup $_settings array from incoming values.
79
+		self::$_settings[ $payment_method_id ] = array(
80
+			// array of full server paths to any EE_PMT_Base children used
81
+			'payment_method_paths' => isset($setup_args['payment_method_paths'])
82
+				? (array) $setup_args['payment_method_paths']
83
+				: array(),
84
+		);
85
+		// add to list of modules to be registered
86
+		add_filter(
87
+			'FHEE__EE_Payment_Method_Manager__register_payment_methods__payment_methods_to_register',
88
+			array('EE_Register_Payment_Method', 'add_payment_methods')
89
+		);
90
+		// If EE_Payment_Method_Manager::register_payment_methods has already been called,
91
+		// then we need to add our caps for this payment method manually
92
+		if (did_action('FHEE__EE_Payment_Method_Manager__register_payment_methods__registered_payment_methods')) {
93
+			$payment_method_manager = LoaderFactory::getLoader()->getShared('EE_Payment_Method_Manager');
94
+			// register payment methods directly
95
+			foreach (self::$_settings[ $payment_method_id ]['payment_method_paths'] as $payment_method_path) {
96
+				$payment_method_manager->register_payment_method($payment_method_path);
97
+			}
98
+			$capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
99
+			$capabilities->addCaps(
100
+				self::getPaymentMethodCapabilities(self::$_settings[ $payment_method_id ])
101
+			);
102
+		}
103
+	}
104 104
 
105 105
 
106
-    /**
107
-     * Filters the list of payment methods to add ours.
108
-     * and they're just full filepaths to FOLDERS containing a payment method class file. Eg.
109
-     *
110
-     * @param array $payment_method_folders array of paths to all payment methods that require registering
111
-     * @return array
112
-     */
113
-    public static function add_payment_methods($payment_method_folders)
114
-    {
115
-        foreach (self::$_settings as $settings) {
116
-            foreach ($settings['payment_method_paths'] as $payment_method_path) {
117
-                $payment_method_folders[] = $payment_method_path;
118
-            }
119
-        }
120
-        return $payment_method_folders;
121
-    }
106
+	/**
107
+	 * Filters the list of payment methods to add ours.
108
+	 * and they're just full filepaths to FOLDERS containing a payment method class file. Eg.
109
+	 *
110
+	 * @param array $payment_method_folders array of paths to all payment methods that require registering
111
+	 * @return array
112
+	 */
113
+	public static function add_payment_methods($payment_method_folders)
114
+	{
115
+		foreach (self::$_settings as $settings) {
116
+			foreach ($settings['payment_method_paths'] as $payment_method_path) {
117
+				$payment_method_folders[] = $payment_method_path;
118
+			}
119
+		}
120
+		return $payment_method_folders;
121
+	}
122 122
 
123 123
 
124
-    /**
125
-     * This deregisters a module that was previously registered with a specific $module_id.
126
-     *
127
-     * @since    4.3.0
128
-     *
129
-     * @param string $module_id the name for the module that was previously registered
130
-     * @return void
131
-     * @throws DomainException
132
-     * @throws EE_Error
133
-     * @throws InvalidArgumentException
134
-     * @throws InvalidInterfaceException
135
-     * @throws InvalidDataTypeException
136
-     */
137
-    public static function deregister($module_id = null)
138
-    {
139
-        if (isset(self::$_settings[ $module_id ])) {
140
-            // set action for just this module id to delay deregistration until core is loaded and ready.
141
-            $module_settings = self::$_settings[ $module_id ];
142
-            unset(self::$_settings[ $module_id ]);
143
-            add_action(
144
-                'AHEE__EE_System__core_loaded_and_ready',
145
-                function () use ($module_settings) {
146
-                    $capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
147
-                    $capabilities->removeCaps(
148
-                        EE_Register_Payment_Method::getPaymentMethodCapabilities($module_settings)
149
-                    );
150
-                }
151
-            );
152
-        }
153
-    }
124
+	/**
125
+	 * This deregisters a module that was previously registered with a specific $module_id.
126
+	 *
127
+	 * @since    4.3.0
128
+	 *
129
+	 * @param string $module_id the name for the module that was previously registered
130
+	 * @return void
131
+	 * @throws DomainException
132
+	 * @throws EE_Error
133
+	 * @throws InvalidArgumentException
134
+	 * @throws InvalidInterfaceException
135
+	 * @throws InvalidDataTypeException
136
+	 */
137
+	public static function deregister($module_id = null)
138
+	{
139
+		if (isset(self::$_settings[ $module_id ])) {
140
+			// set action for just this module id to delay deregistration until core is loaded and ready.
141
+			$module_settings = self::$_settings[ $module_id ];
142
+			unset(self::$_settings[ $module_id ]);
143
+			add_action(
144
+				'AHEE__EE_System__core_loaded_and_ready',
145
+				function () use ($module_settings) {
146
+					$capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
147
+					$capabilities->removeCaps(
148
+						EE_Register_Payment_Method::getPaymentMethodCapabilities($module_settings)
149
+					);
150
+				}
151
+			);
152
+		}
153
+	}
154 154
 
155 155
 
156
-    /**
157
-     * returns an array of the caps that get added when a Payment Method is registered
158
-     *
159
-     * @param array $settings
160
-     * @return array
161
-     * @throws DomainException
162
-     * @throws EE_Error
163
-     * @throws InvalidArgumentException
164
-     * @throws InvalidInterfaceException
165
-     * @throws InvalidDataTypeException
166
-     * @access private  Developers do NOT use this method.  It's only public for PHP5.3 closure support (see deregister)
167
-     *                  When we drop support for PHP5.3 this will be made private again.  You have been warned.
168
-     *
169
-     */
170
-    public static function getPaymentMethodCapabilities(array $settings)
171
-    {
172
-        $payment_method_manager = LoaderFactory::getLoader()->getShared('EE_Payment_Method_Manager');
173
-        $payment_method_caps = array('administrator' => array());
174
-        if (isset($settings['payment_method_paths'])) {
175
-            foreach ($settings['payment_method_paths'] as $payment_method_path) {
176
-                $payment_method_caps = $payment_method_manager->addPaymentMethodCap(
177
-                    strtolower(basename($payment_method_path)),
178
-                    $payment_method_caps
179
-                );
180
-            }
181
-        }
182
-        return $payment_method_caps;
183
-    }
156
+	/**
157
+	 * returns an array of the caps that get added when a Payment Method is registered
158
+	 *
159
+	 * @param array $settings
160
+	 * @return array
161
+	 * @throws DomainException
162
+	 * @throws EE_Error
163
+	 * @throws InvalidArgumentException
164
+	 * @throws InvalidInterfaceException
165
+	 * @throws InvalidDataTypeException
166
+	 * @access private  Developers do NOT use this method.  It's only public for PHP5.3 closure support (see deregister)
167
+	 *                  When we drop support for PHP5.3 this will be made private again.  You have been warned.
168
+	 *
169
+	 */
170
+	public static function getPaymentMethodCapabilities(array $settings)
171
+	{
172
+		$payment_method_manager = LoaderFactory::getLoader()->getShared('EE_Payment_Method_Manager');
173
+		$payment_method_caps = array('administrator' => array());
174
+		if (isset($settings['payment_method_paths'])) {
175
+			foreach ($settings['payment_method_paths'] as $payment_method_path) {
176
+				$payment_method_caps = $payment_method_manager->addPaymentMethodCap(
177
+					strtolower(basename($payment_method_path)),
178
+					$payment_method_caps
179
+				);
180
+			}
181
+		}
182
+		return $payment_method_caps;
183
+	}
184 184
 }
Please login to merge, or discard this patch.
Spacing   +9 added lines, -9 removed lines patch added patch discarded remove patch
@@ -59,11 +59,11 @@  discard block
 block discarded – undo
59 59
             );
60 60
         }
61 61
         // make sure we don't register twice
62
-        if (isset(self::$_settings[ $payment_method_id ])) {
62
+        if (isset(self::$_settings[$payment_method_id])) {
63 63
             return;
64 64
         }
65 65
         // make sure this was called in the right place!
66
-        if (! did_action('AHEE__EE_System__load_espresso_addons')
66
+        if ( ! did_action('AHEE__EE_System__load_espresso_addons')
67 67
             || did_action('AHEE__EE_System__register_shortcodes_modules_and_widgets')
68 68
         ) {
69 69
             EE_Error::doing_it_wrong(
@@ -76,7 +76,7 @@  discard block
 block discarded – undo
76 76
             );
77 77
         }
78 78
         // setup $_settings array from incoming values.
79
-        self::$_settings[ $payment_method_id ] = array(
79
+        self::$_settings[$payment_method_id] = array(
80 80
             // array of full server paths to any EE_PMT_Base children used
81 81
             'payment_method_paths' => isset($setup_args['payment_method_paths'])
82 82
                 ? (array) $setup_args['payment_method_paths']
@@ -92,12 +92,12 @@  discard block
 block discarded – undo
92 92
         if (did_action('FHEE__EE_Payment_Method_Manager__register_payment_methods__registered_payment_methods')) {
93 93
             $payment_method_manager = LoaderFactory::getLoader()->getShared('EE_Payment_Method_Manager');
94 94
             // register payment methods directly
95
-            foreach (self::$_settings[ $payment_method_id ]['payment_method_paths'] as $payment_method_path) {
95
+            foreach (self::$_settings[$payment_method_id]['payment_method_paths'] as $payment_method_path) {
96 96
                 $payment_method_manager->register_payment_method($payment_method_path);
97 97
             }
98 98
             $capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
99 99
             $capabilities->addCaps(
100
-                self::getPaymentMethodCapabilities(self::$_settings[ $payment_method_id ])
100
+                self::getPaymentMethodCapabilities(self::$_settings[$payment_method_id])
101 101
             );
102 102
         }
103 103
     }
@@ -136,13 +136,13 @@  discard block
 block discarded – undo
136 136
      */
137 137
     public static function deregister($module_id = null)
138 138
     {
139
-        if (isset(self::$_settings[ $module_id ])) {
139
+        if (isset(self::$_settings[$module_id])) {
140 140
             // set action for just this module id to delay deregistration until core is loaded and ready.
141
-            $module_settings = self::$_settings[ $module_id ];
142
-            unset(self::$_settings[ $module_id ]);
141
+            $module_settings = self::$_settings[$module_id];
142
+            unset(self::$_settings[$module_id]);
143 143
             add_action(
144 144
                 'AHEE__EE_System__core_loaded_and_ready',
145
-                function () use ($module_settings) {
145
+                function() use ($module_settings) {
146 146
                     $capabilities = LoaderFactory::getLoader()->getShared('EE_Capabilities');
147 147
                     $capabilities->removeCaps(
148 148
                         EE_Register_Payment_Method::getPaymentMethodCapabilities($module_settings)
Please login to merge, or discard this patch.
core/libraries/plugin_api/EE_Register_Messages_Template_Pack.lib.php 2 patches
Indentation   +200 added lines, -200 removed lines patch added patch discarded remove patch
@@ -12,204 +12,204 @@
 block discarded – undo
12 12
 {
13 13
 
14 14
 
15
-    /**
16
-     * Holds values for registered template pack
17
-     *
18
-     * @since 4.5.0
19
-     *
20
-     * @var array
21
-     */
22
-    protected static $_registry = array();
23
-
24
-
25
-    /**
26
-     * Used to register a new template pack with the messages system.
27
-     *
28
-     * Template packs are primarily defined via class extending EE_Messages_Template_Pack and are typically used to
29
-     * change entire layouts for a set of message templates.  This method is used to register the new template pack and
30
-     * automatically have it loaded in the appropriate places.
31
-     *
32
-     * This registry also verifies that there isn't already a template pack registered with the same name and if there
33
-     * is then it will add an EE_Error notice.
34
-     *
35
-     * Note that this only handles registering the your Template Pack class with the message template pack system.
36
-     * However, there is also a naming schema you must follow for templates you are providing with your template pack.
37
-     *
38
-     * @see    EE_Messages_Template_Pack_Default for an example class
39
-     * @see    core/libraries/messages/defaults/default/* for all the example templates the default template pack
40
-     *         supports.
41
-     *
42
-     *
43
-     * @since  4.5.0
44
-     * @throws EE_Error
45
-     *
46
-     * @param string $ref        The internal reference used to refer to this template pack.  Note, this is first come,
47
-     *                           first serve.  If there is already a template pack registered with this name then the
48
-     *                           registry will assign a unique reference for it so it can still be activated (but this
49
-     *                           makes it harder to deregister as it will be unique per load - so its best to try to
50
-     *                           make this a unique string!)
51
-     * @param array  $setup_args array {
52
-     *                           An array of required values for registering the template pack.
53
-     * @type string  $path       The path for the new template pack class.
54
-     * @type string  $classname  The name of the new Template Pack Class.
55
-     *                           }
56
-     *
57
-     * @return void
58
-     */
59
-    public static function register($ref = null, $setup_args = array())
60
-    {
61
-
62
-        // check for required params
63
-        if (empty($ref) || empty($setup_args['path']) || empty($setup_args['classname'])) {
64
-            throw new EE_Error(
65
-                __(
66
-                    'In order to register a new template pack for the EE Messages system, you must include a value to reference the template pack being registered and the setup_args must have the path for the new template pack class as well as the classname for the new Template Pack Class. ',
67
-                    'event_espresso'
68
-                )
69
-            );
70
-        }
71
-
72
-        // make sure we don't register twice
73
-        if (isset(self::$_registry[ $ref ])) {
74
-            return;
75
-        }
76
-
77
-        // check that incoming $ref doesn't already exist. If it does then we'll create a unique reference for this template pack.
78
-        if (isset(self::$_registry[ $ref ])) {
79
-            $ref = uniqid() . '_' . $ref;
80
-        }
81
-
82
-
83
-        // make sure this was called in the right place!
84
-        if (! did_action('EE_Brewing_Regular___messages_caf')
85
-            || did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
86
-        ) {
87
-            EE_Error::doing_it_wrong(
88
-                __METHOD__,
89
-                sprintf(
90
-                    __(
91
-                        'A EE Messages Template Pack given the reference "%s" has been attempted to be registered with the EE Messages System.  It may or may not work because it should be only called on the "EE_Brewing_Regular__messages_caf" hook.',
92
-                        'event_espresso'
93
-                    ),
94
-                    $ref
95
-                ),
96
-                '4.5.0'
97
-            );
98
-        }
99
-
100
-        if (self::_verify_class_not_exist($setup_args['classname'])) {
101
-            self::$_registry[ $ref ] = array(
102
-                'path'      => (string) $setup_args['path'],
103
-                'classname' => (string) $setup_args['classname'],
104
-            );
105
-        }
106
-
107
-        // hook into the system
108
-        add_filter(
109
-            'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
110
-            array('EE_Register_Messages_Template_Pack', 'set_template_pack_path'),
111
-            10
112
-        );
113
-        add_filter(
114
-            'FHEE__EED_Messages__get_template_packs__template_packs',
115
-            array('EE_Register_Messages_Template_Pack', 'set_template_pack'),
116
-            10
117
-        );
118
-    }
119
-
120
-
121
-    /**
122
-     * Callback for the FHEE__EED_Messages___set_messages_paths___MSG_PATHS filter.  This adds this template packs path
123
-     * to the messages autoloader paths.
124
-     *
125
-     * @since  4.5.0
126
-     *
127
-     * @param array $paths Array of paths already registered with the messages autoloader
128
-     *
129
-     * @return array
130
-     */
131
-    public static function set_template_pack_path($paths)
132
-    {
133
-        foreach (self::$_registry as $ref => $args) {
134
-            $paths[] = $args['path'];
135
-        }
136
-        return $paths;
137
-    }
138
-
139
-
140
-    /**
141
-     * Callback for the FHEE__EED_Messages__get_template_packs__template_packs filter. This adds the instantiated,
142
-     * registered template pack to the template packs array when requested by client code.
143
-     *
144
-     * @since 4.5.0
145
-     *
146
-     * @param EE_Messages_Template_Pack[] $template_packs
147
-     * @return EE_Messages_Template_Pack[]
148
-     */
149
-    public static function set_template_pack($template_packs)
150
-    {
151
-        foreach (self::$_registry as $ref => $args) {
152
-            // verify class_exists
153
-            if (! class_exists($args['classname'])) {
154
-                require_once($args['path'] . '/' . $args['classname'] . '.class.php');
155
-            }
156
-
157
-            // check again!
158
-            if (class_exists($args['classname'])) {
159
-                $template_pack = new $args['classname'];
160
-                $template_packs[ $template_pack->dbref ] = $template_pack;
161
-            }
162
-        }
163
-
164
-        return $template_packs;
165
-    }
166
-
167
-
168
-    /**
169
-     * This verifies that the classes for each registered template pack are unique  names.
170
-     *
171
-     * @param string $classname The classname being checked
172
-     *
173
-     * @return bool
174
-     */
175
-    private static function _verify_class_not_exist($classname)
176
-    {
177
-
178
-        // loop through the existing registry and see if the classname is already present.
179
-        foreach (self::$_registry as $ref => $args) {
180
-            if ($args['classname'] == $classname) {
181
-                EE_Error::add_error(
182
-                    sprintf(
183
-                        __(
184
-                            'The %s template pack that you just activated cannot be registered with the messages system because there is already a template pack active using the same classname.  Contact the author of this template pack to let them know of the conflict.  To stop seeing this message you will need to deactivate this template pack.',
185
-                            'event_espresso'
186
-                        ),
187
-                        (string) $setup_args['classname']
188
-                    ),
189
-                    __FILE__,
190
-                    __LINE__,
191
-                    __FUNCTION__
192
-                );
193
-                return false;
194
-            }
195
-        }
196
-        return true;
197
-    }
198
-
199
-
200
-    /**
201
-     * This deregisters a variation set that was previously registered with the given slug.
202
-     *
203
-     * @since 4.5.0
204
-     *
205
-     * @param string $variation_ref The name for the variation set that was previously registered.
206
-     *
207
-     * @return void
208
-     */
209
-    public static function deregister($variation_ref = null)
210
-    {
211
-        if (! empty(self::$_registry[ $variation_ref ])) {
212
-            unset(self::$_registry[ $variation_ref ]);
213
-        }
214
-    }
15
+	/**
16
+	 * Holds values for registered template pack
17
+	 *
18
+	 * @since 4.5.0
19
+	 *
20
+	 * @var array
21
+	 */
22
+	protected static $_registry = array();
23
+
24
+
25
+	/**
26
+	 * Used to register a new template pack with the messages system.
27
+	 *
28
+	 * Template packs are primarily defined via class extending EE_Messages_Template_Pack and are typically used to
29
+	 * change entire layouts for a set of message templates.  This method is used to register the new template pack and
30
+	 * automatically have it loaded in the appropriate places.
31
+	 *
32
+	 * This registry also verifies that there isn't already a template pack registered with the same name and if there
33
+	 * is then it will add an EE_Error notice.
34
+	 *
35
+	 * Note that this only handles registering the your Template Pack class with the message template pack system.
36
+	 * However, there is also a naming schema you must follow for templates you are providing with your template pack.
37
+	 *
38
+	 * @see    EE_Messages_Template_Pack_Default for an example class
39
+	 * @see    core/libraries/messages/defaults/default/* for all the example templates the default template pack
40
+	 *         supports.
41
+	 *
42
+	 *
43
+	 * @since  4.5.0
44
+	 * @throws EE_Error
45
+	 *
46
+	 * @param string $ref        The internal reference used to refer to this template pack.  Note, this is first come,
47
+	 *                           first serve.  If there is already a template pack registered with this name then the
48
+	 *                           registry will assign a unique reference for it so it can still be activated (but this
49
+	 *                           makes it harder to deregister as it will be unique per load - so its best to try to
50
+	 *                           make this a unique string!)
51
+	 * @param array  $setup_args array {
52
+	 *                           An array of required values for registering the template pack.
53
+	 * @type string  $path       The path for the new template pack class.
54
+	 * @type string  $classname  The name of the new Template Pack Class.
55
+	 *                           }
56
+	 *
57
+	 * @return void
58
+	 */
59
+	public static function register($ref = null, $setup_args = array())
60
+	{
61
+
62
+		// check for required params
63
+		if (empty($ref) || empty($setup_args['path']) || empty($setup_args['classname'])) {
64
+			throw new EE_Error(
65
+				__(
66
+					'In order to register a new template pack for the EE Messages system, you must include a value to reference the template pack being registered and the setup_args must have the path for the new template pack class as well as the classname for the new Template Pack Class. ',
67
+					'event_espresso'
68
+				)
69
+			);
70
+		}
71
+
72
+		// make sure we don't register twice
73
+		if (isset(self::$_registry[ $ref ])) {
74
+			return;
75
+		}
76
+
77
+		// check that incoming $ref doesn't already exist. If it does then we'll create a unique reference for this template pack.
78
+		if (isset(self::$_registry[ $ref ])) {
79
+			$ref = uniqid() . '_' . $ref;
80
+		}
81
+
82
+
83
+		// make sure this was called in the right place!
84
+		if (! did_action('EE_Brewing_Regular___messages_caf')
85
+			|| did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
86
+		) {
87
+			EE_Error::doing_it_wrong(
88
+				__METHOD__,
89
+				sprintf(
90
+					__(
91
+						'A EE Messages Template Pack given the reference "%s" has been attempted to be registered with the EE Messages System.  It may or may not work because it should be only called on the "EE_Brewing_Regular__messages_caf" hook.',
92
+						'event_espresso'
93
+					),
94
+					$ref
95
+				),
96
+				'4.5.0'
97
+			);
98
+		}
99
+
100
+		if (self::_verify_class_not_exist($setup_args['classname'])) {
101
+			self::$_registry[ $ref ] = array(
102
+				'path'      => (string) $setup_args['path'],
103
+				'classname' => (string) $setup_args['classname'],
104
+			);
105
+		}
106
+
107
+		// hook into the system
108
+		add_filter(
109
+			'FHEE__EED_Messages___set_messages_paths___MSG_PATHS',
110
+			array('EE_Register_Messages_Template_Pack', 'set_template_pack_path'),
111
+			10
112
+		);
113
+		add_filter(
114
+			'FHEE__EED_Messages__get_template_packs__template_packs',
115
+			array('EE_Register_Messages_Template_Pack', 'set_template_pack'),
116
+			10
117
+		);
118
+	}
119
+
120
+
121
+	/**
122
+	 * Callback for the FHEE__EED_Messages___set_messages_paths___MSG_PATHS filter.  This adds this template packs path
123
+	 * to the messages autoloader paths.
124
+	 *
125
+	 * @since  4.5.0
126
+	 *
127
+	 * @param array $paths Array of paths already registered with the messages autoloader
128
+	 *
129
+	 * @return array
130
+	 */
131
+	public static function set_template_pack_path($paths)
132
+	{
133
+		foreach (self::$_registry as $ref => $args) {
134
+			$paths[] = $args['path'];
135
+		}
136
+		return $paths;
137
+	}
138
+
139
+
140
+	/**
141
+	 * Callback for the FHEE__EED_Messages__get_template_packs__template_packs filter. This adds the instantiated,
142
+	 * registered template pack to the template packs array when requested by client code.
143
+	 *
144
+	 * @since 4.5.0
145
+	 *
146
+	 * @param EE_Messages_Template_Pack[] $template_packs
147
+	 * @return EE_Messages_Template_Pack[]
148
+	 */
149
+	public static function set_template_pack($template_packs)
150
+	{
151
+		foreach (self::$_registry as $ref => $args) {
152
+			// verify class_exists
153
+			if (! class_exists($args['classname'])) {
154
+				require_once($args['path'] . '/' . $args['classname'] . '.class.php');
155
+			}
156
+
157
+			// check again!
158
+			if (class_exists($args['classname'])) {
159
+				$template_pack = new $args['classname'];
160
+				$template_packs[ $template_pack->dbref ] = $template_pack;
161
+			}
162
+		}
163
+
164
+		return $template_packs;
165
+	}
166
+
167
+
168
+	/**
169
+	 * This verifies that the classes for each registered template pack are unique  names.
170
+	 *
171
+	 * @param string $classname The classname being checked
172
+	 *
173
+	 * @return bool
174
+	 */
175
+	private static function _verify_class_not_exist($classname)
176
+	{
177
+
178
+		// loop through the existing registry and see if the classname is already present.
179
+		foreach (self::$_registry as $ref => $args) {
180
+			if ($args['classname'] == $classname) {
181
+				EE_Error::add_error(
182
+					sprintf(
183
+						__(
184
+							'The %s template pack that you just activated cannot be registered with the messages system because there is already a template pack active using the same classname.  Contact the author of this template pack to let them know of the conflict.  To stop seeing this message you will need to deactivate this template pack.',
185
+							'event_espresso'
186
+						),
187
+						(string) $setup_args['classname']
188
+					),
189
+					__FILE__,
190
+					__LINE__,
191
+					__FUNCTION__
192
+				);
193
+				return false;
194
+			}
195
+		}
196
+		return true;
197
+	}
198
+
199
+
200
+	/**
201
+	 * This deregisters a variation set that was previously registered with the given slug.
202
+	 *
203
+	 * @since 4.5.0
204
+	 *
205
+	 * @param string $variation_ref The name for the variation set that was previously registered.
206
+	 *
207
+	 * @return void
208
+	 */
209
+	public static function deregister($variation_ref = null)
210
+	{
211
+		if (! empty(self::$_registry[ $variation_ref ])) {
212
+			unset(self::$_registry[ $variation_ref ]);
213
+		}
214
+	}
215 215
 }
Please login to merge, or discard this patch.
Spacing   +10 added lines, -10 removed lines patch added patch discarded remove patch
@@ -70,18 +70,18 @@  discard block
 block discarded – undo
70 70
         }
71 71
 
72 72
         // make sure we don't register twice
73
-        if (isset(self::$_registry[ $ref ])) {
73
+        if (isset(self::$_registry[$ref])) {
74 74
             return;
75 75
         }
76 76
 
77 77
         // check that incoming $ref doesn't already exist. If it does then we'll create a unique reference for this template pack.
78
-        if (isset(self::$_registry[ $ref ])) {
79
-            $ref = uniqid() . '_' . $ref;
78
+        if (isset(self::$_registry[$ref])) {
79
+            $ref = uniqid().'_'.$ref;
80 80
         }
81 81
 
82 82
 
83 83
         // make sure this was called in the right place!
84
-        if (! did_action('EE_Brewing_Regular___messages_caf')
84
+        if ( ! did_action('EE_Brewing_Regular___messages_caf')
85 85
             || did_action('AHEE__EE_System__perform_activations_upgrades_and_migrations')
86 86
         ) {
87 87
             EE_Error::doing_it_wrong(
@@ -98,7 +98,7 @@  discard block
 block discarded – undo
98 98
         }
99 99
 
100 100
         if (self::_verify_class_not_exist($setup_args['classname'])) {
101
-            self::$_registry[ $ref ] = array(
101
+            self::$_registry[$ref] = array(
102 102
                 'path'      => (string) $setup_args['path'],
103 103
                 'classname' => (string) $setup_args['classname'],
104 104
             );
@@ -150,14 +150,14 @@  discard block
 block discarded – undo
150 150
     {
151 151
         foreach (self::$_registry as $ref => $args) {
152 152
             // verify class_exists
153
-            if (! class_exists($args['classname'])) {
154
-                require_once($args['path'] . '/' . $args['classname'] . '.class.php');
153
+            if ( ! class_exists($args['classname'])) {
154
+                require_once($args['path'].'/'.$args['classname'].'.class.php');
155 155
             }
156 156
 
157 157
             // check again!
158 158
             if (class_exists($args['classname'])) {
159 159
                 $template_pack = new $args['classname'];
160
-                $template_packs[ $template_pack->dbref ] = $template_pack;
160
+                $template_packs[$template_pack->dbref] = $template_pack;
161 161
             }
162 162
         }
163 163
 
@@ -208,8 +208,8 @@  discard block
 block discarded – undo
208 208
      */
209 209
     public static function deregister($variation_ref = null)
210 210
     {
211
-        if (! empty(self::$_registry[ $variation_ref ])) {
212
-            unset(self::$_registry[ $variation_ref ]);
211
+        if ( ! empty(self::$_registry[$variation_ref])) {
212
+            unset(self::$_registry[$variation_ref]);
213 213
         }
214 214
     }
215 215
 }
Please login to merge, or discard this patch.
core/libraries/messages/EE_Message_Generated_From_Token.php 2 patches
Indentation   +107 added lines, -107 removed lines patch added patch discarded remove patch
@@ -12,111 +12,111 @@
 block discarded – undo
12 12
 {
13 13
 
14 14
 
15
-    /**
16
-     * Sending messenger
17
-     *
18
-     * @type EE_messenger | string
19
-     */
20
-    protected $_sending_messenger = '';
21
-
22
-
23
-    /**
24
-     * Holds the incoming token;
25
-     * @type string
26
-     */
27
-    public $token = '';
28
-
29
-
30
-    /**
31
-     * Constructor
32
-     *
33
-     * @param   string    $sending_messenger_slug     This is used to set what messenger is used to "send"
34
-     *                                                the EE_Message retrieved from the DB via the given token.
35
-     * @param   string $token                         This is a token for a Message that should already exist int the db.
36
-     *                                                This is then used to populate the properties in here.
37
-     * @param   EE_Message_Resource_Manager $message_resource_manager
38
-     */
39
-    public function __construct($token, $sending_messenger_slug = 'html', EE_Message_Resource_Manager $message_resource_manager)
40
-    {
41
-        $this->token = $token;
42
-        $this->_sending_messenger = $this->_set_sending_messenger($sending_messenger_slug, $message_resource_manager);
43
-        $this->_message = $this->_generate_message();
44
-        // set params for parent from the message object
45
-        parent::__construct(
46
-            $this->_message->messenger(),
47
-            $this->_message->message_type(),
48
-            array(),
49
-            $this->_message->context(),
50
-            false
51
-        );
52
-    }
53
-
54
-
55
-
56
-    /**
57
-     * @param string                       $sending_messenger_slug
58
-     * @param \EE_Message_Resource_Manager $message_resource_manager
59
-     * @return \EE_messenger | string
60
-     */
61
-    protected function _set_sending_messenger(
62
-        $sending_messenger_slug,
63
-        EE_Message_Resource_Manager $message_resource_manager
64
-    ) {
65
-        $sending_messenger = $message_resource_manager->get_active_messenger($sending_messenger_slug);
66
-        return $sending_messenger instanceof EE_messenger ? $sending_messenger : $sending_messenger_slug;
67
-    }
68
-
69
-
70
-
71
-    /**
72
-     * @return EE_messenger
73
-     */
74
-    public function sending_messenger()
75
-    {
76
-        return $this->_sending_messenger;
77
-    }
78
-
79
-
80
-
81
-    /**
82
-     * generates an EE_Message using the supplied arguments and some defaults
83
-     *
84
-     * @param array $properties
85
-     * @return EE_Message
86
-     * @throws \EE_Error
87
-     */
88
-    protected function _generate_message($properties = array())
89
-    {
90
-        // a message was generated immediately but the parent class will call this again
91
-        if ($this->_message instanceof EE_Message) {
92
-            return $this->_message;
93
-        }
94
-        $message = EEM_Message::instance()->get_one_by_token($this->token);
95
-        if (! $message instanceof EE_Message) {
96
-            throw new EE_Error(
97
-                sprintf(
98
-                    __('Unable to retrieve generated message from DB using given token: "%1$s"', 'event_espresso'),
99
-                    $this->token
100
-                )
101
-            );
102
-        }
103
-        $message->set_STS_ID(EEM_Message::status_idle);
104
-
105
-        if (! $this->_sending_messenger instanceof EE_messenger) {
106
-            $message->set_STS_ID(EEM_Message::status_failed);
107
-            $message->set_error_message(
108
-                sprintf(
109
-                    __('Unable to send message because the "%1$s" messenger is not active or not installed', 'event_espresso'),
110
-                    $this->_sending_messenger
111
-                )
112
-            );
113
-        }
114
-
115
-        // set properties
116
-        $this->_valid = true;
117
-        $this->_messenger = $message->messenger_object();
118
-        $this->_message_type = $message->message_type_object();
119
-        $this->_send_now = $message->send_now();
120
-        return $message;
121
-    }
15
+	/**
16
+	 * Sending messenger
17
+	 *
18
+	 * @type EE_messenger | string
19
+	 */
20
+	protected $_sending_messenger = '';
21
+
22
+
23
+	/**
24
+	 * Holds the incoming token;
25
+	 * @type string
26
+	 */
27
+	public $token = '';
28
+
29
+
30
+	/**
31
+	 * Constructor
32
+	 *
33
+	 * @param   string    $sending_messenger_slug     This is used to set what messenger is used to "send"
34
+	 *                                                the EE_Message retrieved from the DB via the given token.
35
+	 * @param   string $token                         This is a token for a Message that should already exist int the db.
36
+	 *                                                This is then used to populate the properties in here.
37
+	 * @param   EE_Message_Resource_Manager $message_resource_manager
38
+	 */
39
+	public function __construct($token, $sending_messenger_slug = 'html', EE_Message_Resource_Manager $message_resource_manager)
40
+	{
41
+		$this->token = $token;
42
+		$this->_sending_messenger = $this->_set_sending_messenger($sending_messenger_slug, $message_resource_manager);
43
+		$this->_message = $this->_generate_message();
44
+		// set params for parent from the message object
45
+		parent::__construct(
46
+			$this->_message->messenger(),
47
+			$this->_message->message_type(),
48
+			array(),
49
+			$this->_message->context(),
50
+			false
51
+		);
52
+	}
53
+
54
+
55
+
56
+	/**
57
+	 * @param string                       $sending_messenger_slug
58
+	 * @param \EE_Message_Resource_Manager $message_resource_manager
59
+	 * @return \EE_messenger | string
60
+	 */
61
+	protected function _set_sending_messenger(
62
+		$sending_messenger_slug,
63
+		EE_Message_Resource_Manager $message_resource_manager
64
+	) {
65
+		$sending_messenger = $message_resource_manager->get_active_messenger($sending_messenger_slug);
66
+		return $sending_messenger instanceof EE_messenger ? $sending_messenger : $sending_messenger_slug;
67
+	}
68
+
69
+
70
+
71
+	/**
72
+	 * @return EE_messenger
73
+	 */
74
+	public function sending_messenger()
75
+	{
76
+		return $this->_sending_messenger;
77
+	}
78
+
79
+
80
+
81
+	/**
82
+	 * generates an EE_Message using the supplied arguments and some defaults
83
+	 *
84
+	 * @param array $properties
85
+	 * @return EE_Message
86
+	 * @throws \EE_Error
87
+	 */
88
+	protected function _generate_message($properties = array())
89
+	{
90
+		// a message was generated immediately but the parent class will call this again
91
+		if ($this->_message instanceof EE_Message) {
92
+			return $this->_message;
93
+		}
94
+		$message = EEM_Message::instance()->get_one_by_token($this->token);
95
+		if (! $message instanceof EE_Message) {
96
+			throw new EE_Error(
97
+				sprintf(
98
+					__('Unable to retrieve generated message from DB using given token: "%1$s"', 'event_espresso'),
99
+					$this->token
100
+				)
101
+			);
102
+		}
103
+		$message->set_STS_ID(EEM_Message::status_idle);
104
+
105
+		if (! $this->_sending_messenger instanceof EE_messenger) {
106
+			$message->set_STS_ID(EEM_Message::status_failed);
107
+			$message->set_error_message(
108
+				sprintf(
109
+					__('Unable to send message because the "%1$s" messenger is not active or not installed', 'event_espresso'),
110
+					$this->_sending_messenger
111
+				)
112
+			);
113
+		}
114
+
115
+		// set properties
116
+		$this->_valid = true;
117
+		$this->_messenger = $message->messenger_object();
118
+		$this->_message_type = $message->message_type_object();
119
+		$this->_send_now = $message->send_now();
120
+		return $message;
121
+	}
122 122
 }
Please login to merge, or discard this patch.
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -92,7 +92,7 @@  discard block
 block discarded – undo
92 92
             return $this->_message;
93 93
         }
94 94
         $message = EEM_Message::instance()->get_one_by_token($this->token);
95
-        if (! $message instanceof EE_Message) {
95
+        if ( ! $message instanceof EE_Message) {
96 96
             throw new EE_Error(
97 97
                 sprintf(
98 98
                     __('Unable to retrieve generated message from DB using given token: "%1$s"', 'event_espresso'),
@@ -102,7 +102,7 @@  discard block
 block discarded – undo
102 102
         }
103 103
         $message->set_STS_ID(EEM_Message::status_idle);
104 104
 
105
-        if (! $this->_sending_messenger instanceof EE_messenger) {
105
+        if ( ! $this->_sending_messenger instanceof EE_messenger) {
106 106
             $message->set_STS_ID(EEM_Message::status_failed);
107 107
             $message->set_error_message(
108 108
                 sprintf(
Please login to merge, or discard this patch.
core/libraries/messages/EE_Messages_Scheduler.lib.php 2 patches
Indentation   +194 added lines, -194 removed lines patch added patch discarded remove patch
@@ -11,198 +11,198 @@
 block discarded – undo
11 11
 class EE_Messages_Scheduler extends EE_Base
12 12
 {
13 13
 
14
-    /**
15
-     * Number of seconds between batch sends/generates on the cron job.
16
-     * Defaults to 5 minutes in seconds.  If you want to change this interval, you can use the native WordPress
17
-     * `cron_schedules` filter and modify the existing custom `ee_message_cron` schedule interval added.
18
-     *
19
-     * @type int
20
-     */
21
-    const message_cron_schedule = 300;
22
-
23
-    /**
24
-     * Constructor
25
-     */
26
-    public function __construct()
27
-    {
28
-        // register tasks (and make sure only registered once).
29
-        if (! has_action('FHEE__EEH_Activation__get_cron_tasks', array($this, 'register_scheduled_tasks'))) {
30
-            add_action('FHEE__EEH_Activation__get_cron_tasks', array($this, 'register_scheduled_tasks'), 10);
31
-        }
32
-
33
-        // register callbacks for scheduled events (but make sure they are set only once).
34
-        if (! has_action(
35
-            'AHEE__EE_Messages_Scheduler__generation',
36
-            array('EE_Messages_Scheduler', 'batch_generation')
37
-        )) {
38
-            add_action('AHEE__EE_Messages_Scheduler__generation', array('EE_Messages_Scheduler', 'batch_generation'));
39
-            add_action('AHEE__EE_Messages_Scheduler__sending', array('EE_Messages_Scheduler', 'batch_sending'));
40
-            add_action('AHEE__EE_Messages_Scheduler__cleanup', array('EE_Messages_Scheduler', 'cleanup'));
41
-        }
42
-
43
-        // add custom schedules
44
-        add_filter('cron_schedules', array($this, 'custom_schedules'));
45
-    }
46
-
47
-
48
-    /**
49
-     * Add custom schedules for wp_cron
50
-     *
51
-     * @param $schedules
52
-     */
53
-    public function custom_schedules($schedules)
54
-    {
55
-        $schedules['ee_message_cron'] = array(
56
-            'interval' => self::message_cron_schedule,
57
-            'display'  => __(
58
-                'This is the cron time interval for EE Message schedules (defaults to once every 5 minutes)',
59
-                'event_espresso'
60
-            ),
61
-        );
62
-        return $schedules;
63
-    }
64
-
65
-
66
-    /**
67
-     * Callback for FHEE__EEH_Activation__get_cron_tasks that is used to retrieve scheduled Cron events to add and
68
-     * remove.
69
-     *
70
-     * @param array $tasks already existing scheduled tasks
71
-     * @return array
72
-     */
73
-    public function register_scheduled_tasks($tasks)
74
-    {
75
-        EE_Registry::instance()->load_helper('DTT_Helper');
76
-        $tasks['AHEE__EE_Messages_Scheduler__generation'] = 'ee_message_cron';
77
-        $tasks['AHEE__EE_Messages_Scheduler__sending']    = 'ee_message_cron';
78
-        $tasks['AHEE__EE_Messages_Scheduler__cleanup'] = array( EEH_DTT_Helper::tomorrow(), 'daily');
79
-        return $tasks;
80
-    }
81
-
82
-
83
-    /**
84
-     * This initiates a non-blocking separate request to execute on a scheduled task.
85
-     * Note: The EED_Messages module has the handlers for these requests.
86
-     *
87
-     * @param string $task The task the request is being generated for.
88
-     */
89
-    public static function initiate_scheduled_non_blocking_request($task)
90
-    {
91
-        if (apply_filters(
92
-            'EE_Messages_Scheduler__initiate_scheduled_non_blocking_request__do_separate_request',
93
-            true
94
-        )) {
95
-            $request_url  = add_query_arg(
96
-                array_merge(
97
-                    array('ee' => 'msg_cron_trigger'),
98
-                    EE_Messages_Scheduler::get_request_params($task)
99
-                ),
100
-                site_url()
101
-            );
102
-            $request_args = array(
103
-                'timeout'     => 300,
104
-                'blocking'    => (defined('DOING_CRON') && DOING_CRON) || (defined('DOING_AJAX') && DOING_AJAX) ? true : false,
105
-                'sslverify'   => false,
106
-                'redirection' => 10,
107
-            );
108
-            $response     = wp_remote_get($request_url, $request_args);
109
-            if (is_wp_error($response)) {
110
-                trigger_error($response->get_error_message());
111
-            }
112
-        } else {
113
-            EE_Messages_Scheduler::initiate_immediate_request_on_cron($task);
114
-        }
115
-    }
116
-
117
-
118
-    /**
119
-     * This returns
120
-     * the request params used for a scheduled message task request.
121
-     *
122
-     * @param string $task The task the request is for.
123
-     * @return array
124
-     */
125
-    public static function get_request_params($task)
126
-    {
127
-        // transient is used for flood control on msg_cron_trigger requests
128
-        $transient_key = 'ee_trans_' . uniqid($task);
129
-        set_transient($transient_key, 1, 5 * MINUTE_IN_SECONDS);
130
-        return array(
131
-            'type' => $task,
132
-            'key'  => $transient_key,
133
-        );
134
-    }
135
-
136
-
137
-    /**
138
-     * This is used to execute an immediate call to the run_cron task performed by EED_Messages
139
-     *
140
-     * @param string $task The task the request is being generated for.
141
-     */
142
-    public static function initiate_immediate_request_on_cron($task)
143
-    {
144
-        $request_args = EE_Messages_Scheduler::get_request_params($task);
145
-        // set those request args in the request so it gets picked up
146
-        foreach ($request_args as $request_key => $request_value) {
147
-            EE_Registry::instance()->REQ->set($request_key, $request_value);
148
-        }
149
-        EED_Messages::instance()->run_cron();
150
-    }
151
-
152
-
153
-    /**
154
-     * Callback for scheduled AHEE__EE_Messages_Scheduler__generation wp cron event
155
-     */
156
-    public static function batch_generation()
157
-    {
158
-        /**
159
-         * @see filter usage in EE_Messages_Queue::initiate_request_by_priority()
160
-         */
161
-        if (! apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', false)
162
-            || ! EE_Registry::instance()->NET_CFG->core->do_messages_on_same_request
163
-        ) {
164
-            EE_Messages_Scheduler::initiate_immediate_request_on_cron('generate');
165
-        }
166
-    }
167
-
168
-
169
-    /**
170
-     * Callback for scheduled AHEE__EE_Messages_Scheduler__sending
171
-     */
172
-    public static function batch_sending()
173
-    {
174
-        /**
175
-         * @see filter usage in EE_Messages_Queue::initiate_request_by_priority()
176
-         */
177
-        if (! apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', false)
178
-            || ! EE_Registry::instance()->NET_CFG->core->do_messages_on_same_request
179
-        ) {
180
-            EE_Messages_Scheduler::initiate_immediate_request_on_cron('send');
181
-        }
182
-    }
183
-
184
-
185
-    /**
186
-     * This is the callback for the `AHEE__EE_Messages_Scheduler__cleanup` scheduled event action.
187
-     * This runs once a day and if cleanup is active (set via messages settings), it will (by default) delete permanently
188
-     * from the database messages that have a MSG_modified date older than 30 days.
189
-     */
190
-    public static function cleanup()
191
-    {
192
-        // first check if user has cleanup turned on or if we're in maintenance mode.  If in maintenance mode we'll wait
193
-        // until the next scheduled event.
194
-        if (! EE_Registry::instance()->CFG->messages->delete_threshold
195
-            || ! EE_Maintenance_Mode::instance()->models_can_query()
196
-        ) {
197
-            return;
198
-        }
199
-
200
-        /**
201
-         * This filter switch allows other code (such as the EE_Worker_Queue add-on) to replace this with its own handling
202
-         * of deleting messages.
203
-         */
204
-        if (apply_filters('FHEE__EE_Messages_Scheduler__cleanup__handle_cleanup_on_cron', true)) {
205
-            EEM_Message::instance()->delete_old_messages(EE_Registry::instance()->CFG->messages->delete_threshold);
206
-        }
207
-    }
14
+	/**
15
+	 * Number of seconds between batch sends/generates on the cron job.
16
+	 * Defaults to 5 minutes in seconds.  If you want to change this interval, you can use the native WordPress
17
+	 * `cron_schedules` filter and modify the existing custom `ee_message_cron` schedule interval added.
18
+	 *
19
+	 * @type int
20
+	 */
21
+	const message_cron_schedule = 300;
22
+
23
+	/**
24
+	 * Constructor
25
+	 */
26
+	public function __construct()
27
+	{
28
+		// register tasks (and make sure only registered once).
29
+		if (! has_action('FHEE__EEH_Activation__get_cron_tasks', array($this, 'register_scheduled_tasks'))) {
30
+			add_action('FHEE__EEH_Activation__get_cron_tasks', array($this, 'register_scheduled_tasks'), 10);
31
+		}
32
+
33
+		// register callbacks for scheduled events (but make sure they are set only once).
34
+		if (! has_action(
35
+			'AHEE__EE_Messages_Scheduler__generation',
36
+			array('EE_Messages_Scheduler', 'batch_generation')
37
+		)) {
38
+			add_action('AHEE__EE_Messages_Scheduler__generation', array('EE_Messages_Scheduler', 'batch_generation'));
39
+			add_action('AHEE__EE_Messages_Scheduler__sending', array('EE_Messages_Scheduler', 'batch_sending'));
40
+			add_action('AHEE__EE_Messages_Scheduler__cleanup', array('EE_Messages_Scheduler', 'cleanup'));
41
+		}
42
+
43
+		// add custom schedules
44
+		add_filter('cron_schedules', array($this, 'custom_schedules'));
45
+	}
46
+
47
+
48
+	/**
49
+	 * Add custom schedules for wp_cron
50
+	 *
51
+	 * @param $schedules
52
+	 */
53
+	public function custom_schedules($schedules)
54
+	{
55
+		$schedules['ee_message_cron'] = array(
56
+			'interval' => self::message_cron_schedule,
57
+			'display'  => __(
58
+				'This is the cron time interval for EE Message schedules (defaults to once every 5 minutes)',
59
+				'event_espresso'
60
+			),
61
+		);
62
+		return $schedules;
63
+	}
64
+
65
+
66
+	/**
67
+	 * Callback for FHEE__EEH_Activation__get_cron_tasks that is used to retrieve scheduled Cron events to add and
68
+	 * remove.
69
+	 *
70
+	 * @param array $tasks already existing scheduled tasks
71
+	 * @return array
72
+	 */
73
+	public function register_scheduled_tasks($tasks)
74
+	{
75
+		EE_Registry::instance()->load_helper('DTT_Helper');
76
+		$tasks['AHEE__EE_Messages_Scheduler__generation'] = 'ee_message_cron';
77
+		$tasks['AHEE__EE_Messages_Scheduler__sending']    = 'ee_message_cron';
78
+		$tasks['AHEE__EE_Messages_Scheduler__cleanup'] = array( EEH_DTT_Helper::tomorrow(), 'daily');
79
+		return $tasks;
80
+	}
81
+
82
+
83
+	/**
84
+	 * This initiates a non-blocking separate request to execute on a scheduled task.
85
+	 * Note: The EED_Messages module has the handlers for these requests.
86
+	 *
87
+	 * @param string $task The task the request is being generated for.
88
+	 */
89
+	public static function initiate_scheduled_non_blocking_request($task)
90
+	{
91
+		if (apply_filters(
92
+			'EE_Messages_Scheduler__initiate_scheduled_non_blocking_request__do_separate_request',
93
+			true
94
+		)) {
95
+			$request_url  = add_query_arg(
96
+				array_merge(
97
+					array('ee' => 'msg_cron_trigger'),
98
+					EE_Messages_Scheduler::get_request_params($task)
99
+				),
100
+				site_url()
101
+			);
102
+			$request_args = array(
103
+				'timeout'     => 300,
104
+				'blocking'    => (defined('DOING_CRON') && DOING_CRON) || (defined('DOING_AJAX') && DOING_AJAX) ? true : false,
105
+				'sslverify'   => false,
106
+				'redirection' => 10,
107
+			);
108
+			$response     = wp_remote_get($request_url, $request_args);
109
+			if (is_wp_error($response)) {
110
+				trigger_error($response->get_error_message());
111
+			}
112
+		} else {
113
+			EE_Messages_Scheduler::initiate_immediate_request_on_cron($task);
114
+		}
115
+	}
116
+
117
+
118
+	/**
119
+	 * This returns
120
+	 * the request params used for a scheduled message task request.
121
+	 *
122
+	 * @param string $task The task the request is for.
123
+	 * @return array
124
+	 */
125
+	public static function get_request_params($task)
126
+	{
127
+		// transient is used for flood control on msg_cron_trigger requests
128
+		$transient_key = 'ee_trans_' . uniqid($task);
129
+		set_transient($transient_key, 1, 5 * MINUTE_IN_SECONDS);
130
+		return array(
131
+			'type' => $task,
132
+			'key'  => $transient_key,
133
+		);
134
+	}
135
+
136
+
137
+	/**
138
+	 * This is used to execute an immediate call to the run_cron task performed by EED_Messages
139
+	 *
140
+	 * @param string $task The task the request is being generated for.
141
+	 */
142
+	public static function initiate_immediate_request_on_cron($task)
143
+	{
144
+		$request_args = EE_Messages_Scheduler::get_request_params($task);
145
+		// set those request args in the request so it gets picked up
146
+		foreach ($request_args as $request_key => $request_value) {
147
+			EE_Registry::instance()->REQ->set($request_key, $request_value);
148
+		}
149
+		EED_Messages::instance()->run_cron();
150
+	}
151
+
152
+
153
+	/**
154
+	 * Callback for scheduled AHEE__EE_Messages_Scheduler__generation wp cron event
155
+	 */
156
+	public static function batch_generation()
157
+	{
158
+		/**
159
+		 * @see filter usage in EE_Messages_Queue::initiate_request_by_priority()
160
+		 */
161
+		if (! apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', false)
162
+			|| ! EE_Registry::instance()->NET_CFG->core->do_messages_on_same_request
163
+		) {
164
+			EE_Messages_Scheduler::initiate_immediate_request_on_cron('generate');
165
+		}
166
+	}
167
+
168
+
169
+	/**
170
+	 * Callback for scheduled AHEE__EE_Messages_Scheduler__sending
171
+	 */
172
+	public static function batch_sending()
173
+	{
174
+		/**
175
+		 * @see filter usage in EE_Messages_Queue::initiate_request_by_priority()
176
+		 */
177
+		if (! apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', false)
178
+			|| ! EE_Registry::instance()->NET_CFG->core->do_messages_on_same_request
179
+		) {
180
+			EE_Messages_Scheduler::initiate_immediate_request_on_cron('send');
181
+		}
182
+	}
183
+
184
+
185
+	/**
186
+	 * This is the callback for the `AHEE__EE_Messages_Scheduler__cleanup` scheduled event action.
187
+	 * This runs once a day and if cleanup is active (set via messages settings), it will (by default) delete permanently
188
+	 * from the database messages that have a MSG_modified date older than 30 days.
189
+	 */
190
+	public static function cleanup()
191
+	{
192
+		// first check if user has cleanup turned on or if we're in maintenance mode.  If in maintenance mode we'll wait
193
+		// until the next scheduled event.
194
+		if (! EE_Registry::instance()->CFG->messages->delete_threshold
195
+			|| ! EE_Maintenance_Mode::instance()->models_can_query()
196
+		) {
197
+			return;
198
+		}
199
+
200
+		/**
201
+		 * This filter switch allows other code (such as the EE_Worker_Queue add-on) to replace this with its own handling
202
+		 * of deleting messages.
203
+		 */
204
+		if (apply_filters('FHEE__EE_Messages_Scheduler__cleanup__handle_cleanup_on_cron', true)) {
205
+			EEM_Message::instance()->delete_old_messages(EE_Registry::instance()->CFG->messages->delete_threshold);
206
+		}
207
+	}
208 208
 }
Please login to merge, or discard this patch.
Spacing   +9 added lines, -9 removed lines patch added patch discarded remove patch
@@ -26,12 +26,12 @@  discard block
 block discarded – undo
26 26
     public function __construct()
27 27
     {
28 28
         // register tasks (and make sure only registered once).
29
-        if (! has_action('FHEE__EEH_Activation__get_cron_tasks', array($this, 'register_scheduled_tasks'))) {
29
+        if ( ! has_action('FHEE__EEH_Activation__get_cron_tasks', array($this, 'register_scheduled_tasks'))) {
30 30
             add_action('FHEE__EEH_Activation__get_cron_tasks', array($this, 'register_scheduled_tasks'), 10);
31 31
         }
32 32
 
33 33
         // register callbacks for scheduled events (but make sure they are set only once).
34
-        if (! has_action(
34
+        if ( ! has_action(
35 35
             'AHEE__EE_Messages_Scheduler__generation',
36 36
             array('EE_Messages_Scheduler', 'batch_generation')
37 37
         )) {
@@ -75,7 +75,7 @@  discard block
 block discarded – undo
75 75
         EE_Registry::instance()->load_helper('DTT_Helper');
76 76
         $tasks['AHEE__EE_Messages_Scheduler__generation'] = 'ee_message_cron';
77 77
         $tasks['AHEE__EE_Messages_Scheduler__sending']    = 'ee_message_cron';
78
-        $tasks['AHEE__EE_Messages_Scheduler__cleanup'] = array( EEH_DTT_Helper::tomorrow(), 'daily');
78
+        $tasks['AHEE__EE_Messages_Scheduler__cleanup'] = array(EEH_DTT_Helper::tomorrow(), 'daily');
79 79
         return $tasks;
80 80
     }
81 81
 
@@ -92,7 +92,7 @@  discard block
 block discarded – undo
92 92
             'EE_Messages_Scheduler__initiate_scheduled_non_blocking_request__do_separate_request',
93 93
             true
94 94
         )) {
95
-            $request_url  = add_query_arg(
95
+            $request_url = add_query_arg(
96 96
                 array_merge(
97 97
                     array('ee' => 'msg_cron_trigger'),
98 98
                     EE_Messages_Scheduler::get_request_params($task)
@@ -105,7 +105,7 @@  discard block
 block discarded – undo
105 105
                 'sslverify'   => false,
106 106
                 'redirection' => 10,
107 107
             );
108
-            $response     = wp_remote_get($request_url, $request_args);
108
+            $response = wp_remote_get($request_url, $request_args);
109 109
             if (is_wp_error($response)) {
110 110
                 trigger_error($response->get_error_message());
111 111
             }
@@ -125,7 +125,7 @@  discard block
 block discarded – undo
125 125
     public static function get_request_params($task)
126 126
     {
127 127
         // transient is used for flood control on msg_cron_trigger requests
128
-        $transient_key = 'ee_trans_' . uniqid($task);
128
+        $transient_key = 'ee_trans_'.uniqid($task);
129 129
         set_transient($transient_key, 1, 5 * MINUTE_IN_SECONDS);
130 130
         return array(
131 131
             'type' => $task,
@@ -158,7 +158,7 @@  discard block
 block discarded – undo
158 158
         /**
159 159
          * @see filter usage in EE_Messages_Queue::initiate_request_by_priority()
160 160
          */
161
-        if (! apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', false)
161
+        if ( ! apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', false)
162 162
             || ! EE_Registry::instance()->NET_CFG->core->do_messages_on_same_request
163 163
         ) {
164 164
             EE_Messages_Scheduler::initiate_immediate_request_on_cron('generate');
@@ -174,7 +174,7 @@  discard block
 block discarded – undo
174 174
         /**
175 175
          * @see filter usage in EE_Messages_Queue::initiate_request_by_priority()
176 176
          */
177
-        if (! apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', false)
177
+        if ( ! apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', false)
178 178
             || ! EE_Registry::instance()->NET_CFG->core->do_messages_on_same_request
179 179
         ) {
180 180
             EE_Messages_Scheduler::initiate_immediate_request_on_cron('send');
@@ -191,7 +191,7 @@  discard block
 block discarded – undo
191 191
     {
192 192
         // first check if user has cleanup turned on or if we're in maintenance mode.  If in maintenance mode we'll wait
193 193
         // until the next scheduled event.
194
-        if (! EE_Registry::instance()->CFG->messages->delete_threshold
194
+        if ( ! EE_Registry::instance()->CFG->messages->delete_threshold
195 195
             || ! EE_Maintenance_Mode::instance()->models_can_query()
196 196
         ) {
197 197
             return;
Please login to merge, or discard this patch.