/** * 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 MXN777 casino en México: un mundo de slots y promociones irresistibles Kasinot Netissä Tutkimusmatkalla: Käyttöliittymä ja Pelikokemus Arvioituna Online or land-based which casino experience offers better odds Fruit Cocktail: guía completa para jugar y ganar en México en 2026 Verantwoord gokken tips voor een duurzame speelervaring Buitenlandse Casino Alles Wat Je Moet Weten 437009130 Captivating casino environments how design influences player experience BetWinner Senegal Login A Comprehensive Guide 915017505 2026-da Pin up kazino bonusları: necə daha çox dəyər əldə edə bilərsiniz The All-Inclusive Guide to BC.Game Casino and Sportsbook Giocare online o offline quale scelta ti porta a vincere di più Bl777 casino: a historical look at dummy text and its impact on design Test E 250 pour Des Performances Sportives Optimales Avantages et caractéristiques du Trenbolone Acetate pour les athlètes Подключение Deye 6kW BMS Полное руководство 1715636176 Kult Kasino ja sen bonuskaytannot seka operatiiviset toimintatavat Explore the Exciting World of JB Casino Games, Bonuses, and More! Autour de Masteron P 100 pour une Performance Améliorée Les enjeux des régulations légales dans le secteur des jeux d'argent en France Navigating %key1% feels surprisingly intuitive from the first click Test Post Created 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