HEX
Server: Apache/2.4.65 (Debian)
System: Linux 88f31f35b0b8 6.1.0-38-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.147-1 (2025-08-02) x86_64
User: www-data (33)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/html/wp-content/plugins/wpseo-video/detail-retrieval/class-wordpresstv.php
<?php
/**
 * Yoast SEO Video plugin file.
 *
 * @package    Internals
 * @since      1.7.0
 * @version    1.7.0
 */

// Avoid direct calls to this file.
if ( ! class_exists( 'WPSEO_Video_Sitemap' ) ) {
	header( 'Status: 403 Forbidden' );
	header( 'HTTP/1.1 403 Forbidden' );
	exit();
}


/**
 * WordPress.tv Video SEO Details
 *
 * JSON response format from this class' own call in the determine_id... method [2014/8/16]:
 * {
 *    "type":"video",
 *    "version":"1.0",
 *    "title":null,
 *    "width":400,
 *    "height":224,
 *    "html":"<embed src=\"\/\/v.wordpress.com\/zHKcIQfo\" type=\"application\/x-shockwave-flash\" width=\"400\" height=\"224\" allowscriptaccess=\"always\" allowfullscreen=\"true\" wmode=\"transparent\"><\/embed>"
 * }
 */
if ( ! class_exists( 'WPSEO_Video_Details_Wordpresstv' ) ) {

	/**
	 * Class WPSEO_Video_Details_Wordpresstv
	 *
	 * Retrieve video details from WordPress.tv (well grab the ID and then use the VideoPress API)
	 */
	class WPSEO_Video_Details_Wordpresstv extends WPSEO_Video_Details_Videopress {

		/**
		 * Regular expression to retrieve a video ID from a known video URL.
		 *
		 * {@internal Is used in a slightly different way than in the other classes - uses
		 *            a remote call first to get the URL to use this against.}
		 *
		 * @var string
		 */
		protected $id_regex = '`v\.wordpress\.com/([^"]+)`i'; // phpcs:ignore WordPress.WP.CapitalPDangit.MisspelledInText -- URL regex.

		/**
		 * Sprintf template to create a URL from an ID.
		 *
		 * @var string
		 */
		protected $url_template = '//v.wordpress.com/%s';

		/**
		 * Retrieve the video id from a known video url via a remote call, then match it based on a regex
		 *
		 * @param int $match_nr The captured parenthesized sub-pattern to use from matches. Defaults to 1.
		 *
		 * @return void
		 */
		protected function determine_video_id_from_url( $match_nr = 1 ) {
			if ( ( is_string( $this->vid['url'] ) && $this->vid['url'] !== '' ) && $this->id_regex !== '' ) {

				$replace_key = $this->vid['url'];
				// Fix protocol-less urls in parameters as the remote get call most often will not work with them.
				if ( strpos( $this->vid['url'], '//' ) === 0 ) {
					$replace_key = 'http:' . $this->vid['url'];
				}

				$url = sprintf( 'http://wordpress.tv/oembed/?url=%s', $replace_key );
				$url = $this->url_encode( $url );

				$response = $this->remote_get( $url );
				if ( is_string( $response ) && $response !== '' && $response !== 'null' ) {

					$response = json_decode( $response );
					if ( is_object( $response ) ) {
						if ( preg_match( $this->id_regex, $response->html, $match ) ) {
							$this->vid['id'] = $match[ $match_nr ];
						}
					}
				}
			}
		}

		/**
		 * Use the "new" post data with the old video data, to prevent the need for an external video
		 * API call when the video hasn't changed.
		 *
		 * Match whether old data can be used on url rather than video id
		 *
		 * @param string $match_on Array key to use in the $vid array to determine whether or not to use the old data.
		 *                         Defaults to 'url' for this implementation.
		 *
		 * @return bool Whether or not valid old data was found (and used)
		 */
		protected function maybe_use_old_video_data( $match_on = 'url' ) {
			return parent::maybe_use_old_video_data( $match_on );
		}
	}
}