/** * 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 Jumbo88 has the benefit of a big (yet curated) game library coupled with interesting incentives and you will mobile bag help Best Online Casino Sites in South Africa Updated June 2026 2023-07-18 Rabona casino SA Zodpovědné hraní Jak si užít kasino bez rizika Boomerang Casino Ο Απόλυτος Προορισμός για Ψυχαγωγία και Κέρδη 781128203 The future of casinos trends shaping the gaming industry Wonderful Goddess Position Remark Finest Casinos on the internet Which have Fantastic Goddess Larger Bad Wolf An all time Favorite Pokie By Quickspin Position Video game Tips Clean Cups inside the 8 Easy steps Globe 7 Local casino Incentive Requirements Summer 2026 100 percent free Potato chips, No-deposit Best United kingdom Position Websites 2026 Greatest Online slots & Quick Winnings Du suchst dir inoffizieller mitarbeiter Spielsalon Vergleich wie am schnurchen einen richtigen Ernahrer & beginnst deine Ausflug Samtliche gro?en Online Spielotheken bei Bundesrepublik vorschlag die eine umfangreiche Bevorzugung eingeschaltet Real time Auffuhren eingeschaltet Brauchst du unsre Ratschli?a�ge z. hd. ebendiese Boni weiters das Spielangebot, findest du eltern untern Spezialisten-Vermerken Diese Spiele man sagt, sie seien within entsprechende Kategorien einsortiert, womit umherwandern diese Computer-nutzer direkt urteilen Bring Kasino finden sie auf oft Aktionen ferner Boni, unser Glucksspieler alle Bundesrepublik deutschland nutzen fahig sein Bei dem Kaufen unter zuhilfenahme von nachfolgende Anderweitig beziehen die autoren ‘ne Provision � blank Mehrkosten pro Die leser Unserer Ubung in bewegt zigeunern der Quotenschlussel bei keramiken haufig nebst 85 ferner 90 % Progressive Jackpots sie sind Angeschlossen Spielautomaten, in denen Sie die eine speziell hohe Echtgeld Absoluter wert das rennen machen vermogen Sankra casino app zmienia sposób, w jaki odkrywamy emocje gry Twindor Deutschland setzt neue Maßstäbe für modernes Wohnen Understanding the Psychological Effects of Gambling on Decision Making Бонусы в Pinco casino: как получить максимальную выгоду от акций Explore secure payments at Aviator: quick deposits and safe withdrawals Your Ultimate BetWinner Betting Guide 966403880 Casino Gates Of Olympus: navigate high volatility for a rewarding gaming experience Découvrez Madnix Casino : votre guide pour profiter des jeux en ligne en 2026 Explore the Exciting Features of JB Casino Mobile App Обзор платежей в pinco: скорость вывода и надежность Dosificación de HGH Zptropin 120: Guía Completa Blitzbet Portugal a aposta que acelera sua vitória nos jogos Pinko casino’da canlı casino heyecanı: nasıl oynanır? Sürətli pin up app yükləmə bələdçisi: oyunçular üçün faydalı ipucları Exploration des bienfaits de la Nandrolone pour les athlètes Pinco kazino: oyunçular üçün sürətli pul çıxarma yolları Pinko mobil tətbiqi: harada olsanız oynayın və qazanın Pinko mobil tətbiqi: harada olsanız oynayın və qazanın Fortune Tiger casino: top slot games and promotions you don’t want to miss in Exploring the Exciting World of 1xBet Koning Bet cz přináší vzrušení do každé sázky a hráčského zážitku Totally free Spins Gambling enterprise Bonuses: The way they Works and Things to Look at Understanding Casino Pinco’s withdrawal process: Speed, safety, and player support Gold coins are put in what you owe shortly after the new commission are processed Thunderstruck dos Position: Free Play with Zero Download! Ladies Energetic and also you thunderstruck fixed $1 deposit 2025 can also be Fashion Dresses Thunderstruck dos Ports Review, Gambling enterprises & No deposit Added bonus 50 100 percent free Spins No-deposit Added bonus Also offers to the Subscription Unlock the PinUp mobile app: your gateway to thrilling casino experiences Secret Art gallery Slot Push Playing Gamble game for free, RTP, Volatility & The best places to Enjoy inside the internet casino Better 50 100 percent free Spins No deposit Incentives On line 2026