diff options
author | redmatrix <git@macgirvin.com> | 2016-03-15 17:54:06 -0700 |
---|---|---|
committer | redmatrix <git@macgirvin.com> | 2016-03-15 17:54:06 -0700 |
commit | 4188419b30ca1ceba597ad336f751f1b01d161a3 (patch) | |
tree | 6e37269e32eea2b6e0da1d7d4c8d1b0ecd7cf586 | |
parent | d98d7003edfb54c3bbe624e1feb53904f4756f0e (diff) | |
download | volse-hubzilla-4188419b30ca1ceba597ad336f751f1b01d161a3.tar.gz volse-hubzilla-4188419b30ca1ceba597ad336f751f1b01d161a3.tar.bz2 volse-hubzilla-4188419b30ca1ceba597ad336f751f1b01d161a3.zip |
more federation backend work
-rwxr-xr-x | include/items.php | 43 |
1 files changed, 39 insertions, 4 deletions
diff --git a/include/items.php b/include/items.php index d12989707..7f5932cf3 100755 --- a/include/items.php +++ b/include/items.php @@ -2156,9 +2156,6 @@ function get_atom_elements($feed, $item, &$author) { $res['target'] = $obj; } - $res['public_policy'] = 'specific'; - $res['comment_policy'] = 'none'; - $arr = array('feed' => $feed, 'item' => $item, 'result' => $res); call_hooks('parse_atom', $arr); @@ -3850,6 +3847,11 @@ function consume_feed($xml, $importer, &$contact, $pass = 0) { $author = array(); $datarray = get_atom_elements($feed,$item,$author); + if($contact['xchan_network'] === 'rss') { + $res['public_policy'] = 'specific'; + $res['comment_policy'] = 'none'; + } + if((! x($author,'author_name')) || ($author['author_is_feed'])) $author['author_name'] = $contact['xchan_name']; if((! x($author,'author_link')) || ($author['author_is_feed'])) @@ -3907,6 +3909,12 @@ function consume_feed($xml, $importer, &$contact, $pass = 0) { $author = array(); $datarray = get_atom_elements($feed,$item,$author); + if($contact['xchan_network'] === 'rss') { + $res['public_policy'] = 'specific'; + $res['comment_policy'] = 'none'; + } + + if(is_array($contact)) { if((! x($author,'author_name')) || ($author['author_is_feed'])) $author['author_name'] = $contact['xchan_name']; @@ -4060,6 +4068,33 @@ function process_salmon_feed($xml, $importer) { return $ret; } +/* + * Given an xml (atom) feed, find any links with rel="hub" and return an array of href links or false + */ + + +function find_hubs($xml) { + require_once('library/simplepie/simplepie.inc'); + + if(! strlen($xml)) { + logger('empty input'); + return false; + } + + $feed = new SimplePie(); + $feed->set_raw_data($xml); + $feed->init(); + + if($feed->error()) + logger('Error parsing XML: ' . $feed->error()); + + $hubs = $feed->get_links('hub'); + logger('consume_feed: hubs: ' . print_r($hubs,true), LOGGER_DATA); + + return $hubs; +} + + function update_feed_item($uid,$datarray) { logger('update_feed_item: not implemented! ' . $uid . ' ' . print_r($datarray,true), LOGGER_DATA); @@ -4084,8 +4119,8 @@ function handle_feed($uid,$abook_id,$url) { //logger('handle_feed:' . print_r($z,true)); if($z['success']) { - consume_feed($z['body'],$channel,$x[0],0); consume_feed($z['body'],$channel,$x[0],1); + consume_feed($z['body'],$channel,$x[0],2); } } |