Review SanitizationHelperTrait::is_only_sanitized() in depth
jrfnl opened this issue · 0 comments
Per #2356 (comment):
I still have a niggly feeling there is a logic error in the
is_only_sanitized()
method, but I haven't been able to figure out the reason this was originally coded this way, so I'm not touching it for now.The logic error I suspect is in the following code:
// The only parentheses should belong to the sanitizing function. If there's // more than one set, this isn't *only* sanitization. return ( \count( $tokens[ $stackPtr ]['nested_parenthesis'] ) === 1 );This seems to presume that parentheses could only be for function calls, while the extra parentheses may just as well be for control structure conditions.
If the other parentheses are for control structure conditions, I believe the variable should still count as "only sanitized".
It also discounts situations where unslashing is nested within a sanitization function call (which is taken into account in theNonceVerification
sniff, but that is now inconsistent).$a = is_email( $_GET['email'] ); // is_ony_sanitized(): true $a = is_email( wp_unslash( $_GET['email'] ) ); // is_ony_sanitized(): false if ( is_email( $_GET['email'] ) ) {} // is_ony_sanitized(): falseThis should probably be further investigated when adding dedicated tests for these methods (#2272).
Might be a good idea for this and some other issues to involve the security team for second opinions on what the sniffs should accept as valid.