Opened 11 years ago
Last modified 5 years ago
#27421 reopened defect (bug)
Escape madness in meta API
Reported by: | Denis-de-Bernardy | Owned by: | |
---|---|---|---|
Milestone: | Priority: | normal | |
Severity: | normal | Version: | 3.8.1 |
Component: | Options, Meta APIs | Keywords: | has-patch |
Focuses: | Cc: |
Description
I was trying to come up with a reasonably sane wrapper around the WP meta API so as to no longer need to call it directly, and I'm somewhat bemused by the slashing insanity in there...
As I read through the code:
- get_post_meta() expects key and value to be unslashed
- add_post_meta(), update_post_meta() and delete_post_meta() expect key and value to be slashed
- WP uses wp_unslash() to strip slashes in add_metadata(), update_metadata(), and delete_metadata()
- the codex suggests to use wp_slash() to add slashes before storing data
This could all work in the best of worlds, but then:
- the codex is mysteriously silent on the need to slash keys as well
- wp_unslash() will dutifully unslash objects, but wp_slash() doesn't slash them to begin with
- wp_slash() and wp_unslash() would not be able to slash private variables (short of using Reflection, perhaps) even if they wanted to
- wp_slash() and wp_unslash() will not bother processing array keys that could have been sent from e.g. a POST request.
Admittedly, it's not every day where $_REQUEST keys are inserted as is the database, so there's likely little room for SQL injections with respect to that last point, and array keys are typically without slashes, leaving little room for quirky keys that lose their slashes while getting stored.
Still, I'm left scratching my head as to if/when we'll actually allow objects to get stored using the meta API without running the risk of seeing their data unslashed at arbitrary points in time.
Attachments (1)
Change History (9)
#2
@
11 years ago
- Milestone Awaiting Review deleted
- Resolution set to duplicate
- Status changed from new to closed
#3
@
11 years ago
- Resolution duplicate deleted
- Status changed from closed to reopened
I'd argue this ticket has more to do with making:
wp_slash(wp_unslash($data))
andwp_unslash(wp_slash($data))
work properly, meaning returning $data
in each case irrespective of whether it's a scalar, a string, an array, an object, or a combination of the latter.
#18322 is more about a long term thing which, frankly, I don't expect to see fixed any time soon. We need wp_slash() to mirror wp_unslash() in the meanwhile, meaning wp_slash() must be capable of slashing objects.
#5
@
11 years ago
Then this might be a duplicate of https://core.trac.wordpress.org/ticket/24106#comment:10.
#8
@
8 years ago
Any news on this?
I've stumbled on it when trying to fix compatibility issue between my plugin (Duplicate Post) and some visual editors that store objects in metadata: if I call wp_slash on the original post's custom fields before storing them into the copy they become unusable.
The patch seems to work fine. What's needed for that to make it into the core? Can I help in any way?
Oh yes, and I forgot what is possibly the most colorful point: update_post_meta() expects $meta_value to be slashed, but $prev_value is expected to be *unslashed*.