2010-10-19 21:54:53 +00:00
|
|
|
<?php
|
2010-10-20 11:25:10 +00:00
|
|
|
|
2010-10-19 21:54:53 +00:00
|
|
|
class RSSData {
|
|
|
|
public $ERROR;
|
|
|
|
public $items;
|
|
|
|
|
2010-11-04 23:19:00 +00:00
|
|
|
/**
|
|
|
|
* Constructor, takes a DOMDocument and returns an array of parsed items.
|
2010-11-05 00:59:28 +00:00
|
|
|
* @param $xml DOMDocument: the pre-parsed XML Document
|
|
|
|
* @return Object RSSData object with a member items that is an array of parsed items,
|
2010-11-04 23:19:00 +00:00
|
|
|
*/
|
2010-11-01 16:25:04 +00:00
|
|
|
function __construct( $xml ) {
|
2010-11-01 18:29:09 +00:00
|
|
|
if ( !( $xml instanceOf DOMDocument ) ) {
|
2010-11-04 23:19:00 +00:00
|
|
|
$this->ERROR = "Not passed DOMDocument object.";
|
|
|
|
return;
|
2010-11-01 16:25:04 +00:00
|
|
|
}
|
|
|
|
$xpath = new DOMXPath( $xml );
|
2010-11-04 23:19:00 +00:00
|
|
|
$items = $xpath->query( '/rss/channel/item' );
|
2010-10-19 21:54:53 +00:00
|
|
|
|
2010-11-05 00:59:28 +00:00
|
|
|
if( $items->length !== 0 ) {
|
2010-11-04 23:19:00 +00:00
|
|
|
foreach ( $items as $item ) {
|
|
|
|
$bit = array();
|
|
|
|
foreach ( $item->childNodes as $n ) {
|
|
|
|
$name = $this->rssTokenToName( $n->nodeName );
|
|
|
|
if ( $name != null ) {
|
2010-11-05 00:59:28 +00:00
|
|
|
/**
|
|
|
|
* Because for DOMElements the nodeValue is just
|
2010-11-04 23:19:00 +00:00
|
|
|
* the text of the containing element, without any
|
|
|
|
* tags, it makes this a safe, if unattractive,
|
|
|
|
* value to use. If you want to allow people to
|
|
|
|
* mark up their RSS, some more precautions are
|
2010-11-05 00:59:28 +00:00
|
|
|
* needed.
|
|
|
|
*/
|
2010-11-04 23:19:00 +00:00
|
|
|
$bit[$name] = $n->nodeValue;
|
|
|
|
}
|
2010-10-20 11:25:10 +00:00
|
|
|
}
|
2010-11-04 23:19:00 +00:00
|
|
|
$this->items[] = $bit;
|
2010-10-19 21:54:53 +00:00
|
|
|
}
|
2010-11-04 23:19:00 +00:00
|
|
|
} else {
|
2010-11-05 00:59:28 +00:00
|
|
|
$this->ERROR = 'No RSS items found.';
|
2010-11-04 23:19:00 +00:00
|
|
|
return;
|
2010-10-19 21:54:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-11-04 23:19:00 +00:00
|
|
|
/**
|
|
|
|
* Return a string that will be used to map RSS elements that
|
|
|
|
* contain similar data (e.g. dc:date, date, and pubDate) to the
|
|
|
|
* same array key. This works on WordPress feeds as-is, but it
|
|
|
|
* probably needs a way to concert dc:date format dates to be the
|
|
|
|
* same as pubDate.
|
2010-11-05 00:59:28 +00:00
|
|
|
*
|
|
|
|
* @param $n String: name of the element we have
|
|
|
|
* @return String Name to map it to
|
2010-11-04 23:19:00 +00:00
|
|
|
*/
|
|
|
|
protected function rssTokenToName( $n ) {
|
2010-10-20 11:25:10 +00:00
|
|
|
switch( $n ) {
|
|
|
|
case 'dc:date':
|
|
|
|
return 'date';
|
2010-10-19 21:54:53 +00:00
|
|
|
# parse "2010-10-18T18:07:00Z"
|
2010-10-20 11:25:10 +00:00
|
|
|
case 'pubDate':
|
|
|
|
return 'date';
|
2010-10-19 21:54:53 +00:00
|
|
|
# parse RFC date
|
2010-10-20 11:25:10 +00:00
|
|
|
case 'dc:creator':
|
|
|
|
return 'author';
|
|
|
|
case 'title':
|
|
|
|
return 'title';
|
|
|
|
case 'content:encoded':
|
|
|
|
return 'encodedContent';
|
2010-10-19 21:54:53 +00:00
|
|
|
|
2010-10-20 11:25:10 +00:00
|
|
|
case 'slash:comments':
|
|
|
|
case 'slash:department':
|
|
|
|
case 'slash:section':
|
|
|
|
case 'slash:hit_parade':
|
|
|
|
case 'feedburner:origLink':
|
|
|
|
case 'wfw:commentRss':
|
|
|
|
case 'comments':
|
|
|
|
case 'category':
|
2010-10-19 21:54:53 +00:00
|
|
|
return null;
|
|
|
|
|
|
|
|
default:
|
|
|
|
return $n;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|