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-screencast.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();
}


/**
 * Screencast.com Video SEO Details
 *
 * @todo no api or connection from getting video details from the url so we extract the
 * details from the embed code itself
 * Embedly actually provides usable info, so we may want to consider implementing this using
 * Embedly as Screencast does not seem to support oembed nor have their own API.
 */
if ( ! class_exists( 'WPSEO_Video_Details_Screencast' ) ) {

	/**
	 * Class WPSEO_Video_Details_Screencast
	 */
	class WPSEO_Video_Details_Screencast extends WPSEO_Video_Details {

		/**
		 * Regular expression to retrieve a video ID from a known video URL.
		 *
		 * @var string
		 */
		protected $id_regex = '`[/\.]screencast\.com/(.*)$`i';

		/**
		 * Information on the remote URL to use for retrieving the video details.
		 *
		 * @var string[]
		 */
		protected $remote_url = [];

		/**
		 * Retrieve the video id from a known video url based on a regex match.
		 *
		 * @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 ( ( isset( $this->vid['url']['url'] ) && is_string( $this->vid['url']['url'] ) && $this->vid['url']['url'] !== '' ) && $this->id_regex !== '' ) {
				if ( preg_match( $this->id_regex, $this->vid['url']['url'], $match ) ) {
					$this->vid['id'] = $match[ $match_nr ];
				}
			}
		}

		/**
		 * Retrieve information on a video via a remote API call.
		 *
		 * Currently implemented to use already existing information.
		 *
		 * @return void
		 */
		protected function get_remote_video_info() {
			if ( is_array( $this->vid['url'] ) && isset( $this->vid['url']['embed'] ) ) {
				$this->remote_response = $this->vid['url']['embed'];
			}
		}

		/**
		 * Decode a remote response as DOMXPath object
		 *
		 * @uses WPSEO_Video_Details::$remote_url
		 *
		 * @return void
		 */
		protected function decode_remote_video_info() {
			if ( ! empty( $this->remote_response ) && ( extension_loaded( 'dom' ) && class_exists( 'DOMXPath' ) ) ) {
				$dom = new DOMDocument();

				// The loadHTML() method will throw an error on malformed HTML.
				// phpcs:ignore WordPress.PHP.NoSilencedErrors.Discouraged
				@$dom->loadHTML( $this->remote_response );
				$xpath = new DOMXPath( $dom );

				$item = $xpath->query( '//object/param[@name="flashVars"]' );
				if ( $item instanceof DOMNodeList && $item->length > 0 ) {
					$item = $item->item( 0 )->getAttribute( 'value' );
					parse_str( $item, $response );
					if ( is_array( $response ) && $response !== [] ) {
						$this->decoded_response = $response;
					}
				}
			}

			if ( ! isset( $this->decoded_response ) ) {
				$this->decoded_response = $this->remote_response;
			}
		}

		/**
		 * Check if the response is for a valid video
		 *
		 * @return bool
		 */
		protected function is_video_response() {
			return ( ! empty( $this->decoded_response ) );
		}

		/**
		 * Set the video height
		 *
		 * @return void
		 */
		protected function set_height() {
			if ( ! empty( $this->decoded_response['containerheight'] ) ) {
				$this->vid['height'] = $this->decoded_response['containerheight'];
			}
		}

		/**
		 * Set the player location
		 *
		 * @return void
		 */
		protected function set_player_loc() {
			if ( ! empty( $this->decoded_response['content'] ) ) {
				$this->vid['player_loc'] = $this->decoded_response['content'];
			}
		}

		/**
		 * Set the thumbnail location
		 *
		 * @return void
		 */
		protected function set_thumbnail_loc() {
			if ( isset( $this->decoded_response['thumb'] ) && is_string( $this->decoded_response['thumb'] ) && $this->decoded_response['thumb'] !== '' ) {
				$image = $this->make_image_local( $this->decoded_response['thumb'] );
				if ( is_string( $image ) && $image !== '' ) {
					$this->vid['thumbnail_loc'] = $image;
				}
			}
		}

		/**
		 * Set the video width
		 *
		 * @return void
		 */
		protected function set_width() {
			if ( ! empty( $this->decoded_response['containerwidth'] ) ) {
				$this->vid['width'] = $this->decoded_response['containerwidth'];
			}
		}
	}
}