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-ustudio.php
<?php
/**
 * Yoast SEO Video plugin file.
 *
 * @package    Internals
 * @since      3.7.0
 * @version    3.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_Ustudio' ) ) {

	/**
	 * Class WPSEO_Video_Details_Ustudio
	 */
	class WPSEO_Video_Details_Ustudio extends WPSEO_Video_Details {

		/**
		 * Regular expression to retrieve a video ID from a known video URL.
		 *
		 * The ID for use in this module is combo of {destination_id/video_id} (include '/').
		 *
		 * @var string
		 */
		protected $id_regex = '`ustudio\.com/embed/([/a-zA-Z0-9]+)`i';

		/**
		 * Sprintf template to create a URL from an ID.
		 *
		 * @var string
		 */
		protected $url_template = 'https://app.ustudio.com/embed/%s';

		/**
		 * Information on the remote URL to use for retrieving the video details.
		 *
		 * @var array<string, string>
		 */
		protected $remote_url = [
			'pattern'       => 'https://app.ustudio.com/embed/%s/config.json',
			'replace_key'   => 'id',
			'response_type' => 'json',
		];

		/**
		 * First video in the response.
		 *
		 * @var array|false
		 */
		private $first_video;

		/**
		 * Information on the largest transcode.
		 *
		 * @var array|false
		 */
		private $transcode;

		/**
		 * Set video details to their new values
		 *
		 * The actual setting is done via methods in the concrete classes.
		 *
		 * @return void
		 */
		protected function put_video_details() {
			$this->first_video = $this->get_decoded_video();

			if ( is_array( $this->first_video ) ) {
				$this->transcode = $this->get_transcode();
				parent::put_video_details();
			}
		}

		/**
		 * Set the player location.
		 *
		 * @return void
		 */
		protected function set_player_loc() {
			if ( ! empty( $this->vid['id'] ) ) {
				$this->vid['player_loc'] = 'https://app.ustudio.com/embed/' . $this->vid['id'];
			}
		}

		/**
		 * Pull the first video from the details, if exists.
		 *
		 * @return array|false
		 */
		protected function get_decoded_video() {
			if ( ! empty( $this->decoded_response->videos ) ) {
				return $this->decoded_response->videos[0];
			}
			return false;
		}

		/**
		 * Pull the largest (widest) transcode, preferably mp4.
		 *
		 * @return array|false
		 */
		protected function get_transcode() {
			$transcode = false;
			if ( ! empty( $this->first_video->transcodes ) ) {
				foreach ( $this->first_video->transcodes as $format => $items ) {
					foreach ( $items as $item ) {
						$item->format = $format;
						if ( ! $transcode ) {
							// For starters, use the first transcode we find.
							$transcode = $item;
						}
						elseif ( $format === 'mp4' && $transcode->format !== 'mp4' ) {
							// If item is mp4 and best transcode isn't, use the mp4.
							$transcode = $item;
						}
						elseif ( $item->width > $transcode->width ) {
							// If item is wider, use it.
							$transcode = $item;
						}
					}
				}
			}
			return $transcode;
		}

		/**
		 * Set the thumbnail location
		 *
		 * @return void
		 */
		protected function set_thumbnail_loc() {
			if ( ! empty( $this->first_video->images ) ) {
				foreach ( $this->first_video->images as $image ) {
					if ( $image->type === 'poster' ) {
						$local_img = $this->make_image_local( $image->image_url );
						if ( is_string( $local_img ) && $local_img !== '' ) {
							$this->vid['thumbnail_loc'] = $local_img;
							return;
						}
					}
				}
			}
		}

		/**
		 * Set the duration
		 *
		 * @return void
		 */
		protected function set_duration() {
			if ( ! empty( $this->first_video->duration ) && is_numeric( $this->first_video->duration ) ) {
				$this->vid['duration'] = $this->first_video->duration;
			}
		}

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

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

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