You are here

class SyndicationParser in Feeds 8.3

Defines an RSS and Atom feed parser.

Plugin annotation


@FeedsParser(
  id = "syndication",
  title = @Translation("RSS/Atom"),
  description = @Translation("Default parser for RSS, Atom and RDF feeds.")
)

Hierarchy

Expanded class hierarchy of SyndicationParser

1 file declares its use of SyndicationParser
SyndicationParserTest.php in tests/src/Unit/Feeds/Parser/SyndicationParserTest.php

File

src/Feeds/Parser/SyndicationParser.php, line 25

Namespace

Drupal\feeds\Feeds\Parser
View source
class SyndicationParser extends PluginBase implements ParserInterface {

  /**
   * {@inheritdoc}
   */
  public function parse(FeedInterface $feed, FetcherResultInterface $fetcher_result, StateInterface $state) {
    $result = new ParserResult();
    Reader::setExtensionManager(\Drupal::service('feed.bridge.reader'));
    Reader::registerExtension('GeoRSS');
    $raw = $fetcher_result
      ->getRaw();
    if (!strlen(trim($raw))) {
      throw new EmptyFeedException();
    }
    try {
      $channel = Reader::importString($raw);
    } catch (ExceptionInterface $e) {
      $args = [
        '%site' => $feed
          ->label(),
        '%error' => trim($e
          ->getMessage()),
      ];
      throw new \RuntimeException($this
        ->t('The feed from %site seems to be broken because of error "%error".', $args));
    }
    foreach ($channel as $delta => $entry) {
      $item = new SyndicationItem();

      // Move the values to an array as expected by processors.
      $item
        ->set('title', $entry
        ->getTitle())
        ->set('guid', $entry
        ->getId())
        ->set('url', $entry
        ->getLink())
        ->set('guid', $entry
        ->getId())
        ->set('url', $entry
        ->getLink())
        ->set('description', $entry
        ->getDescription())
        ->set('content', $entry
        ->getContent())
        ->set('tags', $entry
        ->getCategories()
        ->getValues())
        ->set('feed_title', $channel
        ->getTitle())
        ->set('feed_description', $channel
        ->getDescription())
        ->set('feed_url', $channel
        ->getLink());
      if ($image = $channel
        ->getImage()) {
        $item
          ->set('feed_image_uri', $image['uri']);
      }
      if ($enclosure = $entry
        ->getEnclosure()) {
        $item
          ->set('enclosures', [
          rawurldecode($enclosure->url),
        ]);
      }
      if ($author = $entry
        ->getAuthor()) {
        $author += [
          'name' => '',
          'email' => '',
        ];
        $item
          ->set('author_name', $author['name'])
          ->set('author_email', $author['email']);
      }
      if ($date = $entry
        ->getDateCreated()) {
        $item
          ->set('timestamp', $date
          ->getTimestamp());
      }
      if ($date = $entry
        ->getDateModified()) {
        $item
          ->set('updated', $date
          ->getTimestamp());
      }
      if ($point = $entry
        ->getGeoPoint()) {
        $item
          ->set('georss_lat', $point['lat'])
          ->set('georss_lon', $point['lon']);
      }
      $result
        ->addItem($item);
    }
    return $result;
  }

  /**
   * {@inheritdoc}
   */
  public function getMappingSources() {
    return [
      'feed_title' => [
        'label' => $this
          ->t('Feed title'),
        'description' => $this
          ->t('Title of the feed.'),
      ],
      'feed_description' => [
        'label' => $this
          ->t('Feed description'),
        'description' => $this
          ->t('Description of the feed.'),
      ],
      'feed_image_uri' => [
        'label' => $this
          ->t('Feed image'),
        'description' => $this
          ->t('The URL of the feed image.'),
      ],
      'feed_url' => [
        'label' => $this
          ->t('Feed URL (link)'),
        'description' => $this
          ->t('URL of the feed.'),
      ],
      'title' => [
        'label' => $this
          ->t('Title'),
        'description' => $this
          ->t('Title of the feed item.'),
        'suggestions' => [
          'targets' => [
            'subject',
            'title',
            'label',
            'name',
          ],
          'types' => [
            'field_item:text' => [],
          ],
        ],
      ],
      'content' => [
        'label' => $this
          ->t('Content'),
        'description' => $this
          ->t('Content of the feed item.'),
        'suggested' => [
          'body',
        ],
        'suggestions' => [
          'targets' => [
            'body',
          ],
          'types' => [
            'field_item:text_with_summary' => [],
          ],
        ],
      ],
      'description' => [
        'label' => $this
          ->t('Description'),
        'description' => $this
          ->t('Description of the feed item.'),
        'suggested' => [
          'body',
        ],
        'suggestions' => [
          'targets' => [
            'body',
          ],
          'types' => [
            'field_item:text_with_summary' => [],
          ],
        ],
      ],
      'author_name' => [
        'label' => $this
          ->t('Author name'),
        'description' => $this
          ->t("Name of the feed item's author."),
        'suggestions' => [
          'types' => [
            'entity_reference_field' => [
              'target_type' => 'user',
            ],
          ],
        ],
      ],
      'author_email' => [
        'label' => $this
          ->t('Author email'),
        'description' => $this
          ->t("Name of the feed item's email address."),
      ],
      'timestamp' => [
        'label' => $this
          ->t('Published date'),
        'description' => $this
          ->t('Published date as UNIX time GMT of the feed item.'),
        'suggestions' => [
          'targets' => [
            'created',
          ],
        ],
      ],
      'updated' => [
        'label' => $this
          ->t('Updated date'),
        'description' => $this
          ->t('Updated date as UNIX time GMT of the feed item.'),
        'suggestions' => [
          'targets' => [
            'changed',
          ],
        ],
      ],
      'url' => [
        'label' => $this
          ->t('Item URL (link)'),
        'description' => $this
          ->t('URL of the feed item.'),
        'suggestions' => [
          'targets' => [
            'url',
          ],
        ],
      ],
      'guid' => [
        'label' => $this
          ->t('Item GUID'),
        'description' => $this
          ->t('Global Unique Identifier of the feed item.'),
        'suggestions' => [
          'targets' => [
            'guid',
          ],
        ],
      ],
      'tags' => [
        'label' => $this
          ->t('Categories'),
        'description' => $this
          ->t('An array of categories that have been assigned to the feed item.'),
        'suggestions' => [
          'targets' => [
            'field_tags',
          ],
          'types' => [
            'field_item:taxonomy_term_reference' => [],
          ],
        ],
      ],
      'georss_lat' => [
        'label' => $this
          ->t('Item latitude'),
        'description' => $this
          ->t('The feed item latitude.'),
      ],
      'georss_lon' => [
        'label' => $this
          ->t('Item longitude'),
        'description' => $this
          ->t('The feed item longitude.'),
      ],
      'enclosures' => [
        'label' => $this
          ->t('Enclosures'),
        'description' => $this
          ->t('A list of enclosures attached to the feed item.'),
        'suggestions' => [
          'types' => [
            'field_item:file' => [],
          ],
        ],
      ],
    ];
  }

}

