Agregar miniatura a WordPress RSS con otra etiqueta

5 minutos de lectura

Estoy usando un WordPress RSS para usar en mi proyecto de iOS. El feed no tiene enlaces en miniatura, así que busqué y encontré este código para agregar enlaces en miniatura al feed.

/* include thumbnail in RSS feed */
function add_thumb_to_RSS($content) {
   global $post;
   if ( has_post_thumbnail( $post->ID ) ){
      $content="" . get_the_post_thumbnail( $post->ID, 'thumbnail' ) . '' . $content;
   }
   return $content;
}
add_filter('the_excerpt_rss', 'add_thumb_to_RSS');
add_filter('the_content_feed', 'add_thumb_to_RSS')

Este código agrega el enlace de la imagen en el feed, pero lo agrega como código html al comienzo de la etiqueta de descripción de esta manera:

<description>
<![CDATA[
<img width="150" height="150" src="http://www.ipadia.co/wp-content/uploads/2012/02/sayfada-bul-150x150.png" class="attachment-thumbnail wp-post-image" alt="sayfada bul" title="sayfada bul" />Some text some text Some text some text Some text some text Some text some text Some text some text Some text some text ....
]]>
</description>

Quiero agregar un enlace de imagen con otra etiqueta como <image> o <thumb> the link </thumb>. Entonces puedo analizar esto más fácilmente.

¿Cómo puedo hacer esto? Gracias por adelantado.

Finalmente lo resolví 🙂 Cambié la función que publiqué antes. La nueva función es esta:

add_action('rss2_item', function(){
  global $post;

  $output="";
  $thumbnail_ID = get_post_thumbnail_id( $post->ID );
  $thumbnail = wp_get_attachment_image_src($thumbnail_ID, 'thumbnail');
  $output .= '<post-thumbnail>';
    $output .= '<url>'. $thumbnail[0] .'</url>';
    $output .= '<width>'. $thumbnail[1] .'</width>';
    $output .= '<height>'. $thumbnail[2] .'</height>';
    $output .= '</post-thumbnail>';

  echo $output;
});

Esto da el enlace de la imagen en la nueva etiqueta. <post-thumbnail> como yo quería

avatar de usuario
Mario Bellart

Hay 2 funciones en wordpress que te pueden ayudar de una manera muy fácil, prueba esto:

(int) $id = get_post_thumbnail_id($post->ID);
$url = wp_get_attachment_url( $id ); 

Editar:

Para modificar el feed puedes consultar esta documentación

Una opción fácil es modificar directamente la plantilla del feed, un ejemplo:

en el archivo wp-includes/feed-rss2.php (tenga en cuenta que puede modificar otra plantilla de fuente como “feed-rss.php”, “feed-atom.php”) puede agregar la nueva etiqueta:

echo '<?xml version="1.0" encoding="'.get_option('blog_charset').'"?'.'>'; ?>

<rss version="2.0"
    xmlns:content="http://purl.org/rss/1.0/modules/content/"
    xmlns:wfw="http://wellformedweb.org/CommentAPI/"
    xmlns:dc="http://purl.org/dc/elements/1.1/"
    xmlns:atom="http://www.w3.org/2005/Atom"
    xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
    xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
    <?php do_action('rss2_ns'); ?>
>

<channel>
    <title><?php bloginfo_rss('name'); wp_title_rss(); ?></title>
    <atom:link href="https://stackoverflow.com/questions/14257343/<?php self_link(); ?>" rel="self" type="application/rss+xml" />
    <link><?php bloginfo_rss('url') ?></link>
    <description><?php bloginfo_rss("description") ?></description>
    <lastBuildDate><?php echo mysql2date('D, d M Y H:i:s +0000', get_lastpostmodified('GMT'), false); ?></lastBuildDate>
    <language><?php bloginfo_rss( 'language' ); ?></language>
    <sy:updatePeriod><?php echo apply_filters( 'rss_update_period', 'hourly' ); ?></sy:updatePeriod>
    <sy:updateFrequency><?php echo apply_filters( 'rss_update_frequency', '1' ); ?></sy:updateFrequency>
    <?php do_action('rss2_head'); ?>
    <?php while( have_posts()) : the_post(); ?>
    <item>
        <title><?php the_title_rss() ?></title>
        <link><?php the_permalink_rss() ?></link>
        <comments><?php comments_link_feed(); ?></comments>
        <pubDate><?php echo mysql2date('D, d M Y H:i:s +0000', get_post_time('Y-m-d H:i:s', true), false); ?></pubDate>
        <dc:creator><?php the_author() ?></dc:creator>
        <?php the_category_rss('rss2') ?>
        <?php 
            //start modified code to add tag with post thumb url
            (int) $id = get_post_thumbnail_id($post->ID);
            $thumb_url = wp_get_attachment_url( $id ); 
        ?>
        <thumb><?php echo $thumb_url;?></thumb>
            <?php //end modified code to add tag with post thumb url ?>
        <guid isPermaLink="false"><?php the_guid(); ?></guid>
<?php if (get_option('rss_use_excerpt')) : ?>
        <description><![CDATA[<?php the_excerpt_rss() ?>]]></description>
<?php else : ?>
        <description><![CDATA[<?php the_excerpt_rss() ?>]]></description>
    <?php if ( strlen( $post->post_content ) > 0 ) : ?>
        <content:encoded><![CDATA[<?php the_content_feed('rss2') ?>]]></content:encoded>
    <?php else : ?>
        <content:encoded><![CDATA[<?php the_excerpt_rss() ?>]]></content:encoded>
    <?php endif; ?>
<?php endif; ?>
        <wfw:commentRss><?php echo esc_url( get_post_comments_feed_link(null, 'rss2') ); ?></wfw:commentRss>
        <slash:comments><?php echo get_comments_number(); ?></slash:comments>
<?php rss_enclosure(); ?>
    <?php do_action('rss2_item'); ?>
    </item>
    <?php endwhile; ?>
</channel>
</rss>

  • Gracias por tu buena respuesta, te lo agradezco. Lo resolví con un método corto y lo publiqué como respuesta. Gracias de nuevo Mario.

    – alper_k

    10 de enero de 2013 a las 12:52

Hay un complemento para hacer esto para WordPress que agrega la imagen como un recinto.

https://github.com/kasparsd/feed-image-enclosure/blob/master/feed-image-enclosure.php

¿Ha sido útil esta solución?