WP_oEmbed::get_provider()
Takes a URL and returns the corresponding oEmbed provider's URL, if there is one.
Method of the class: WP_oEmbed{}
No Hooks.
Return
String|false
. The oEmbed provider URL on success, false on failure.
Usage
$WP_oEmbed = new WP_oEmbed(); $WP_oEmbed->get_provider( $url, $args );
- $url(string) (required)
- The URL to the content.
- $args(string|array)
Additional provider arguments.
Default: ''
- discover(true|false)
Optional. Determines whether to attempt to discover link tags at the given URL for an oEmbed provider when the provider URL is not found in the built-in providers list.
Default: true
- discover(true|false)
Notes
Changelog
Since 4.0.0 | Introduced. |
WP_oEmbed::get_provider() WP oEmbed::get provider code WP 6.7.1
public function get_provider( $url, $args = '' ) { $args = wp_parse_args( $args ); $provider = false; if ( ! isset( $args['discover'] ) ) { $args['discover'] = true; } foreach ( $this->providers as $matchmask => $data ) { list( $providerurl, $regex ) = $data; // Turn the asterisk-type provider URLs into regex. if ( ! $regex ) { $matchmask = '#' . str_replace( '___wildcard___', '(.+)', preg_quote( str_replace( '*', '___wildcard___', $matchmask ), '#' ) ) . '#i'; $matchmask = preg_replace( '|^#http\\\://|', '#https?\://', $matchmask ); } if ( preg_match( $matchmask, $url ) ) { $provider = str_replace( '{format}', 'json', $providerurl ); // JSON is easier to deal with than XML. break; } } if ( ! $provider && $args['discover'] ) { $provider = $this->discover( $url ); } return $provider; }