Press This: Make the regular expressions for matching images easier to read by not requiring escaping.

Fixes #32878


git-svn-id: https://develop.svn.wordpress.org/trunk@34736 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Dion Hulse 2015-10-01 05:15:05 +00:00
parent ee2c079ade
commit 3ffcb9548d

View File

@ -390,8 +390,8 @@ class WP_Press_This {
/** /**
* Utility method to limit image source URLs. * Utility method to limit image source URLs.
* *
* Excluded URLs include share-this type buttons, loaders, spinners, spacers, WP interface images, * Excluded URLs include share-this type buttons, loaders, spinners, spacers, WordPress interface images,
* tiny buttons or thumbs, mathtag.com or quantserve.com images, or the WP stats gif. * tiny buttons or thumbs, mathtag.com or quantserve.com images, or the WordPress.com stats gif.
* *
* @ignore * @ignore
* @since 4.2.0 * @since 4.2.0
@ -402,32 +402,32 @@ class WP_Press_This {
private function _limit_img( $src ) { private function _limit_img( $src ) {
$src = $this->_limit_url( $src ); $src = $this->_limit_url( $src );
if ( preg_match( '/\/ad[sx]{1}?\//', $src ) ) { if ( preg_match( '!/ad[sx]?/!i', $src ) ) {
// Ads // Ads
return ''; return '';
} else if ( preg_match( '/(\/share-?this[^\.]+?\.[a-z0-9]{3,4})(\?.*)?$/', $src ) ) { } else if ( preg_match( '!(/share-?this[^.]+?\.[a-z0-9]{3,4})(\?.*)?$!i', $src ) ) {
// Share-this type button // Share-this type button
return ''; return '';
} else if ( preg_match( '/\/(spinner|loading|spacer|blank|rss)\.(gif|jpg|png)/', $src ) ) { } else if ( preg_match( '!/(spinner|loading|spacer|blank|rss)\.(gif|jpg|png)!i', $src ) ) {
// Loaders, spinners, spacers // Loaders, spinners, spacers
return ''; return '';
} else if ( preg_match( '/\/([^\.\/]+[-_]{1})?(spinner|loading|spacer|blank)s?([-_]{1}[^\.\/]+)?\.[a-z0-9]{3,4}/', $src ) ) { } else if ( preg_match( '!/([^./]+[-_])?(spinner|loading|spacer|blank)s?([-_][^./]+)?\.[a-z0-9]{3,4}!i', $src ) ) {
// Fancy loaders, spinners, spacers // Fancy loaders, spinners, spacers
return ''; return '';
} else if ( preg_match( '/([^\.\/]+[-_]{1})?thumb[^.]*\.(gif|jpg|png)$/', $src ) ) { } else if ( preg_match( '!([^./]+[-_])?thumb[^.]*\.(gif|jpg|png)$!i', $src ) ) {
// Thumbnails, too small, usually irrelevant to context // Thumbnails, too small, usually irrelevant to context
return ''; return '';
} else if ( preg_match( '/\/wp-includes\//', $src ) ) { } else if ( false !== stripos( $src, '/wp-includes/' ) ) {
// Classic WP interface images // Classic WordPress interface images
return ''; return '';
} else if ( preg_match( '/[^\d]{1}\d{1,2}x\d+\.(gif|jpg|png)$/', $src ) ) { } else if ( preg_match( '![^\d]\d{1,2}x\d+\.(gif|jpg|png)$!i', $src ) ) {
// Most often tiny buttons/thumbs (< 100px wide) // Most often tiny buttons/thumbs (< 100px wide)
return ''; return '';
} else if ( preg_match( '/\/pixel\.(mathtag|quantserve)\.com/', $src ) ) { } else if ( preg_match( '!/pixel\.(mathtag|quantserve)\.com!i', $src ) ) {
// See mathtag.com and https://www.quantcast.com/how-we-do-it/iab-standard-measurement/how-we-collect-data/ // See mathtag.com and https://www.quantcast.com/how-we-do-it/iab-standard-measurement/how-we-collect-data/
return ''; return '';
} else if ( preg_match( '/\/[gb]\.gif(\?.+)?$/', $src ) ) { } else if ( preg_match( '!/[gb]\.gif(\?.+)?$!i', $src ) ) {
// Classic WP stats gif // WordPress.com stats gif
return ''; return '';
} }
@ -452,19 +452,19 @@ class WP_Press_This {
if ( empty( $src ) ) if ( empty( $src ) )
return ''; return '';
if ( preg_match( '/\/\/(m|www)\.youtube\.com\/(embed|v)\/([^\?]+)\?.+$/', $src, $src_matches ) ) { if ( preg_match( '!//(m|www)\.youtube\.com/(embed|v)/([^?]+)\?.+$!i', $src, $src_matches ) ) {
// Embedded Youtube videos (www or mobile) // Embedded Youtube videos (www or mobile)
$src = 'https://www.youtube.com/watch?v=' . $src_matches[3]; $src = 'https://www.youtube.com/watch?v=' . $src_matches[3];
} else if ( preg_match( '/\/\/player\.vimeo\.com\/video\/([\d]+)([\?\/]{1}.*)?$/', $src, $src_matches ) ) { } else if ( preg_match( '!//player\.vimeo\.com/video/([\d]+)([?/].*)?$!i', $src, $src_matches ) ) {
// Embedded Vimeo iframe videos // Embedded Vimeo iframe videos
$src = 'https://vimeo.com/' . (int) $src_matches[1]; $src = 'https://vimeo.com/' . (int) $src_matches[1];
} else if ( preg_match( '/\/\/vimeo\.com\/moogaloop\.swf\?clip_id=([\d]+)$/', $src, $src_matches ) ) { } else if ( preg_match( '!//vimeo\.com/moogaloop\.swf\?clip_id=([\d]+)$!i', $src, $src_matches ) ) {
// Embedded Vimeo Flash videos // Embedded Vimeo Flash videos
$src = 'https://vimeo.com/' . (int) $src_matches[1]; $src = 'https://vimeo.com/' . (int) $src_matches[1];
} else if ( preg_match( '/\/\/vine\.co\/v\/([^\/]+)\/embed/', $src, $src_matches ) ) { } else if ( preg_match( '!//vine\.co/v/([^/]+)/embed!i', $src, $src_matches ) ) {
// Embedded Vine videos // Embedded Vine videos
$src = 'https://vine.co/v/' . $src_matches[1]; $src = 'https://vine.co/v/' . $src_matches[1];
} else if ( preg_match( '/\/\/(www\.)?dailymotion\.com\/embed\/video\/([^\/\?]+)([\/\?]{1}.+)?/', $src, $src_matches ) ) { } else if ( preg_match( '!//(www\.)?dailymotion\.com/embed/video/([^/?]+)([/?].+)?!i', $src, $src_matches ) ) {
// Embedded Daily Motion videos // Embedded Daily Motion videos
$src = 'https://www.dailymotion.com/video/' . $src_matches[2]; $src = 'https://www.dailymotion.com/video/' . $src_matches[2];
} else { } else {