/** * 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 BigWins Casino & Sportsbook Your Ultimate Gaming Destination -546521355 How Dazard Casino Maintains Player Retention Through Targeted Game Aggregator Shifts Discover the Ultimate Gaming Experience at Playhub Casino Online DrückGlück ️ Offizielles DrückGlück Casino Slot game of thrones as part of Teutonia DrückGlück Erfahrungen: Slot -Spiele Queens Day Tilt Diese Online Spielhölle inoffizieller mitarbeiter Erprobung 2026 20 Freispiele bloß Einzahlung Tagesordnungspunkt Play Black Diamond Casino Casinos Juni 2026 Nachfolgende besten Kasino Freispiele bloß Slot wild warriors Einzahlung im Sechster monat des jahres 2026! Discover the Best Online Slots and Casinos at slotsandcasino-us.com 115380067 Review de Entretenimiento Juega gamomat tragamonedas de juego en línea de Tragaperras Jimi Hendrix sobre NetEnt 2026 Jack willy wonka ofertas And The Beanstalk Netent Slot Machine Review Soluciona Sin cargo Online Servidoras CS ningún seis Official Chile Los Cómo jugar tragamonedas superiores servidores Counter-Strike 1.seis Understanding responsible gambling A guide to safe practices with Shikaka Best Casino Games Die besten Online-Casinos 2026: Eine umfassende Übersicht Gamification-Trends in Online-Casinos: Die Zukunft des Glücksspiels The Best Neteller Gambling Establishments Online: A Comprehensive Overview The Rise of Online Casino Sites: A Comprehensive Overview Exploring Jammy Jack Casino Game Glitches: Causes and Solutions Prihodnost iger na srečo Kako se bo trg spremenil v naslednjih letih Wild Joker Casino License: A Comprehensive Review SpinChester Casino gezien door de ogen van een iGaming veteraan Votre Checklist pour un Jeu de Casino Réussi au Club Player Casino Établir un budget efficace pour vos visites au casino SpinChester Casino Partners with Playtech to Introduce New Jackpot Slots Winspark: Frode o Verità? Una Analisi Approfondita Intercasino einflussreicher Link Bonus Quelltext & Gutschein 2026 Willkommensbonus InterCasino Untersuchung 2026 Berechnung + 900 Freezing Classics Slotspiel für Geld Maklercourtage + Freispiele Jabeh de ️ Erreichbar chicago bang bang Casino Casinos Deutschland 347 Auf jeden fall 2026 Саѕіnοѕ mіt mr bet Casino -Bonus Іnѕtаdеbіt ΥΕΑR Unser 8 besten Angeschlossen-Casinos Deutschlands Casino multibanco 2026 im Vergleich Casino book of ra deluxe free download game pc Maklercourtage bloß Einzahlung Juno 2026 Beste Echtgeld Online bastet and cats Spielautomat Casinos: Ganz in einer Casino Verzeichnis【2026】 Beste Erreichbar Casinos 2026 Kasino insta Bestes Durchgang 220+ geprüfte Casinos im Konvention MR BET Login Kết quả bóng đá trực tuyến hôm nay Beste pay pal Sizzling Hot Verbunden Casinos Brd 2026: Meine Erfahrungen Beste Erreichbar Casinos Viking Runecraft Slot Deutschland Sechster monat des jahres 2026 Ho Ho Ho Casino -Einzahlung comgate » Kostenlos Aufführen 2026 HighSpin Casino im Detail Meine Bewertung von UI und Ladezeiten Anmeldung, Maklercourtage clash of pirates Online -Slot 50% Bis zu 500 Angeschlossen rooks revenge Slot -Spiel Spielbank Teutonia Spielsaal Erreichbar Spielen EuroGrand Casino golden book Casino Untersuchung 2026 Allemal & Vertrauenswürdig? The Changing Impact of Technology on the Casino Industry and Future Outlook Experience the Thrill of Betzino Casino & Sportsbook 217001739 Unlock Exciting 120 Free Spins for Real Money 25 Free Spins No Deposit – Ontdek de Voordelen en Aanbiedingen Navigating responsible gambling essential practices for players Vital Pieces Of 10 Лучших Казино Онлайн 2026 DrückGlück Provision bloß Einzahlung: Beste Secret Forest Slot online Angebote & Freispiele Jambobet Your Ultimate Sports Betting Destination Тестирование инверторов Deye Sun 06K Оборудование для солнечных станций Nejpopulárnější kasinové hry a jejich tajemství