add support for dc:subject and slash:comments
This commit is contained in:
parent
ee78f81ccd
commit
d4992d6b48
4 changed files with 37 additions and 11 deletions
|
@ -1,9 +1,11 @@
|
||||||
<?php
|
<?php
|
||||||
class FeedItem_Atom {
|
class FeedItem_Atom {
|
||||||
private $elem;
|
private $elem;
|
||||||
|
private $xpath;
|
||||||
|
|
||||||
function __construct($elem, $doc, $xpath) {
|
function __construct($elem, $doc, $xpath) {
|
||||||
$this->elem = $elem;
|
$this->elem = $elem;
|
||||||
|
$this->xpath = $xpath;
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_id() {
|
function get_id() {
|
||||||
|
@ -63,9 +65,12 @@ class FeedItem_Atom {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// todo
|
|
||||||
function get_comments_count() {
|
function get_comments_count() {
|
||||||
|
$comments = $this->xpath->query("slash:comments", $this->elem)->item(0);
|
||||||
|
|
||||||
|
if ($comments) {
|
||||||
|
return $comments->nodeValue;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_categories() {
|
function get_categories() {
|
||||||
|
@ -77,6 +82,11 @@ class FeedItem_Atom {
|
||||||
array_push($cats, $cat->getAttribute("term"));
|
array_push($cats, $cat->getAttribute("term"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$categories = $this->xpath->query("dc:subject", $this->elem);
|
||||||
|
|
||||||
|
foreach ($categories as $cat) {
|
||||||
|
array_push($cats, $cat->nodeValue);
|
||||||
|
}
|
||||||
|
|
||||||
return $cats;
|
return $cats;
|
||||||
}
|
}
|
||||||
|
@ -100,6 +110,18 @@ class FeedItem_Atom {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$enclosures = $this->xpath->query("media:content", $this->elem);
|
||||||
|
|
||||||
|
foreach ($enclosures as $enclosure) {
|
||||||
|
$enc = new FeedEnclosure();
|
||||||
|
|
||||||
|
$enc->type = $enclosure->getAttribute("type");
|
||||||
|
$enc->link = $enclosure->getAttribute("url");
|
||||||
|
$enc->length = $enclosure->getAttribute("length");
|
||||||
|
|
||||||
|
array_push($encs, $enc);
|
||||||
|
}
|
||||||
|
|
||||||
return $encs;
|
return $encs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -63,9 +63,12 @@ class FeedItem_RSS {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// todo
|
|
||||||
function get_comments_count() {
|
function get_comments_count() {
|
||||||
|
$comments = $this->xpath->query("slash:comments", $this->elem)->item(0);
|
||||||
|
|
||||||
|
if ($comments) {
|
||||||
|
return $comments->nodeValue;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_categories() {
|
function get_categories() {
|
||||||
|
@ -76,6 +79,12 @@ class FeedItem_RSS {
|
||||||
array_push($cats, $cat->nodeValue);
|
array_push($cats, $cat->nodeValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$categories = $this->xpath->query("dc:subject", $this->elem);
|
||||||
|
|
||||||
|
foreach ($categories as $cat) {
|
||||||
|
array_push($cats, $cat->nodeValue);
|
||||||
|
}
|
||||||
|
|
||||||
return $cats;
|
return $cats;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,8 +105,6 @@ class FeedItem_RSS {
|
||||||
|
|
||||||
$enclosures = $this->xpath->query("media:content", $this->elem);
|
$enclosures = $this->xpath->query("media:content", $this->elem);
|
||||||
|
|
||||||
$encs = array();
|
|
||||||
|
|
||||||
foreach ($enclosures as $enclosure) {
|
foreach ($enclosures as $enclosure) {
|
||||||
$enc = new FeedEnclosure();
|
$enc = new FeedEnclosure();
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,9 @@ class FeedParser {
|
||||||
$xpath->registerNamespace('atom', 'http://www.w3.org/2005/Atom');
|
$xpath->registerNamespace('atom', 'http://www.w3.org/2005/Atom');
|
||||||
$xpath->registerNamespace('media', 'http://search.yahoo.com/mrss/');
|
$xpath->registerNamespace('media', 'http://search.yahoo.com/mrss/');
|
||||||
$xpath->registerNamespace('rdf', 'http://www.w3.org/1999/02/22-rdf-syntax-ns#');
|
$xpath->registerNamespace('rdf', 'http://www.w3.org/1999/02/22-rdf-syntax-ns#');
|
||||||
|
$xpath->registerNamespace('slash', 'http://purl.org/rss/1.0/modules/slash/');
|
||||||
|
$xpath->registerNamespace('dc', 'http://purl.org/dc/elements/1.1/');
|
||||||
|
|
||||||
$this->xpath = $xpath;
|
$this->xpath = $xpath;
|
||||||
|
|
||||||
$root = $xpath->query("(//atom:feed|//channel|//rdf:rdf|//rdf:RDF)")->item(0);
|
$root = $xpath->query("(//atom:feed|//channel|//rdf:rdf|//rdf:RDF)")->item(0);
|
||||||
|
|
|
@ -581,13 +581,7 @@
|
||||||
$entry_comments = db_escape_string(mb_substr(trim($entry_comments), 0, 245));
|
$entry_comments = db_escape_string(mb_substr(trim($entry_comments), 0, 245));
|
||||||
$entry_author = db_escape_string(mb_substr(trim($entry_author), 0, 245));
|
$entry_author = db_escape_string(mb_substr(trim($entry_author), 0, 245));
|
||||||
|
|
||||||
$num_comments = $item->get_comments_count();
|
$num_comments = (int) $item->get_comments_count();
|
||||||
|
|
||||||
if (is_array($num_comments) && is_array($num_comments[0])) {
|
|
||||||
$num_comments = (int) $num_comments[0]["data"];
|
|
||||||
} else {
|
|
||||||
$num_comments = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
_debug("author $entry_author", $debug_enabled);
|
_debug("author $entry_author", $debug_enabled);
|
||||||
_debug("num_comments: $num_comments", $debug_enabled);
|
_debug("num_comments: $num_comments", $debug_enabled);
|
||||||
|
|
Loading…
Reference in a new issue