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

if ( ! class_exists( 'WPSEO_Video_Details_Evs' ) ) {

	/**
	 * Easy Video Suite (EVS) Video SEO Details
	 *
	 * @todo Add other evs metadata: player_loc, content_loc, duration, width, height.
	 */
	class WPSEO_Video_Details_Evs extends WPSEO_Video_Details {

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

		/**
		 * EVS location.
		 *
		 * @var string
		 */
		protected $evs_location;

		/**
		 * Instantiate the class
		 *
		 * Retrieve the EVS location and only pass of to the parent constructor if we find one
		 *
		 * @param array $vid     The video array with all the data.
		 * @param array $old_vid The video array with all the data of the previous "fetch", if available.
		 */
		public function __construct( $vid, $old_vid = [] ) {
			$this->evs_location = get_option( 'evs_location' );

			if ( $this->evs_location ) {
				parent::__construct( $vid, $old_vid );
			}
			else {
				/*
				 * @todo [JRF -> Yoast] Why not use (merge with) oldvid data here if available?
				 * The api key might be removed, but old data might still be better than none.
				 */
				$this->vid = $vid;
			}
		}

		/**
		 * Set the video id to a known video url.
		 *
		 * @param int $match_nr Not used in this implementation.
		 *
		 * @return void
		 */
		protected function determine_video_id_from_url( $match_nr = 1 ) {
			if ( ! empty( $this->vid['url'] ) ) {
				$this->vid['id'] = $this->vid['url'];
			}
		}

		/**
		 * Retrieve information on a video via a remote API call
		 *
		 * @return void
		 */
		protected function get_remote_video_info() {
			if ( ! empty( $this->vid['id'] ) ) {
				// Retrieve evs thumbnail info.
				$api      = $this->evs_location . '/api.php';
				$response = wp_remote_post(
					$api,
					[
						'method'      => 'POST',
						'timeout'     => 45,
						'redirection' => 5,
						'httpversion' => '1.0',
						'blocking'    => true,
						'headers'     => [],
						'cookies'     => [],
						'body'        => [
							'page_url' => $this->vid['id'],
							'method'   => 'public-file-images',
						],
					]
				);

				if ( ! is_wp_error( $response ) && ! empty( $response['body'] ) ) {
					$this->remote_response = $response['body'];
				}
			}
		}

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

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

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