Members

Namesort descending Modifiers Type Description Overrides
DependencySerializationTrait::$_entityStorages protected property An array of entity type IDs keyed by the property name of their storages.
DependencySerializationTrait::$_serviceIds protected property An array of service IDs keyed by property name used for serialization.
DependencySerializationTrait::__sleep public function 1
DependencySerializationTrait::__wakeup public function 2
DependencyTrait::$dependencies protected property The object's dependencies.
DependencyTrait::addDependencies protected function Adds multiple dependencies.
DependencyTrait::addDependency protected function Adds a dependency.
MessengerTrait::$messenger protected property The messenger. 29
MessengerTrait::messenger public function Gets the messenger. 29
MessengerTrait::setMessenger public function Sets the messenger.
PluginBase::$configuration protected property Configuration information passed into the plugin. 1
PluginBase::$feedType protected property The importer this plugin is working for.
PluginBase::$linkGenerator protected property The link generator.
PluginBase::$pluginDefinition protected property The plugin implementation definition. 1
PluginBase::$pluginId protected property The plugin_id.
PluginBase::$urlGenerator protected property The url generator.
PluginBase::calculateDependencies public function Calculates dependencies for the configured plugin. Overrides DependentPluginInterface::calculateDependencies 2
PluginBase::container private function Returns the service container.
PluginBase::defaultConfiguration public function Gets default configuration for this plugin. Overrides ConfigurableInterface::defaultConfiguration 7
PluginBase::defaultFeedConfiguration public function Returns default feed configuration. Overrides FeedsPluginInterface::defaultFeedConfiguration 3
PluginBase::DERIVATIVE_SEPARATOR constant A string which is used to separate base plugin IDs from the derivative ID.
PluginBase::getBaseId public function Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface::getBaseId
PluginBase::getConfiguration public function Gets this plugin's configuration. Overrides ConfigurableInterface::getConfiguration
PluginBase::getDerivativeId public function Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface::getDerivativeId
PluginBase::getPluginDefinition public function Gets the definition of the plugin implementation. Overrides PluginInspectionInterface::getPluginDefinition 3
PluginBase::getPluginId public function Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface::getPluginId
PluginBase::isConfigurable public function Determines if the plugin is configurable.
PluginBase::l protected function Renders a link to a route given a route name and its parameters.
PluginBase::linkGenerator protected function Returns the link generator service.
PluginBase::onFeedDeleteMultiple public function A feed is being deleted. 3
PluginBase::onFeedSave public function A feed is being saved.
PluginBase::onFeedTypeDelete public function The feed type is being deleted. 1
PluginBase::onFeedTypeSave public function The feed type is being saved. 1
PluginBase::pluginType public function Returns the type of plugin. Overrides FeedsPluginInterface::pluginType
PluginBase::setConfiguration public function Sets the configuration for this plugin instance. Overrides ConfigurableInterface::setConfiguration 1
PluginBase::url protected function Generates a URL or path for a specific route based on the given parameters.
PluginBase::urlGenerator protected function Returns the URL generator service.
PluginBase::__construct public function Constructs a PluginBase object. Overrides PluginBase::__construct 4
StringTranslationTrait::$stringTranslation protected property The string translation service. 1
StringTranslationTrait::formatPlural protected function Formats a string containing a count of items.
StringTranslationTrait::getNumberOfPlurals protected function Returns the number of plurals supported by a given language.
StringTranslationTrait::getStringTranslation protected function Gets the string translation service.
StringTranslationTrait::setStringTranslation public function Sets the string translation service to use. 2
StringTranslationTrait::t protected function Translates a string to the current language or to a given language.
SyndicationParser::getMappingSources public function Declare the possible mapping sources that this parser produces. Overrides ParserInterface::getMappingSources
SyndicationParser::parse public function Parses content returned by fetcher. Overrides ParserInterface::parse