You are here

class Feed in Zircon Profile 8.0

Same name in this branch
  1. 8.0 vendor/zendframework/zend-feed/src/Writer/Feed.php \Zend\Feed\Writer\Feed
  2. 8.0 core/modules/aggregator/src/Entity/Feed.php \Drupal\aggregator\Entity\Feed
  3. 8.0 vendor/zendframework/zend-feed/src/Reader/Extension/Syndication/Feed.php \Zend\Feed\Reader\Extension\Syndication\Feed
  4. 8.0 vendor/zendframework/zend-feed/src/Reader/Extension/Atom/Feed.php \Zend\Feed\Reader\Extension\Atom\Feed
  5. 8.0 vendor/zendframework/zend-feed/src/Reader/Extension/Podcast/Feed.php \Zend\Feed\Reader\Extension\Podcast\Feed
  6. 8.0 vendor/zendframework/zend-feed/src/Reader/Extension/DublinCore/Feed.php \Zend\Feed\Reader\Extension\DublinCore\Feed
  7. 8.0 vendor/zendframework/zend-feed/src/Reader/Extension/CreativeCommons/Feed.php \Zend\Feed\Reader\Extension\CreativeCommons\Feed
  8. 8.0 vendor/zendframework/zend-feed/src/Writer/Extension/ITunes/Feed.php \Zend\Feed\Writer\Extension\ITunes\Feed
  9. 8.0 core/modules/views/src/Plugin/views/display/Feed.php \Drupal\views\Plugin\views\display\Feed
  10. 8.0 vendor/zendframework/zend-feed/src/Writer/Extension/Atom/Renderer/Feed.php \Zend\Feed\Writer\Extension\Atom\Renderer\Feed
  11. 8.0 vendor/zendframework/zend-feed/src/Writer/Extension/DublinCore/Renderer/Feed.php \Zend\Feed\Writer\Extension\DublinCore\Renderer\Feed
  12. 8.0 vendor/zendframework/zend-feed/src/Writer/Extension/ITunes/Renderer/Feed.php \Zend\Feed\Writer\Extension\ITunes\Renderer\Feed
Same name and namespace in other branches
  1. 8 vendor/zendframework/zend-feed/src/Writer/Extension/Atom/Renderer/Feed.php \Zend\Feed\Writer\Extension\Atom\Renderer\Feed

Hierarchy

  • class \Zend\Feed\Writer\Extension\Atom\Renderer\Feed extends \Extension\AbstractRenderer

Expanded class hierarchy of Feed

19 string references to 'Feed'
aggregator.schema.yml in core/modules/aggregator/config/schema/aggregator.schema.yml
core/modules/aggregator/config/schema/aggregator.schema.yml
core.services.yml in core/core.services.yml
core/core.services.yml
ExtensionPluginManager::validatePlugin in vendor/zendframework/zend-feed/src/Writer/ExtensionPluginManager.php
Validate the plugin
PreviewTest::testPreviewUI in core/modules/views_ui/src/Tests/PreviewTest.php
Tests arguments in the preview form.
views.view.aggregator_rss_feed.yml in core/modules/aggregator/config/optional/views.view.aggregator_rss_feed.yml
core/modules/aggregator/config/optional/views.view.aggregator_rss_feed.yml

... See full list

1 service uses Feed
feed.writer.atomrendererfeed in core/core.services.yml
Zend\Feed\Writer\Extension\Atom\Renderer\Feed

File

vendor/zendframework/zend-feed/src/Writer/Extension/Atom/Renderer/Feed.php, line 18

Namespace

Zend\Feed\Writer\Extension\Atom\Renderer
View source
class Feed extends Extension\AbstractRenderer {

  /**
   * Set to TRUE if a rendering method actually renders something. This
   * is used to prevent premature appending of a XML namespace declaration
   * until an element which requires it is actually appended.
   *
   * @var bool
   */
  protected $called = false;

  /**
   * Render feed
   *
   * @return void
   */
  public function render() {

    /**
     * RSS 2.0 only. Used mainly to include Atom links and
     * Pubsubhubbub Hub endpoint URIs under the Atom namespace
     */
    if (strtolower($this
      ->getType()) == 'atom') {
      return;
    }
    $this
      ->_setFeedLinks($this->dom, $this->base);
    $this
      ->_setHubs($this->dom, $this->base);
    if ($this->called) {
      $this
        ->_appendNamespaces();
    }
  }

  /**
   * Append namespaces to root element of feed
   *
   * @return void
   */
  protected function _appendNamespaces() {
    $this
      ->getRootElement()
      ->setAttribute('xmlns:atom', 'http://www.w3.org/2005/Atom');
  }

  /**
   * Set feed link elements
   *
   * @param  DOMDocument $dom
   * @param  DOMElement $root
   * @return void
   */
  protected function _setFeedLinks(DOMDocument $dom, DOMElement $root) {
    $flinks = $this
      ->getDataContainer()
      ->getFeedLinks();
    if (!$flinks || empty($flinks)) {
      return;
    }
    foreach ($flinks as $type => $href) {
      if (strtolower($type) == $this
        ->getType()) {

        // issue 2605
        $mime = 'application/' . strtolower($type) . '+xml';
        $flink = $dom
          ->createElement('atom:link');
        $root
          ->appendChild($flink);
        $flink
          ->setAttribute('rel', 'self');
        $flink
          ->setAttribute('type', $mime);
        $flink
          ->setAttribute('href', $href);
      }
    }
    $this->called = true;
  }

  /**
   * Set PuSH hubs
   *
   * @param  DOMDocument $dom
   * @param  DOMElement $root
   * @return void
   */
  protected function _setHubs(DOMDocument $dom, DOMElement $root) {
    $hubs = $this
      ->getDataContainer()
      ->getHubs();
    if (!$hubs || empty($hubs)) {
      return;
    }
    foreach ($hubs as $hubUrl) {
      $hub = $dom
        ->createElement('atom:link');
      $hub
        ->setAttribute('rel', 'hub');
      $hub
        ->setAttribute('href', $hubUrl);
      $root
        ->appendChild($hub);
    }
    $this->called = true;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
Feed::$called protected property Set to TRUE if a rendering method actually renders something. This is used to prevent premature appending of a XML namespace declaration until an element which requires it is actually appended.
Feed::render public function Render feed
Feed::_appendNamespaces protected function Append namespaces to root element of feed
Feed::_setFeedLinks protected function Set feed link elements
Feed::_setHubs protected function Set PuSH hubs