2013-04-04 23:34:07 -04:00
|
|
|
<?php
|
|
|
|
|
2014-12-23 21:28:26 -05:00
|
|
|
namespace PicoFeed\Parser;
|
2014-05-20 14:20:27 -04:00
|
|
|
|
|
|
|
use SimpleXMLElement;
|
2015-07-19 11:19:26 -04:00
|
|
|
use PicoFeed\Filter\Filter;
|
2014-05-20 14:20:27 -04:00
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* RSS 1.0 parser.
|
2014-05-20 14:20:27 -04:00
|
|
|
*
|
2016-07-28 21:14:51 -04:00
|
|
|
* @package PicoFeed\Parser
|
2014-05-20 14:20:27 -04:00
|
|
|
* @author Frederic Guillot
|
|
|
|
*/
|
2015-07-19 11:19:26 -04:00
|
|
|
class Rss10 extends Parser
|
2013-04-04 23:34:07 -04:00
|
|
|
{
|
2015-07-19 11:19:26 -04:00
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Supported namespaces.
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
protected $namespaces = array(
|
|
|
|
'rss' => 'http://purl.org/rss/1.0/',
|
|
|
|
'dc' => 'http://purl.org/dc/elements/1.1/',
|
|
|
|
'content' => 'http://purl.org/rss/1.0/modules/content/',
|
|
|
|
'feedburner' => 'http://rssnamespace.org/feedburner/ext/1.0',
|
|
|
|
);
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Get the path to the items XML tree.
|
|
|
|
*
|
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
2014-05-20 14:20:27 -04:00
|
|
|
*
|
|
|
|
* @return SimpleXMLElement
|
|
|
|
*/
|
|
|
|
public function getItemsTree(SimpleXMLElement $xml)
|
2013-04-04 23:34:07 -04:00
|
|
|
{
|
2015-07-19 11:19:26 -04:00
|
|
|
return XmlParser::getXPathResult($xml, 'rss:item', $this->namespaces)
|
2016-04-17 19:34:54 -04:00
|
|
|
?: XmlParser::getXPathResult($xml, 'item')
|
|
|
|
?: $xml->item;
|
2014-05-20 14:20:27 -04:00
|
|
|
}
|
2013-04-04 23:34:07 -04:00
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the feed url.
|
2014-05-20 14:20:27 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
2015-07-19 11:19:26 -04:00
|
|
|
public function findFeedUrl(SimpleXMLElement $xml, Feed $feed)
|
2014-05-20 14:20:27 -04:00
|
|
|
{
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setFeedUrl('');
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the site url.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findSiteUrl(SimpleXMLElement $xml, Feed $feed)
|
|
|
|
{
|
2016-04-17 19:34:54 -04:00
|
|
|
$value = XmlParser::getXPathResult($xml, 'rss:channel/rss:link', $this->namespaces)
|
|
|
|
?: XmlParser::getXPathResult($xml, 'channel/link')
|
|
|
|
?: $xml->channel->link;
|
2015-07-19 11:19:26 -04:00
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setSiteUrl(XmlParser::getValue($value));
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the feed description.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findFeedDescription(SimpleXMLElement $xml, Feed $feed)
|
|
|
|
{
|
|
|
|
$description = XmlParser::getXPathResult($xml, 'rss:channel/rss:description', $this->namespaces)
|
2016-04-17 19:34:54 -04:00
|
|
|
?: XmlParser::getXPathResult($xml, 'channel/description')
|
|
|
|
?: $xml->channel->description;
|
2015-07-19 11:19:26 -04:00
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setDescription(XmlParser::getValue($description));
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the feed logo url.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findFeedLogo(SimpleXMLElement $xml, Feed $feed)
|
|
|
|
{
|
|
|
|
$logo = XmlParser::getXPathResult($xml, 'rss:image/rss:url', $this->namespaces)
|
2016-04-17 19:34:54 -04:00
|
|
|
?: XmlParser::getXPathResult($xml, 'image/url');
|
2015-07-19 11:19:26 -04:00
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setLogo(XmlParser::getValue($logo));
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the feed icon.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findFeedIcon(SimpleXMLElement $xml, Feed $feed)
|
|
|
|
{
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setIcon('');
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the feed title.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findFeedTitle(SimpleXMLElement $xml, Feed $feed)
|
|
|
|
{
|
|
|
|
$title = XmlParser::getXPathResult($xml, 'rss:channel/rss:title', $this->namespaces)
|
2016-04-17 19:34:54 -04:00
|
|
|
?: XmlParser::getXPathResult($xml, 'channel/title')
|
|
|
|
?: $xml->channel->title;
|
2015-07-19 11:19:26 -04:00
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setTitle(Filter::stripWhiteSpace(XmlParser::getValue($title)) ?: $feed->getSiteUrl());
|
2014-05-20 14:20:27 -04:00
|
|
|
}
|
2013-04-04 23:34:07 -04:00
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the feed language.
|
2014-05-20 14:20:27 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function findFeedLanguage(SimpleXMLElement $xml, Feed $feed)
|
|
|
|
{
|
2015-07-19 11:19:26 -04:00
|
|
|
$language = XmlParser::getXPathResult($xml, 'rss:channel/dc:language', $this->namespaces)
|
|
|
|
?: XmlParser::getXPathResult($xml, 'channel/dc:language', $this->namespaces);
|
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setLanguage(XmlParser::getValue($language));
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the feed id.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findFeedId(SimpleXMLElement $xml, Feed $feed)
|
|
|
|
{
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setId($feed->getFeedUrl() ?: $feed->getSiteUrl());
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the feed date.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed xml
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findFeedDate(SimpleXMLElement $xml, Feed $feed)
|
|
|
|
{
|
|
|
|
$date = XmlParser::getXPathResult($xml, 'rss:channel/dc:date', $this->namespaces)
|
|
|
|
?: XmlParser::getXPathResult($xml, 'channel/dc:date', $this->namespaces);
|
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$feed->setDate($this->getDateParser()->getDateTime(XmlParser::getValue($date)));
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-07-28 21:14:51 -04:00
|
|
|
* Find the item published date.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param Item $item Item object
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
2016-07-28 21:14:51 -04:00
|
|
|
public function findItemPublishedDate(SimpleXMLElement $entry, Item $item, Feed $feed)
|
2015-07-19 11:19:26 -04:00
|
|
|
{
|
|
|
|
$date = XmlParser::getXPathResult($entry, 'dc:date', $this->namespaces);
|
|
|
|
|
2016-07-28 21:14:51 -04:00
|
|
|
$item->setPublishedDate(!empty($date) ? $this->getDateParser()->getDateTime(XmlParser::getValue($date)) : null);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find the item updated date.
|
|
|
|
*
|
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param Item $item Item object
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
|
|
|
*/
|
|
|
|
public function findItemUpdatedDate(SimpleXMLElement $entry, Item $item, Feed $feed)
|
|
|
|
{
|
|
|
|
if ($item->publishedDate === null) {
|
|
|
|
$this->findItemPublishedDate($entry, $item, $feed);
|
|
|
|
}
|
|
|
|
$item->setUpdatedDate($item->getPublishedDate()); // No updated date in RSS 1.0 specifications
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the item title.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param \PicoFeed\Parser\Item $item Item object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findItemTitle(SimpleXMLElement $entry, Item $item)
|
|
|
|
{
|
|
|
|
$title = XmlParser::getXPathResult($entry, 'rss:title', $this->namespaces)
|
2016-04-17 19:34:54 -04:00
|
|
|
?: XmlParser::getXPathResult($entry, 'title')
|
|
|
|
?: $entry->title;
|
2015-07-19 11:19:26 -04:00
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$item->setTitle(Filter::stripWhiteSpace(XmlParser::getValue($title)) ?: $item->getUrl());
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the item author.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $xml Feed
|
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param \PicoFeed\Parser\Item $item Item object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findItemAuthor(SimpleXMLElement $xml, SimpleXMLElement $entry, Item $item)
|
|
|
|
{
|
|
|
|
$author = XmlParser::getXPathResult($entry, 'dc:creator', $this->namespaces)
|
|
|
|
?: XmlParser::getXPathResult($xml, 'rss:channel/dc:creator', $this->namespaces)
|
|
|
|
?: XmlParser::getXPathResult($xml, 'channel/dc:creator', $this->namespaces);
|
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$item->setAuthor(XmlParser::getValue($author));
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the item content.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param \PicoFeed\Parser\Item $item Item object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findItemContent(SimpleXMLElement $entry, Item $item)
|
|
|
|
{
|
|
|
|
$content = XmlParser::getXPathResult($entry, 'content:encoded', $this->namespaces);
|
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
if (XmlParser::getValue($content) === '') {
|
2015-07-19 11:19:26 -04:00
|
|
|
$content = XmlParser::getXPathResult($entry, 'rss:description', $this->namespaces)
|
2016-04-17 19:34:54 -04:00
|
|
|
?: XmlParser::getXPathResult($entry, 'description')
|
|
|
|
?: $entry->description;
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$item->setContent(XmlParser::getValue($content));
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the item URL.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param \PicoFeed\Parser\Item $item Item object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findItemUrl(SimpleXMLElement $entry, Item $item)
|
|
|
|
{
|
|
|
|
$link = XmlParser::getXPathResult($entry, 'feedburner:origLink', $this->namespaces)
|
2016-04-17 19:34:54 -04:00
|
|
|
?: XmlParser::getXPathResult($entry, 'rss:link', $this->namespaces)
|
|
|
|
?: XmlParser::getXPathResult($entry, 'link')
|
|
|
|
?: $entry->link;
|
2015-07-19 11:19:26 -04:00
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$item->setUrl(XmlParser::getValue($link));
|
2014-05-20 14:20:27 -04:00
|
|
|
}
|
2013-04-04 23:34:07 -04:00
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Genereate the item id.
|
2014-05-20 14:20:27 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param \PicoFeed\Parser\Item $item Item object
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function findItemId(SimpleXMLElement $entry, Item $item, Feed $feed)
|
|
|
|
{
|
2016-04-17 19:34:54 -04:00
|
|
|
$item->setId($this->generateId(
|
2014-12-23 21:28:26 -05:00
|
|
|
$item->getTitle(), $item->getUrl(), $item->getContent()
|
2016-04-17 19:34:54 -04:00
|
|
|
));
|
2014-05-20 14:20:27 -04:00
|
|
|
}
|
2013-08-29 19:34:11 -04:00
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the item enclosure.
|
2014-05-20 14:20:27 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param \PicoFeed\Parser\Item $item Item object
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function findItemEnclosure(SimpleXMLElement $entry, Item $item, Feed $feed)
|
|
|
|
{
|
2013-04-04 23:34:07 -04:00
|
|
|
}
|
2015-07-19 11:19:26 -04:00
|
|
|
|
|
|
|
/**
|
2015-10-19 22:49:30 -04:00
|
|
|
* Find the item language.
|
2015-07-19 11:19:26 -04:00
|
|
|
*
|
2015-10-19 22:49:30 -04:00
|
|
|
* @param SimpleXMLElement $entry Feed item
|
|
|
|
* @param \PicoFeed\Parser\Item $item Item object
|
|
|
|
* @param \PicoFeed\Parser\Feed $feed Feed object
|
2015-07-19 11:19:26 -04:00
|
|
|
*/
|
|
|
|
public function findItemLanguage(SimpleXMLElement $entry, Item $item, Feed $feed)
|
|
|
|
{
|
|
|
|
$language = XmlParser::getXPathResult($entry, 'dc:language', $this->namespaces);
|
|
|
|
|
2016-04-17 19:34:54 -04:00
|
|
|
$item->setLanguage(XmlParser::getValue($language) ?: $feed->getLanguage());
|
2015-07-19 11:19:26 -04:00
|
|
|
}
|
2014-05-20 14:20:27 -04:00
|
|
|
}
|