????

Your IP : 18.219.226.57


Current Path : /proc/self/cwd/wp-content/plugins/presto-player/inc/Services/API/
Upload File :
Current File : //proc/self/cwd/wp-content/plugins/presto-player/inc/Services/API/RestSettingsController.php

<?php

namespace PrestoPlayer\Services\API;

class RestSettingsController extends \WP_REST_Settings_Controller {


	/**
	 * Constructor.
	 *
	 * @since 4.7.0
	 */
	public function __construct() {
		$this->namespace = 'presto-player/v1';
		$this->rest_base = 'settings';
	}

	/**
	 * Register controller
	 *
	 * @return void
	 */
	public function register() {
		add_action( 'rest_api_init', array( $this, 'register_routes' ) );
		add_filter( 'rest_pre_update_setting', array( $this, 'validatePlayerBrandingCSS' ), 10, 3 );
	}

	/**
	 * Retrieves all of the registered options for the Settings API.
	 *
	 * @since 4.7.0
	 *
	 * @return array Array of registered options.
	 */
	protected function get_registered_options() {
		$rest_options = array();

		foreach ( get_registered_settings() as $name => $args ) {
			if ( ! in_array( $name, array( 'presto_player_branding', 'presto_player_youtube', 'presto_player_presets', 'presto_player_audio_presets', 'presto_player_instant_video_width', 'presto_player_media_hub_sync_default' ) ) ) {
				continue;
			}

			if ( empty( $args['show_in_rest'] ) ) {
				continue;
			}

			$rest_args = array();

			if ( is_array( $args['show_in_rest'] ) ) {
				$rest_args = $args['show_in_rest'];
			}

			$defaults = array(
				'name'   => ! empty( $rest_args['name'] ) ? $rest_args['name'] : $name,
				'schema' => array(),
			);

			$rest_args = array_merge( $defaults, $rest_args );

			$default_schema = array(
				'type'        => empty( $args['type'] ) ? null : $args['type'],
				'description' => empty( $args['description'] ) ? '' : $args['description'],
				'default'     => isset( $args['default'] ) ? $args['default'] : null,
			);

			$rest_args['schema']      = array_merge( $default_schema, $rest_args['schema'] );
			$rest_args['option_name'] = $name;

			// Skip over settings that don't have a defined type in the schema.
			if ( empty( $rest_args['schema']['type'] ) ) {
				continue;
			}

			/*
			 * Allow the supported types for settings, as we don't want invalid types
			 * to be updated with arbitrary values that we can't do decent sanitizing for.
			 */
			if ( ! in_array( $rest_args['schema']['type'], array( 'number', 'integer', 'string', 'boolean', 'array', 'object' ), true ) ) {
				continue;
			}

			$rest_args['schema'] = rest_default_additional_properties_to_false( $rest_args['schema'] );

			$rest_options[ $rest_args['name'] ] = $rest_args;
		}

		return $rest_options;
	}

	/**
	 * Validate player branding css setting value before updating.
	 *
	 * @param mixed           $value   The value of the setting.
	 * @param string          $setting The setting name.
	 * @param WP_REST_Request $request The request object.
	 *
	 * @return void
	 */
	public function validatePlayerBrandingCSS( $value, $setting, $request ) {
		if ( 'presto_player_branding' !== $setting ) {
			return $value;
		}

		if ( isset( $request['player_css'] ) && ! empty( $request['player_css'] ) ) {
			$css_validation_result = $this->validateCustomCSS( $request['player_css'] );
			if ( is_wp_error( $css_validation_result ) ) {
				wp_die( $css_validation_result, 400 );
			}
		}

		return $value;
	}

	/**
	 * Validate style.css as valid CSS.
	 *
	 * Currently just checks for invalid markup.
	 *
	 * @param string $css CSS to validate.
	 *
	 * @return true|WP_Error True if the input was validated, otherwise WP_Error.
	 */
	protected function validateCustomCSS( $css ) {
		if ( preg_match( '#</?\w+#', $css ) ) {
			return new \WP_Error(
				'rest_custom_css_illegal_markup',
				__( 'Markup is not allowed in CSS.', 'gutenberg' ),
				array( 'status' => 400 )
			);
		}
		return true;
	}
}