/** * 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 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 HighSpin Casino im Detail Meine Bewertung von UI und Ladezeiten Тестирование инверторов Deye Sun 06K Оборудование для солнечных станций Nejpopulárnější kasinové hry a jejich tajemství Ginja Casino Bonus Offers My Profitability Analysis and Wagering Strategy Ultimate Guide on How to Repost on Instagram Tips and Tricks Discover the Exciting Features of DK88 Singapore Mi experiencia real calculando el retorno de bonos en Zombillion Casino Free Gambling Establishment Games Online: The Ultimate Guide The Rise of Casinos Not on Gamstop Is MisterX Casino Legit A Comprehensive Overview MK2866 10 10: Učinkovit dodatek za kulturistiko Step-by-Step Guide to BetPanda Casino Registration Bonuszahlung: aztec gems deluxe Slot großer Sieg Steuer, Ausschüttung & Auswertung abgesprochen 5 Euroletten Spielbank Provision abzüglich Einzahlung: No Bestes Online -Casino Ultimate Hot Frankierung Boni 2026 $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 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 SpinChester Casino Partners with Playtech to Introduce New Jackpot Slots 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 Experience the Thrill of Betzino Casino & Sportsbook 217001739