Opened 6 years ago
Closed 5 years ago
#45484 closed defect (bug) (fixed)
starter content theme_mods/options throw php warning if not string
Reported by: | timph | Owned by: | SergeyBiryukov |
---|---|---|---|
Milestone: | 5.3 | Priority: | normal |
Severity: | normal | Version: | 4.7 |
Component: | Customize | Keywords: | has-patch needs-testing |
Focuses: | Cc: |
Description
theme_mods/options can be mixed:
https://developer.wordpress.org/reference/functions/set_theme_mod/
https://developer.wordpress.org/reference/functions/update_option/
When the starter content is checking for the post symbols in theme_mods/options it does a preg_match on the value, which throws PHP warnings:
In the very least it would be nice if core could check if is_array. Better would be a more comprehensive check based on types, to attempt to extract the post symbols for the many types of theme_mods/options that people set.
Attachments (2)
Change History (19)
#3
@
6 years ago
- Keywords reporter-feedback removed
Sure @SergeyBiryukov - if you add this to twenty-ninteen's functions.php file:
add_theme_support( 'starter-content', [
'theme_mods' => [
'testing' => [ 1, 2, 3 ],
],
] );
It results in: [21-Mar-2019 22:59:12 UTC] PHP Warning: preg_match() expects parameter 2 to be string, array given in /srv/www/wordpress-default/public_html/wp-includes/class-wp-customize-manager.php on line 1548
#4
@
6 years ago
- Keywords has-patch needs-testing added; needs-patch removed
Patch can be tested by adding this code to twenty-nineteen's functions.php:
add_action( 'after_setup_theme', 'add_testing_theme_support' ); add_action( 'customize_register', 'add_testing_customizer_settings' ); function add_testing_theme_support() { add_theme_support( 'starter-content', [ 'attachments' => [ 'test' => [ 'post_title' => 'testing for post ID', 'file' => 'screenshot.png', ], ], 'theme_mods' => [ 'testing' => [ 1, '{{test}}', 3 ], 'testing_string' => '{{test}}', ], 'options' => [ 'testing' => [ 1, 2, '{{test}}' ], ], ] ); } function add_testing_customizer_settings( $wp_customize ) { $wp_customize->add_setting( 'testing' , [ 'default' => 0, 'transport' => 'postMessage', ] ); $wp_customize->add_setting( 'testing_string' , [ 'default' => '', 'transport' => 'postMessage', ] ); }
If you're not using a fresh_site install, you will need to manually force that state, you can add this to the same functions.php file:
update_option( 'fresh_site', 1 );
Now go into the customizer, and you will get PHP warning for not being able to preg_match on the values passed as they are arrays, like these:
[22-Mar-2019 03:25:50 UTC] PHP Warning: preg_match() expects parameter 2 to be string, array given in /srv/www/wordpress-default/public_html/wp-includes/class-wp-customize-manager.php on line 1526 [22-Mar-2019 03:25:50 UTC] PHP Warning: preg_match() expects parameter 2 to be string, array given in /srv/www/wordpress-default/public_html/wp-includes/class-wp-customize-manager.php on line 1544
Now apply patch, and follow the same steps. You should no longer receive PHP warnings.
From the browser console, you can verify the correct value is set in the array for the theme_mod using the customizer js api:
wp.customize( 'testing' )();
The code for options vs theme_mods is pretty much identical, so it could probably be consolidated if necessary.
The patch does the following steps for theme_mods and options:
- serialize value with maybe_serialize()
- check for post symbol matches on strings.
- replace these strings with post ID ints.
- unserialize value with maybe_unserialize() so values can be properly used.
This ticket was mentioned in Slack in #core-customize by tim. View the logs.
6 years ago
This ticket was mentioned in Slack in #themereview by tim. View the logs.
5 years ago
This ticket was mentioned in Slack in #core by joyously. View the logs.
5 years ago
#8
@
5 years ago
- Milestone changed from Awaiting Review to 5.3
- Owner set to SergeyBiryukov
- Status changed from new to reviewing
This ticket was mentioned in Slack in #themereview by tim. View the logs.
5 years ago
This ticket was mentioned in Slack in #core by joyously. View the logs.
5 years ago
This ticket was mentioned in Slack in #core by marybaum. View the logs.
5 years ago
This ticket was mentioned in Slack in #themereview by joyously. View the logs.
5 years ago
#14
@
5 years ago
In terms of testing this, I have tested various theme mods which had values serialized in this step, and the post symbols have all been able to be successfully updated. In doing testing, the values which were strings also still are functional as they were before this patch and testing. This has been a pretty big barrier for themes to work around if they decide to support starter content.
#15
@
5 years ago
- Milestone changed from Future Release to 5.3
Per discussion with the Theme Review Team, moving back for now to review the patch in the next few days.
Hi @timph, thanks for the ticket!
Could you provide an example of affected values and the warnings they trigger?