1 | <?php |
||
7 | class Jetpack_Sync_Defaults { |
||
8 | |||
9 | static $default_options_whitelist = array( |
||
|
|||
10 | 'stylesheet', |
||
11 | 'blogname', |
||
12 | 'blogdescription', |
||
13 | 'blog_charset', |
||
14 | 'permalink_structure', |
||
15 | 'category_base', |
||
16 | 'tag_base', |
||
17 | 'sidebars_widgets', |
||
18 | 'comment_moderation', |
||
19 | 'default_comment_status', |
||
20 | 'page_on_front', |
||
21 | 'rss_use_excerpt', |
||
22 | 'subscription_options', |
||
23 | 'stb_enabled', |
||
24 | 'stc_enabled', |
||
25 | 'comment_registration', |
||
26 | 'show_avatars', |
||
27 | 'avatar_default', |
||
28 | 'avatar_rating', |
||
29 | 'highlander_comment_form_prompt', |
||
30 | 'jetpack_comment_form_color_scheme', |
||
31 | 'stats_options', |
||
32 | 'gmt_offset', |
||
33 | 'timezone_string', |
||
34 | 'jetpack_sync_non_public_post_stati', |
||
35 | 'jetpack_options', |
||
36 | 'site_icon', // (int) - ID of core's Site Icon attachment ID |
||
37 | 'default_post_format', |
||
38 | 'default_category', |
||
39 | 'large_size_w', |
||
40 | 'large_size_h', |
||
41 | 'thumbnail_size_w', |
||
42 | 'thumbnail_size_h', |
||
43 | 'medium_size_w', |
||
44 | 'medium_size_h', |
||
45 | 'thumbnail_crop', |
||
46 | 'image_default_link_type', |
||
47 | 'site_logo', |
||
48 | 'sharing-options', |
||
49 | 'sharing-services', |
||
50 | 'post_count', |
||
51 | 'default_ping_status', |
||
52 | 'sticky_posts', |
||
53 | 'blog_public', |
||
54 | 'default_pingback_flag', |
||
55 | 'require_name_email', |
||
56 | 'close_comments_for_old_posts', |
||
57 | 'close_comments_days_old', |
||
58 | 'thread_comments', |
||
59 | 'thread_comments_depth', |
||
60 | 'page_comments', |
||
61 | 'comments_per_page', |
||
62 | 'default_comments_page', |
||
63 | 'comment_order', |
||
64 | 'comments_notify', |
||
65 | 'moderation_notify', |
||
66 | 'social_notifications_like', |
||
67 | 'social_notifications_reblog', |
||
68 | 'social_notifications_subscribe', |
||
69 | 'comment_whitelist', |
||
70 | 'comment_max_links', |
||
71 | 'moderation_keys', |
||
72 | 'jetpack_wga', |
||
73 | 'disabled_likes', |
||
74 | 'disabled_reblogs', |
||
75 | 'jetpack_comment_likes_enabled', |
||
76 | 'twitter_via', |
||
77 | 'jetpack-twitter-cards-site-tag', |
||
78 | 'wpcom_publish_posts_with_markdown', |
||
79 | 'wpcom_publish_comments_with_markdown', |
||
80 | 'jetpack_activated', |
||
81 | 'jetpack_available_modules', |
||
82 | 'jetpack_autoupdate_plugins', |
||
83 | 'jetpack_autoupdate_plugins_translations', |
||
84 | 'jetpack_autoupdate_themes', |
||
85 | 'jetpack_autoupdate_themes_translations', |
||
86 | 'jetpack_autoupdate_core', |
||
87 | 'jetpack_autoupdate_translations', |
||
88 | 'carousel_background_color', |
||
89 | 'carousel_display_exif', |
||
90 | 'jetpack_portfolio', |
||
91 | 'jetpack_portfolio_posts_per_page', |
||
92 | 'jetpack_testimonial', |
||
93 | 'jetpack_testimonial_posts_per_page', |
||
94 | 'tiled_galleries', |
||
95 | 'gravatar_disable_hovercards', |
||
96 | 'infinite_scroll', |
||
97 | 'infinite_scroll_google_analytics', |
||
98 | 'wp_mobile_excerpt', |
||
99 | 'wp_mobile_featured_images', |
||
100 | 'wp_mobile_app_promos', |
||
101 | 'monitor_receive_notifications', |
||
102 | 'post_by_email_address', |
||
103 | 'jetpack_protect_key', |
||
104 | 'jetpack_protect_global_whitelist', |
||
105 | 'jetpack_sso_require_two_step', |
||
106 | 'jetpack_relatedposts', |
||
107 | 'verification_services_codes', |
||
108 | 'users_can_register', |
||
109 | 'active_plugins', |
||
110 | 'uninstall_plugins', |
||
111 | 'advanced_seo_front_page_description', // Jetpack_SEO_Utils::FRONT_PAGE_META_OPTION |
||
112 | 'advanced_seo_title_formats', // Jetpack_SEO_Titles::TITLE_FORMATS_OPTION |
||
113 | 'jetpack_api_cache_enabled', |
||
114 | ); |
||
115 | |||
116 | public static function get_options_whitelist() { |
||
130 | |||
131 | static $default_constants_whitelist = array( |
||
132 | 'EMPTY_TRASH_DAYS', |
||
133 | 'WP_POST_REVISIONS', |
||
134 | 'AUTOMATIC_UPDATER_DISABLED', |
||
135 | 'ABSPATH', |
||
136 | 'WP_CONTENT_DIR', |
||
137 | 'FS_METHOD', |
||
138 | 'DISALLOW_FILE_EDIT', |
||
139 | 'DISALLOW_FILE_MODS', |
||
140 | 'WP_AUTO_UPDATE_CORE', |
||
141 | 'WP_HTTP_BLOCK_EXTERNAL', |
||
142 | 'WP_ACCESSIBLE_HOSTS', |
||
143 | 'JETPACK__VERSION', |
||
144 | 'IS_PRESSABLE', |
||
145 | 'DISABLE_WP_CRON', |
||
146 | 'ALTERNATE_WP_CRON', |
||
147 | 'WP_CRON_LOCK_TIMEOUT', |
||
148 | 'PHP_VERSION', |
||
149 | 'WP_MEMORY_LIMIT', |
||
150 | 'WP_MAX_MEMORY_LIMIT' |
||
151 | ); |
||
152 | |||
153 | public static function get_constants_whitelist() { |
||
165 | |||
166 | static $default_callable_whitelist = array( |
||
167 | 'wp_max_upload_size' => 'wp_max_upload_size', |
||
168 | 'is_main_network' => array( 'Jetpack', 'is_multi_network' ), |
||
169 | 'is_multi_site' => 'is_multisite', |
||
170 | 'main_network_site' => array( 'Jetpack_Sync_Functions', 'main_network_site_url' ), |
||
171 | 'site_url' => array( 'Jetpack_Sync_Functions', 'site_url' ), |
||
172 | 'home_url' => array( 'Jetpack_Sync_Functions', 'home_url' ), |
||
173 | 'single_user_site' => array( 'Jetpack', 'is_single_user_site' ), |
||
174 | 'updates' => array( 'Jetpack', 'get_updates' ), |
||
175 | 'has_file_system_write_access' => array( 'Jetpack_Sync_Functions', 'file_system_write_access' ), |
||
176 | 'is_version_controlled' => array( 'Jetpack_Sync_Functions', 'is_version_controlled' ), |
||
177 | 'taxonomies' => array( 'Jetpack_Sync_Functions', 'get_taxonomies' ), |
||
178 | 'post_types' => array( 'Jetpack_Sync_Functions', 'get_post_types' ), |
||
179 | 'post_type_features' => array( 'Jetpack_Sync_Functions', 'get_post_type_features' ), |
||
180 | 'shortcodes' => array( 'Jetpack_Sync_Functions', 'get_shortcodes' ), |
||
181 | 'rest_api_allowed_post_types' => array( 'Jetpack_Sync_Functions', 'rest_api_allowed_post_types' ), |
||
182 | 'rest_api_allowed_public_metadata' => array( 'Jetpack_Sync_Functions', 'rest_api_allowed_public_metadata' ), |
||
183 | 'sso_is_two_step_required' => array( 'Jetpack_SSO_Helpers', 'is_two_step_required' ), |
||
184 | 'sso_should_hide_login_form' => array( 'Jetpack_SSO_Helpers', 'should_hide_login_form' ), |
||
185 | 'sso_match_by_email' => array( 'Jetpack_SSO_Helpers', 'match_by_email' ), |
||
186 | 'sso_new_user_override' => array( 'Jetpack_SSO_Helpers', 'new_user_override' ), |
||
187 | 'sso_bypass_default_login_form' => array( 'Jetpack_SSO_Helpers', 'bypass_login_forward_wpcom' ), |
||
188 | 'wp_version' => array( 'Jetpack_Sync_Functions', 'wp_version' ), |
||
189 | 'get_plugins' => array( 'Jetpack_Sync_Functions', 'get_plugins' ), |
||
190 | 'get_plugins_action_links' => array( 'Jetpack_Sync_functions', 'get_plugins_action_links' ), |
||
191 | 'active_modules' => array( 'Jetpack', 'get_active_modules' ), |
||
192 | 'hosting_provider' => array( 'Jetpack_Sync_Functions', 'get_hosting_provider' ), |
||
193 | 'locale' => 'get_locale', |
||
194 | 'site_icon_url' => array( 'Jetpack_Sync_Functions', 'site_icon_url' ), |
||
195 | 'roles' => array( 'Jetpack_Sync_Functions', 'roles' ), |
||
196 | ); |
||
197 | |||
198 | public static function get_callable_whitelist() { |
||
210 | |||
211 | static $blacklisted_post_types = array( |
||
212 | 'ai1ec_event', |
||
213 | 'bwg_album', |
||
214 | 'bwg_gallery', |
||
215 | 'customize_changeset', // WP built-in post type for Customizer changesets |
||
216 | 'dn_wp_yt_log', |
||
217 | 'http', |
||
218 | 'idx_page', |
||
219 | 'jetpack_migration', |
||
220 | 'postman_sent_mail', |
||
221 | 'rssap-feed', |
||
222 | 'rssmi_feed_item', |
||
223 | 'secupress_log_action', |
||
224 | 'sg_optimizer_jobs', |
||
225 | 'snitch', |
||
226 | 'wpephpcompat_jobs', |
||
227 | 'wprss_feed_item', |
||
228 | 'wp_automatic', |
||
229 | ); |
||
230 | |||
231 | static $default_post_checksum_columns = array( |
||
232 | 'ID', |
||
233 | 'post_modified', |
||
234 | ); |
||
235 | |||
236 | static $default_post_meta_checksum_columns = array( |
||
237 | 'meta_id', |
||
238 | 'meta_value' |
||
239 | ); |
||
240 | |||
241 | static $default_comment_checksum_columns = array( |
||
242 | 'comment_ID', |
||
243 | 'comment_content', |
||
244 | ); |
||
245 | |||
246 | static $default_comment_meta_checksum_columns = array( |
||
247 | 'meta_id', |
||
248 | 'meta_value' |
||
249 | ); |
||
250 | |||
251 | static $default_option_checksum_columns = array( |
||
252 | 'option_name', |
||
253 | 'option_value', |
||
254 | ); |
||
255 | |||
256 | static $default_multisite_callable_whitelist = array( |
||
257 | 'network_name' => array( 'Jetpack', 'network_name' ), |
||
258 | 'network_allow_new_registrations' => array( 'Jetpack', 'network_allow_new_registrations' ), |
||
259 | 'network_add_new_users' => array( 'Jetpack', 'network_add_new_users' ), |
||
260 | 'network_site_upload_space' => array( 'Jetpack', 'network_site_upload_space' ), |
||
261 | 'network_upload_file_types' => array( 'Jetpack', 'network_upload_file_types' ), |
||
262 | 'network_enable_administration_menus' => array( 'Jetpack', 'network_enable_administration_menus' ), |
||
263 | ); |
||
264 | |||
265 | public static function get_multisite_callable_whitelist() { |
||
266 | /** |
||
267 | * Filter the list of multisite callables that are manageable via the JSON API. |
||
268 | * |
||
269 | * @module sync |
||
270 | * |
||
271 | * @since 4.8 |
||
272 | * |
||
273 | * @param array The default list of multisite callables. |
||
274 | */ |
||
275 | return apply_filters( 'jetpack_sync_multisite_callable_whitelist', self::$default_multisite_callable_whitelist ); |
||
276 | } |
||
277 | |||
278 | static $post_meta_whitelist = array( |
||
279 | '_feedback_akismet_values', |
||
280 | '_feedback_email', |
||
281 | '_feedback_extra_fields', |
||
282 | '_g_feedback_shortcode', |
||
283 | '_jetpack_post_thumbnail', |
||
284 | '_menu_item_classes', |
||
285 | '_menu_item_menu_item_parent', |
||
286 | '_menu_item_object', |
||
287 | '_menu_item_object_id', |
||
288 | '_menu_item_orphaned', |
||
289 | '_menu_item_type', |
||
290 | '_menu_item_xfn', |
||
291 | '_publicize_facebook_user', |
||
292 | '_publicize_twitter_user', |
||
293 | '_thumbnail_id', |
||
294 | '_wp_attached_file', |
||
295 | '_wp_attachment_backup_sizes', |
||
296 | '_wp_attachment_context', |
||
297 | '_wp_attachment_image_alt', |
||
298 | '_wp_attachment_is_custom_background', |
||
299 | '_wp_attachment_is_custom_header', |
||
300 | '_wp_attachment_metadata', |
||
301 | '_wp_page_template', |
||
302 | '_wp_trash_meta_comments_status', |
||
303 | '_wpas_mess', |
||
304 | 'content_width', |
||
305 | 'custom_css_add', |
||
306 | 'custom_css_preprocessor', |
||
307 | 'enclosure', |
||
308 | 'imagedata', |
||
309 | 'nova_price', |
||
310 | 'publicize_results', |
||
311 | 'sharing_disabled', |
||
312 | 'switch_like_status', |
||
313 | 'videopress_guid', |
||
314 | 'vimeo_poster_image', |
||
315 | 'advanced_seo_description', // Jetpack_SEO_Posts::DESCRIPTION_META_KEY |
||
316 | ); |
||
317 | |||
318 | public static function get_post_meta_whitelist() { |
||
319 | /** |
||
320 | * Filter the list of post meta data that are manageable via the JSON API. |
||
321 | * |
||
322 | * @module sync |
||
323 | * |
||
324 | * @since 4.8 |
||
325 | * |
||
326 | * @param array The default list of meta data keys. |
||
327 | */ |
||
328 | return apply_filters( 'jetpack_sync_post_meta_whitelist', self::$post_meta_whitelist ); |
||
329 | } |
||
330 | |||
331 | static $comment_meta_whitelist = array( |
||
332 | 'hc_avatar', |
||
333 | 'hc_post_as', |
||
334 | 'hc_wpcom_id_sig', |
||
335 | 'hc_foreign_user_id' |
||
336 | ); |
||
337 | |||
338 | public static function get_comment_meta_whitelist() { |
||
339 | /** |
||
340 | * Filter the list of comment meta data that are manageable via the JSON API. |
||
341 | * |
||
342 | * @module sync |
||
343 | * |
||
344 | * @since 5.7.0 |
||
345 | * |
||
346 | * @param array The default list of comment meta data keys. |
||
347 | */ |
||
348 | return apply_filters( 'jetpack_sync_comment_meta_whitelist', self::$comment_meta_whitelist ); |
||
349 | } |
||
350 | |||
351 | // TODO: move this to server? - these are theme support values |
||
352 | // that should be synced as jetpack_current_theme_supports_foo option values |
||
353 | static $default_theme_support_whitelist = array( |
||
354 | 'post-thumbnails', |
||
355 | 'post-formats', |
||
356 | 'custom-header', |
||
357 | 'custom-background', |
||
358 | 'custom-logo', |
||
359 | 'menus', |
||
360 | 'automatic-feed-links', |
||
361 | 'editor-style', |
||
362 | 'widgets', |
||
363 | 'html5', |
||
364 | 'title-tag', |
||
365 | 'jetpack-social-menu', |
||
366 | 'jetpack-responsive-videos', |
||
367 | 'infinite-scroll', |
||
368 | 'site-logo', |
||
369 | ); |
||
370 | |||
371 | static function is_whitelisted_option( $option ) { |
||
382 | |||
383 | static $default_capabilities_whitelist = array( |
||
384 | 'switch_themes', |
||
385 | 'edit_themes', |
||
386 | 'edit_theme_options', |
||
387 | 'install_themes', |
||
388 | 'activate_plugins', |
||
389 | 'edit_plugins', |
||
390 | 'install_plugins', |
||
391 | 'edit_users', |
||
392 | 'edit_files', |
||
393 | 'manage_options', |
||
394 | 'moderate_comments', |
||
395 | 'manage_categories', |
||
396 | 'manage_links', |
||
397 | 'upload_files', |
||
398 | 'import', |
||
399 | 'unfiltered_html', |
||
400 | 'edit_posts', |
||
401 | 'edit_others_posts', |
||
402 | 'edit_published_posts', |
||
403 | 'publish_posts', |
||
404 | 'edit_pages', |
||
405 | 'read', |
||
406 | 'publish_pages', |
||
407 | 'edit_others_pages', |
||
408 | 'edit_published_pages', |
||
409 | 'delete_pages', |
||
410 | 'delete_others_pages', |
||
411 | 'delete_published_pages', |
||
412 | 'delete_posts', |
||
413 | 'delete_others_posts', |
||
414 | 'delete_published_posts', |
||
415 | 'delete_private_posts', |
||
416 | 'edit_private_posts', |
||
417 | 'read_private_posts', |
||
418 | 'delete_private_pages', |
||
419 | 'edit_private_pages', |
||
420 | 'read_private_pages', |
||
421 | 'delete_users', |
||
422 | 'create_users', |
||
423 | 'unfiltered_upload', |
||
424 | 'edit_dashboard', |
||
425 | 'customize', |
||
426 | 'delete_site', |
||
427 | 'update_plugins', |
||
428 | 'delete_plugins', |
||
429 | 'update_themes', |
||
430 | 'update_core', |
||
431 | 'list_users', |
||
432 | 'remove_users', |
||
433 | 'add_users', |
||
434 | 'promote_users', |
||
435 | 'delete_themes', |
||
436 | 'export', |
||
437 | 'edit_comment', |
||
438 | 'upload_plugins', |
||
439 | 'upload_themes', |
||
440 | ); |
||
441 | |||
442 | public static function get_capabilities_whitelist() { |
||
454 | |||
455 | static function get_max_sync_execution_time() { |
||
463 | |||
464 | static $default_network_options_whitelist = array( |
||
465 | 'site_name', |
||
466 | 'jetpack_protect_key', |
||
467 | 'jetpack_protect_global_whitelist', |
||
468 | 'active_sitewide_plugins', |
||
469 | ); |
||
470 | |||
471 | static $default_taxonomy_whitelist = array(); |
||
472 | static $default_dequeue_max_bytes = 500000; // very conservative value, 1/2 MB |
||
473 | static $default_upload_max_bytes = 600000; // a little bigger than the upload limit to account for serialization |
||
474 | static $default_upload_max_rows = 500; |
||
475 | static $default_sync_wait_time = 10; // seconds, between syncs |
||
476 | static $default_sync_wait_threshold = 5; // only wait before next send if the current send took more than X seconds |
||
477 | static $default_enqueue_wait_time = 10; // wait between attempting to continue a full sync, via requests |
||
478 | static $default_max_queue_size = 1000; |
||
479 | static $default_max_queue_lag = 900; // 15 minutes |
||
480 | static $default_queue_max_writes_sec = 100; // 100 rows a second |
||
481 | static $default_post_types_blacklist = array(); |
||
482 | static $default_post_meta_whitelist = array(); |
||
483 | static $default_comment_meta_whitelist = array(); |
||
484 | static $default_disable = 0; // completely disable sending data to wpcom |
||
485 | static $default_sync_via_cron = 1; // use cron to sync |
||
486 | static $default_render_filtered_content = 0; // render post_filtered_content |
||
487 | static $default_max_enqueue_full_sync = 100; // max number of items to enqueue at a time when running full sync |
||
488 | static $default_max_queue_size_full_sync = 1000; // max number of total items in the full sync queue |
||
489 | static $default_sync_callables_wait_time = MINUTE_IN_SECONDS; // seconds before sending callables again |
||
490 | static $default_sync_constants_wait_time = HOUR_IN_SECONDS; // seconds before sending constants again |
||
491 | static $default_sync_queue_lock_timeout = 120; // 2 minutes |
||
492 | static $default_cron_sync_time_limit = 30; // 30 seconds |
||
493 | } |
||
494 |
The PSR-2 coding standard requires that all properties in a class have their visibility explicitly declared. If you declare a property using
the property is implicitly global.
To learn more about the PSR-2, please see the PHP-FIG site on the PSR-2.