/** * 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 Les Bienfaits de l’Oxandrolone pour les Athlètes Maximizing Your Earnings with Sportsbook and Casino Affiliate Programs 1617200161 Zahraniční casina Objevte svět online hazardu Erlebe den Zauber der stake7 Freispiele für grenzenlosen Spielspaß Experience Thrill and Excitement at Mr Bet Casino Exploring the Exciting World of Casobet Casino Platform Напълно безплатни портове без verde casino регистрация за вход дъмпове Enjoy Reddish Mansions Slot: Opinion, ruby fortune casino Casinos, Bonus and Movies Джак Промо кодове за приложението за слотове на verde casino Амърсмит В интернет Новолайн Вход за bombastic casino Харбърс Ехтгелд Play Online 100percent free spins no deposit online slots free Най-голямото хазартно Промо кодове ice casino предприятие с безплатни въртящи се хазартни игри за 2022 г. Напълно безплатни Изтегляне на приложението ice casino за Android слотове онлайн £10 казино без депозит ice casino 100 процента безплатно Не е необходим депозит през 2021 г. Online 7 sins slot for money casino games the real deal Currency Бездепозитни допълнителни казина Бонус ice casino контакт в България от десет долара безплатно Ръководство за онлайн хазарт и намиране на Изтегляне на APK на приложението hitnspin много добри казина през 2022 г. Lobstermania 100 процента Официален сайт за влизане в hitnspin безплатно Насладете се Raging Rhino Casino slot games Play for Totally free spins on Cash Spin free and no Put Играйте напълно безплатно Портове най-голям без депозит goldbet онлайн без регистрация كازينو Betser المحلي يقدم 50 لفة مجانية بنسبة 100% Raging Rhino 500 free spins mymmys gold Totally free Ports Gamble Online Slot machines Erreichbar Casinos Antique Riches echtes Geld ohne deutsche Lizenz 2026: Traktandum 15 inoffizieller mitarbeiter Probe Smarter Ai-Telefonassistent für jedes Praxen, MVZ & Kliniken I flowers $ 1 Kaution medflex 100 Freispiele bloß Einzahlung: Slot -Spiele Antique Riches Neue Angebote inoffizieller mitarbeiter Sechster monat des jahres Online Game of Thrones Spielautomat Spielbank Einzahlungen über PayPal Casino Uden Rofus Oplev Spilfrihed Step-by-Step Guide to the DuoBetz Casino Registration Process Decandrol Dosaggio: Guida Completa per un Uso Sicuro ed Efficace Zahraniční kasina pro Čechy Oblíbená volba pro online hráče Navigating taya365 feels like flipping open a well-worn, intuitive map rather than wrestling with a new gadget Test Post Created FIFA World Cup insights: compare Bitcoin betting odds at leading casinos Unleashing Entertainment The DexSport Casino Platform De Bedste Udenlandske Bookmakere En Guide til Online Spil Provision Angeschlossen Casinos 2026 Exklusive Spielbank Echtes Geld Online Casino NO Einzahlung verde casino Boni inside Deutschland Beste Mobile Casinos & Spielotheken Online keno GGL Slots 2026 Mobile Casinos 2026: black hawk Slot Free Spins Beste Mobilfunktelefon Casinos Deutschland Nové online kasino 2026 Trendy, nabídky a co očekávat Casinos En internet con manga larga Dinero Real referente a España 2026 Funciona regalado en Big Bass Halloween 2 sobre modo demo Juegos online en México casino Brazino777 Slots Maquinitas Tragamonedas online Hygetropin 100 IU in njegova vloga v kulturizmu Your essential roadmap to the most trusted online casinos in Canada for new players Saltando corrente apertura, il giocatore potrebbe calare la opzione di prendere il gratifica FIFA World Cup official site: explore secure access and exciting game options Casinò Non AAMS Online 2026: scopri la varietà di giochi e le opzioni di نصائح للمراهنات: كيفية استخدام USDT betting في كأس العالم 2026 Step into the world of Dexsport: your guide to seamless casino play Esistono premio privo di base addirittura a chi preferisce il bazzecola del bingo