[wp-trac] [WordPress Trac] #56198: Check cache key type
WordPress Trac
noreply at wordpress.org
Wed Aug 3 14:35:15 UTC 2022
#56198: Check cache key type
-------------------------+-----------------------------
Reporter: tillkruess | Owner: SergeyBiryukov
Type: enhancement | Status: closed
Priority: normal | Milestone: 6.1
Component: Cache API | Version: trunk
Severity: normal | Resolution: fixed
Keywords: has-patch | Focuses: performance
-------------------------+-----------------------------
Changes (by SergeyBiryukov):
* owner: (none) => SergeyBiryukov
* status: new => closed
* resolution: => fixed
Comment:
In [changeset:"53818" 53818]:
{{{
#!CommitTicketReference repository="" revision="53818"
Cache API: Validate cache key in `WP_Object_Cache` methods.
Some plugins may call the `wp_cache_*()` functions with an empty string,
`false`, or `null` as cache key, usually as a result of not checking the
return value of another function that's used as the key.
Previously, this was silently failing, leading to odd behavior at best and
often breakage due to key collisions.
A valid cache key must be either an integer number or a non-empty string.
This commit introduces a quick type check on the given cache keys and adds
a `_doing_it_wrong()` message that should help plugin developers to notice
these issues quicker.
Includes:
* A check in `update_user_caches()` and `clean_user_cache()` to make sure
user email is not empty before being cached or removed from cache, as it
is technically possible to create a user with empty email via
`wp_insert_user()`.
* Some minor cleanup in unit tests where the email was passed to
`wp_insert_user()` incorrectly or was unintentionally reset.
Props tillkruess, malthert, dd32, spacedmonkey, flixos90, peterwilsoncc,
SergeyBiryukov.
Fixes #56198.
}}}
--
Ticket URL: <https://core.trac.wordpress.org/ticket/56198#comment:20>
WordPress Trac <https://core.trac.wordpress.org/>
WordPress publishing platform
More information about the wp-trac
mailing list