/** * 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 $1 Put Casino Nz 2022 ᐈ Western slot machines Better step 1 Money Put Casino 50+ Greatest Commission Online casinos Inside the United kingdom And Coyote Cash $1 deposit you will Worldwide Is MisterX Casino Legit A Comprehensive Overview Bonuszahlung: aztec gems deluxe Slot großer Sieg Steuer, Ausschüttung & Auswertung abgesprochen MK2866 10 10: Učinkovit dodatek za kulturistiko Step-by-Step Guide to BetPanda Casino Registration 5 Euroletten Spielbank Provision abzüglich Einzahlung: No Bestes Online -Casino Ultimate Hot Frankierung Boni 2026 Hellspin Big Bad Wolf New Version online slot Gambling enterprise A Look at the Top Slots at Casinos Finest On the internet Bingo casino Europa no deposit Web sites & Game Inside the 2022 Las juegos sobre slots quickspin juegos de casino con manga larga recursos positivo son una argucia de números, no de fortuna Freispiele abzüglich Einzahlung 2026 Fix 100 kostenlose Spins keine Einzahlung gladiator of rome verfügbar within DE Spielbank Bonus abzüglich Einzahlung neu Neue No temple of luxor Slot Casino -Sites Anzahlung Maklercourtage Codes Eurogrand Casino Probe & Prämie Angebote gladiator arena Spiel June 2026 The Benefits of Copper Peptide GHK-Cu for Athletes Neteller Online Casinos spinfest Login 2024 Angeschlossen Kasino Golden Goddess $ 1 Kaution Über Handyrechnung Retournieren Teutonia 1 Einzahlung Per Handyrechnung Casino mit Google Play Eur Casinos Navegar sin complicaciones en los mejores casinos online en Colombia: diseño pensado para todos Test Post Created Discover the Benefits of Low Deposit Casinos Online 19594880 Apple Pay Casinos in the UK A New Era of Secure Transactions Gomblingo Die aufregende Welt des Online-Glücksspiels -288693042 Navigating dafabet’s interface feels surprisingly intuitive from the first click Test Post Created Pin Up casino: top juegos para disfrutar y ganar en 2026 Avantages Incontournables du Peg Mgf 2 pour Athlètes The Rise of NBAJIBet Revolutionizing Sports Betting The Most Effective Neteller Gambling Establishments Online: A Guide to Safe and Secure Betting Online Casino Provision 2026 unser Hey Sushi Casino besten Aktionen Unser besten Freispiele abzüglich Einzahlung 2026 erste Seite Aktualisiert právní předpisy a regulace v oblasti kasin co byste měli vědět o Gransino casino La psicología detrás del juego ¿por qué arriesgamos tanto Exploring FatBet Casino & Sportsbook Your Ultimate Gaming Destination Die besten Casinos der Welt entdecken Ein ultimativer Leitfaden für Spieler Unlocking the Thrills of 1red Casino Free Spins Descifrando la mala calidad de los juegos en los casinos en línea F7 Casino Data Privacy: Understanding the Importance of Secure Gaming Erlebe das authentische Gefühl eines Live-Dealers im Casino Stratégies de jeux de casino Vegaz pour maximiser vos gains Prism Casino Crypto-Bonus: Alles, was Sie wissen müssen Experience the Thrill of Online Gambling at Betblast Casino Estrategias Ganadoras en Dendera Casino: Consejos y Trucos para Éxito Lohnt es sich bei Crazy Tower Casino nach der Arbeit zu spielen The Rise of Casinos Not on Gamstop Unlocking Rewards: Checklist for Getting Bonuses at Rufus Casino Infografía: Cómo funciona el casino Betcave Crazy Tower Casino biedt nu directe uitbetalingen aan voor al je winsten Baccarat für Anfänger: Ein umfassender Leitfaden Free Gambling Establishment Games Online: The Ultimate Guide