#7104 closed defect (bug) (fixed)
oembed activity review
Reported by: | DJPaul | Owned by: | |
---|---|---|---|
Milestone: | 2.6 | Priority: | normal |
Severity: | normal | Version: | |
Component: | Core | Keywords: | has-patch |
Cc: |
Description
Some observations from a post-commit code review:
- https://buddypress.trac.wordpress.org/browser/trunk/src/bp-core/classes/class-bp-oembed-component.php?rev=10837#L43 throws an exception -- we do not use exceptions anywhere in BuddyPress, and they are infrequent in WordPress core (for good or bad). I think this should be refactored somehow, maybe just assume this property is always set, or
die
. - In
bp_activity_embed_media()
, there's$_REQUEST['hide_media']
. How is this variable going to be passed over aPOST
? It's aGET
endpoint, so can't this beGET
? css-activity.php
; why isn't this just a CSS file?bp_activity_setup_oembed()
we could just move these filters into acitivity-filters.php, which I think is the aim of that file? Doesn't really impact performance even if running on a too-old version of WordPress.bp_activity_embed_has_activity()
the(int) $activity_id === (int) $activity->id
bit -- like we did recently, can't we please just change whatever calls this function to make damn sure integers are always passed?bp_activity_get_embed_excerpt()
the "<func> includes the 'Read More'" bit -- that comment block should open with/*
not/**
as it's not a PHPDoc block, and the latter will confuse the WP Code Reference documentation parser here.bp_activity_embed_excerpt_onclick_location_filter()
-- the regular expression is too brittle. All it'd take is for the href property not to start at the beginning of the link block. There's a better way to do this which I'm trying to remember and will leave a comment later.- Also in
bp_activity_setup_oembed()
, we should useversion_compare()
to check the WordPress function. I know we are internally inconsistent but let's get it right here.
Thanks for your work on this, it looks really great!
Attachments (1)
Change History (15)
#3
@
8 years ago
- Keywords has-patch added
Thanks for the feedback, @DJPaul. I'm going to reply to each point in a separate comment.
First:
css-activity.php; why isn't this just a CSS file?
Initially, it's because we did not have dedicated functions to locate and load assets in Core, so I kind of hacked my way around by using a template part. On hindsight, this is bad and breaks theme developer conventions.
So attachment:7104.css.patch is what I originally envisioned for locating and loading assets. It introduces two functions:
bp_locate_template_asset()
- which is almost exactly likebp_locate_template()
bp_get_template_asset()
- which is almost exactly likebp_get_template_part()
I feel this should replace BP_Legacy::locate_asset_in_stack()
.
#4
@
8 years ago
throws an exception -- we do not use exceptions anywhere in BuddyPress, and they are infrequent in WordPress core (for good or bad).
I think exceptions are good, but I understand the concerns of sticking with what WordPress is doing.
I'm fine with whatever you decide here.
bp_activity_setup_oembed() we could just move these filters into acitivity-filters.php
Will make the change.
Update - Fixed in r10852.
Also in bp_activity_setup_oembed(), we should use version_compare() to check the WordPress function.
Will make the change. Is there a legitimate use for bp_get_major_wp_version()
?
Update - Fixed in r10851.
bp_activity_embed_excerpt_onclick_location_filter() -- the regular expression is too brittle.
Good catch. I guess a dev that is filtering the embed excerpt could inject link attributes before the onclick filter is run.
Anyway, this should work:
function bp_activity_embed_excerpt_onclick_location_filter( $text ) {
return preg_replace_callback( '/<a\s+[^>]*href=\"([^\"]*)\"/iU', 'bp_activity_embed_excerpt_onclick_location_filter_callback', $text );
}
bp_activity_embed_has_activity() the (int) $activity_id === (int) $activity->id bit
I'll commit some stuff from #6977 to fix this.
Update - Fixed in r10854.
#5
@
8 years ago
Probably not much use for bp_get_major_wp_version() except perhaps whoever added it didn't know better, and missed it in review. We can probably stop using it sometime.
In 10844: