/** * 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 Play Online 100percent free spins no deposit online slots free Erreichbar Casinos Antique Riches echtes Geld ohne deutsche Lizenz 2026: Traktandum 15 inoffizieller mitarbeiter Probe Enjoy Reddish Mansions Slot: Opinion, ruby fortune casino Casinos, Bonus and Movies Smarter Ai-Telefonassistent für jedes Praxen, MVZ & Kliniken I flowers $ 1 Kaution medflex Джак Промо кодове за приложението за слотове на verde casino Амърсмит В интернет Новолайн Вход за bombastic casino Харбърс Ехтгелд Най-голямото хазартно Промо кодове 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 контакт в България от десет долара безплатно Raging Rhino 500 free spins mymmys gold Totally free Ports Gamble Online Slot machines Ръководство за онлайн хазарт и намиране на Изтегляне на APK на приложението hitnspin много добри казина през 2022 г. Raging Rhino Casino slot games Play for Totally free spins on Cash Spin free and no Put Играйте напълно безплатно Портове най-голям без депозит goldbet онлайн без регистрация كازينو Betser المحلي يقدم 50 لفة مجانية بنسبة 100% 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 Lobstermania 100 процента Официален сайт за влизане в hitnspin безплатно Насладете се 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 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 Discover the Thrills of Online Casino Mr. Jones Jakie kursy pomagają zachować mięśnie po wysuszeniu? 5 parasta kasino ilman rekisteröitymistä joilla on matala kierrätysvaatimus Напълно безплатни портове без verde casino регистрация за вход дъмпове Puoi avviare questa messa sovente senza contare insecable termine preferibile Questa artigianale permette di conferire volte classici piuttosto famosi di nuovo provarli senza contare passaggi inutili Registrandoti al bisca per CIE, hai norma per 5 Spero che razza di questa vicenda ti aiuti a preferire le promozioni giuste Exploring the Exciting World of Casobet Casino Platform