2014-05-20 14:20:27 -04:00
|
|
|
<?php
|
|
|
|
|
2014-12-23 21:28:26 -05:00
|
|
|
namespace PicoFeed\Parser;
|
2014-05-20 14:20:27 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Feed Item
|
|
|
|
*
|
|
|
|
* @author Frederic Guillot
|
2014-12-23 21:28:26 -05:00
|
|
|
* @package Parser
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
class Item
|
|
|
|
{
|
2014-12-23 21:28:26 -05:00
|
|
|
/**
|
|
|
|
* List of known RTL languages
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var public
|
|
|
|
*/
|
|
|
|
public $rtl = array(
|
|
|
|
'ar', // Arabic (ar-**)
|
|
|
|
'fa', // Farsi (fa-**)
|
|
|
|
'ur', // Urdu (ur-**)
|
|
|
|
'ps', // Pashtu (ps-**)
|
|
|
|
'syr', // Syriac (syr-**)
|
|
|
|
'dv', // Divehi (dv-**)
|
|
|
|
'he', // Hebrew (he-**)
|
|
|
|
'yi', // Yiddish (yi-**)
|
|
|
|
);
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Item id
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $id = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Item title
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $title = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Item url
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $url = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Item author
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $author= '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Item date
|
|
|
|
*
|
|
|
|
* @access public
|
2015-03-01 19:56:11 +01:00
|
|
|
* @var \DateTime
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
2015-03-01 19:56:11 +01:00
|
|
|
public $date = null;
|
2014-05-20 14:20:27 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Item content
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $content = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Item enclosure url
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $enclosure_url = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Item enclusure type
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $enclosure_type = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Item language
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $language = '';
|
|
|
|
|
2015-03-25 19:59:41 -04:00
|
|
|
/**
|
|
|
|
* Raw XML
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var \SimpleXMLElement
|
|
|
|
*/
|
|
|
|
public $xml;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* List of namespaces
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
public $namespaces = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get specific XML tag or attribute value
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $tag Tag name (examples: guid, media:content)
|
|
|
|
* @param string $attribute Tag attribute
|
2015-07-19 11:19:26 -04:00
|
|
|
* @return array|false Tag values or error
|
2015-03-25 19:59:41 -04:00
|
|
|
*/
|
|
|
|
public function getTag($tag, $attribute = '')
|
|
|
|
{
|
2015-07-19 11:19:26 -04:00
|
|
|
// convert to xPath attribute query
|
|
|
|
if ($attribute !== '') {
|
|
|
|
$attribute = '/@'.$attribute;
|
2015-03-25 19:59:41 -04:00
|
|
|
}
|
|
|
|
|
2015-07-19 11:19:26 -04:00
|
|
|
// construct query
|
|
|
|
$query = './/'.$tag.$attribute;
|
|
|
|
$elements = XmlParser::getXPathResult($this->xml, $query, $this->namespaces);
|
|
|
|
|
|
|
|
if ($elements === false) { // xPath error
|
|
|
|
return false;
|
2015-03-25 19:59:41 -04:00
|
|
|
}
|
|
|
|
|
2015-07-19 11:19:26 -04:00
|
|
|
return array_map(function ($element) { return (string) $element;}, $elements);
|
2015-03-25 19:59:41 -04:00
|
|
|
}
|
|
|
|
|
2014-05-20 14:20:27 -04:00
|
|
|
/**
|
|
|
|
* Return item information
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function __toString()
|
|
|
|
{
|
|
|
|
$output = '';
|
|
|
|
|
2015-03-01 19:56:11 +01:00
|
|
|
foreach (array('id', 'title', 'url', 'language', 'author', 'enclosure_url', 'enclosure_type') as $property) {
|
2014-05-20 14:20:27 -04:00
|
|
|
$output .= 'Item::'.$property.' = '.$this->$property.PHP_EOL;
|
|
|
|
}
|
|
|
|
|
2015-03-01 19:56:11 +01:00
|
|
|
$output .= 'Item::date = '.$this->date->format(DATE_RFC822).PHP_EOL;
|
2014-12-23 21:28:26 -05:00
|
|
|
$output .= 'Item::isRTL() = '.($this->isRTL() ? 'true' : 'false').PHP_EOL;
|
2014-05-20 14:20:27 -04:00
|
|
|
$output .= 'Item::content = '.strlen($this->content).' bytes'.PHP_EOL;
|
|
|
|
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get title
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function getTitle()
|
|
|
|
{
|
|
|
|
return $this->title;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get url
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function getUrl()
|
|
|
|
{
|
|
|
|
return $this->url;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get id
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function getId()
|
|
|
|
{
|
|
|
|
return $this->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get date
|
|
|
|
*
|
|
|
|
* @access public
|
2015-07-19 11:19:26 -04:00
|
|
|
* $return \DateTime
|
2014-05-20 14:20:27 -04:00
|
|
|
*/
|
|
|
|
public function getDate()
|
|
|
|
{
|
|
|
|
return $this->date;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get content
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function getContent()
|
|
|
|
{
|
|
|
|
return $this->content;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get enclosure url
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function getEnclosureUrl()
|
|
|
|
{
|
|
|
|
return $this->enclosure_url;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get enclosure type
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function getEnclosureType()
|
|
|
|
{
|
|
|
|
return $this->enclosure_type;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get language
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function getLanguage()
|
|
|
|
{
|
|
|
|
return $this->language;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get author
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* $return string
|
|
|
|
*/
|
|
|
|
public function getAuthor()
|
|
|
|
{
|
|
|
|
return $this->author;
|
|
|
|
}
|
2014-12-23 21:28:26 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return true if the item is "Right to Left"
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isRTL()
|
|
|
|
{
|
|
|
|
return Parser::isLanguageRTL($this->language);
|
|
|
|
}
|
2014-05-20 14:20:27 -04:00
|
|
|
}
|