/** * WP_oEmbed_Controller class, used to provide an oEmbed endpoint. * * @package WordPress * @subpackage Embeds * @since 4.4.0 */ /** * oEmbed API endpoint controller. * * Registers the REST API route and delivers the response data. * The output format (XML or JSON) is handled by the REST API. * * @since 4.4.0 */ #[AllowDynamicProperties] final class WP_oEmbed_Controller { /** * Register the oEmbed REST API route. * * @since 4.4.0 */ public function register_routes() { /** * Filters the maxwidth oEmbed parameter. * * @since 4.4.0 * * @param int $maxwidth Maximum allowed width. Default 600. */ $maxwidth = apply_filters( 'oembed_default_width', 600 ); register_rest_route( 'oembed/1.0', '/embed', array( array( 'methods' => WP_REST_Server::READABLE, 'callback' => array( $this, 'get_item' ), 'permission_callback' => '__return_true', 'args' => array( 'url' => array( 'description' => __( 'The URL of the resource for which to fetch oEmbed data.' ), 'required' => true, 'type' => 'string', 'format' => 'uri', ), 'format' => array( 'default' => 'json', 'sanitize_callback' => 'wp_oembed_ensure_format', ), 'maxwidth' => array( 'default' => $maxwidth, 'sanitize_callback' => 'absint', ), ), ), ) ); register_rest_route( 'oembed/1.0', '/proxy', array( array( 'methods' => WP_REST_Server::READABLE, 'callback' => array( $this, 'get_proxy_item' ), 'permission_callback' => array( $this, 'get_proxy_item_permissions_check' ), 'args' => array( 'url' => array( 'description' => __( 'The URL of the resource for which to fetch oEmbed data.' ), 'required' => true, 'type' => 'string', 'format' => 'uri', ), 'format' => array( 'description' => __( 'The oEmbed format to use.' ), 'type' => 'string', 'default' => 'json', 'enum' => array( 'json', 'xml', ), ), 'maxwidth' => array( 'description' => __( 'The maximum width of the embed frame in pixels.' ), 'type' => 'integer', 'default' => $maxwidth, 'sanitize_callback' => 'absint', ), 'maxheight' => array( 'description' => __( 'The maximum height of the embed frame in pixels.' ), 'type' => 'integer', 'sanitize_callback' => 'absint', ), 'discover' => array( 'description' => __( 'Whether to perform an oEmbed discovery request for unsanctioned providers.' ), 'type' => 'boolean', 'default' => true, ), ), ), ) ); } /** * Callback for the embed API endpoint. * * Returns the JSON object for the post. * * @since 4.4.0 * * @param WP_REST_Request $request Full data about the request. * @return array|WP_Error oEmbed response data or WP_Error on failure. */ public function get_item( $request ) { $post_id = url_to_postid( $request['url'] ); /** * Filters the determined post ID. * * @since 4.4.0 * * @param int $post_id The post ID. * @param string $url The requested URL. */ $post_id = apply_filters( 'oembed_request_post_id', $post_id, $request['url'] ); $data = get_oembed_response_data( $post_id, $request['maxwidth'] ); if ( ! $data ) { return new WP_Error( 'oembed_invalid_url', get_status_header_desc( 404 ), array( 'status' => 404 ) ); } return $data; } /** * Checks if current user can make a proxy oEmbed request. * * @since 4.8.0 * * @return true|WP_Error True if the request has read access, WP_Error object otherwise. */ public function get_proxy_item_permissions_check() { if ( ! current_user_can( 'edit_posts' ) ) { return new WP_Error( 'rest_forbidden', __( 'Sorry, you are not allowed to make proxied oEmbed requests.' ), array( 'status' => rest_authorization_required_code() ) ); } return true; } /** * Callback for the proxy API endpoint. * * Returns the JSON object for the proxied item. * * @since 4.8.0 * * @see WP_oEmbed::get_html() * @global WP_Embed $wp_embed WordPress Embed object. * @global WP_Scripts $wp_scripts * * @param WP_REST_Request $request Full data about the request. * @return object|WP_Error oEmbed response data or WP_Error on failure. */ public function get_proxy_item( $request ) { global $wp_embed, $wp_scripts; $args = $request->get_params(); // Serve oEmbed data from cache if set. unset( $args['_wpnonce'] ); $cache_key = 'oembed_' . md5( serialize( $args ) ); $data = get_transient( $cache_key ); if ( ! empty( $data ) ) { return $data; } $url = $request['url']; unset( $args['url'] ); // Copy maxwidth/maxheight to width/height since WP_oEmbed::fetch() uses these arg names. if ( isset( $args['maxwidth'] ) ) { $args['width'] = $args['maxwidth']; } if ( isset( $args['maxheight'] ) ) { $args['height'] = $args['maxheight']; } // Short-circuit process for URLs belonging to the current site. $data = get_oembed_response_data_for_url( $url, $args ); if ( $data ) { return $data; } $data = _wp_oembed_get_object()->get_data( $url, $args ); if ( false === $data ) { // Try using a classic embed, instead. /* @var WP_Embed $wp_embed */ $html = $wp_embed->get_embed_handler_html( $args, $url ); if ( $html ) { // Check if any scripts were enqueued by the shortcode, and include them in the response. $enqueued_scripts = array(); foreach ( $wp_scripts->queue as $script ) { $enqueued_scripts[] = $wp_scripts->registered[ $script ]->src; } return (object) array( 'provider_name' => __( 'Embed Handler' ), 'html' => $html, 'scripts' => $enqueued_scripts, ); } return new WP_Error( 'oembed_invalid_url', get_status_header_desc( 404 ), array( 'status' => 404 ) ); } /** This filter is documented in wp-includes/class-wp-oembed.php */ $data->html = apply_filters( 'oembed_result', _wp_oembed_get_object()->data2html( (object) $data, $url ), $url, $args ); /** * Filters the oEmbed TTL value (time to live). * * Similar to the {@see 'oembed_ttl'} filter, but for the REST API * oEmbed proxy endpoint. * * @since 4.8.0 * * @param int $time Time to live (in seconds). * @param string $url The attempted embed URL. * @param array $args An array of embed request arguments. */ $ttl = apply_filters( 'rest_oembed_ttl', DAY_IN_SECONDS, $url, $args ); set_transient( $cache_key, $data, $ttl ); return $data; } } https://validator.w3.org/feed/docs/rss2.html Roulo Casino Three Hours Vanished Playing Roulette Discover the Exciting World of Yenyabet Your Gateway to Online Betting -419214651 Experience the Thrill of Slots Angels Casino Online -190573839 Roulo Casino Updates Wagering Requirements on Welcome Bonuses What Your Prospects Actually Assume About Your 10 Лучших Казино Онлайн России? A Roulo Casino és a Pragmatic Play együttműködési megállapodást kötött az élő kaszinó kínálat bővítésére SpinLynx Casino 2026 Player Safety and Licensing Verification Report SpinLynx Casino Licensing and Provider Deals What It Means for GGR Perche ho deciso di testare il bonus di benvenuto su Redracer Casino The Regal Expert double play superbet $1 deposit Casino No deposit Added bonus Rules The newest & Current People June 2026 Redracer Casino recenze z pohledu zodpovědného hraní No deposit $1 buckin broncos Free Spins to own Immortal Relationship from the Game International Best No deposit Bonuses 2026 Greatest All of us Web igrosoft slots for ipad based casinos Honest and you may Fred Gambling enterprise No-deposit Incentives & Review > arcade bomb slot HELP-Ranked by the Gambling enterprise help Redracer Casino kooperiert mit Evolution Gaming für Live-Erlebnis 4 Ways To Avoid Казино На Деньги В России Burnout Explore the Best Online Casinos Not on GamStop 453053515 Exploring Non GamStop Betting Sites A Comprehensive Guide 455437890 CasoBet Casino Trustpilot Score 2026 A Comprehensive Review Horse Racing Betting Beyond GamStop An Ultimate Guide Exploring Non GamStop Bookies Your Guide to Alternative Betting Options 457797250 Amazon Slots Casino User Feedback Insights and Experiences Rumors, Lies and Онлайн Казино На Деньги The Wish Master jagtslot af Netent Top 50 online casino udbyder Særlige funktioner Befizetés nélküli helyi kaszinókedvezmények 90 év feletti amerikai állampolgároknak. További ajánlatok Principaux casinos un peu en compagnie de En public-dealer et virements immédiats Wild Gambler fruit mania Slot Free Spins Demobån af Playtech Vederlagsfri Spilleautomat og Spilanmeldelse Desire Needed! Cloudflare Betwinner app Android Todo lo que necesitas saber Обзор Pinco: что нужно знать о бонусах и акциях в 2026 году Unlock 30 Free Spins for Real Cash and Explore Exciting Casino Opportunities Exploring UK Casinos Not on Gamstop 29279645 Discovering Casino Cactus UK A Unique Gaming Experience Non BetStop Gambling Sites A Comprehensive Guide What Everyone Is Saying About Интернет Казино And What You Should Do Make Your Казино Играть A Reality Greatest ten Dollars Deposit Gambling enterprise Web sites in the install funky fruits 2026 Greatest step 1 Put Casinos slot no deposit Canada 2026 To 150 Free Revolves to own step one Top-ten Online casinos Recently A real income Reviews Pyramid online slot June 2026 Penny Ports On best no deposit bonus online casinos line Play 100 percent free Penny Slot machines & Gambling establishment The Majestic Experience of Casino Golden Lion Discover the Excitement of River Belle Casino Online -76047839 Ten Concepts About Казино На Деньги РФ That really Work Sustanon nel Culturismo: Un Guida Completa Cosa è cambiato per i giocatori italiani su Night Win Casino nel 2026 Candyland Casino: ¿Estafa o Verdad? Mastering casino games essential tips and tricks for success Winning Days Casino Player Reviews: An In-Depth Analysis Живое казино Pinco: погрузитесь в мир захватывающих игр и реальных дилеров The Mafia Guide To 10 Лучших Казино Онлайн 2026