require_once("include/enotify.php");
require_once("include/socgraph.php");
require_once("include/Photo.php");
+require_once("include/Scrape.php");
+require_once("include/follow.php");
define('OSTATUS_DEFAULT_POLL_INTERVAL', 30); // given in minutes
define('OSTATUS_DEFAULT_POLL_TIMEFRAME', 1440); // given in minutes
define('OSTATUS_DEFAULT_POLL_TIMEFRAME_MENTIONS', 14400); // given in minutes
+function ostatus_check_follow_friends() {
+ $r = q("SELECT `uid`,`v` FROM `pconfig` WHERE `cat`='system' AND `k`='ostatus_legacy_contact' AND `v` != ''");
+
+ if (!$r)
+ return;
+
+ foreach ($r AS $contact) {
+ ostatus_follow_friends($contact["uid"], $contact["v"]);
+ set_pconfig($contact["uid"], "system", "ostatus_legacy_contact", "");
+ }
+}
+
+// This function doesn't work reliable by now.
+function ostatus_follow_friends($uid, $url) {
+ $contact = probe_url($url);
+
+ if (!$contact)
+ return;
+
+ $api = $contact["baseurl"]."/api/";
+
+ // Fetching friends
+ $data = z_fetch_url($api."statuses/friends.json?screen_name=".$contact["nick"]);
+
+ if (!$data["success"])
+ return;
+
+ $friends = json_decode($data["body"]);
+
+ foreach ($friends AS $friend) {
+ $url = $friend->statusnet_profile_url;
+ $r = q("SELECT `url` FROM `contact` WHERE `uid` = %d AND
+ (`nurl` = '%s' OR `alias` = '%s' OR `alias` = '%s') AND
+ `network` != '%s' LIMIT 1",
+ intval($uid), dbesc(normalise_link($url)),
+ dbesc(normalise_link($url)), dbesc($url), dbesc(NETWORK_STATUSNET));
+ if (!$r) {
+ $data = probe_url($friend->statusnet_profile_url);
+ if ($data["network"] == NETWORK_OSTATUS) {
+ $result = new_contact($uid,$friend->statusnet_profile_url);
+ if ($result["success"])
+ logger($friend->name." ".$url." - success", LOGGER_DEBUG);
+ else
+ logger($friend->name." ".$url." - failed", LOGGER_DEBUG);
+ } else
+ logger($friend->name." ".$url." - not OStatus", LOGGER_DEBUG);
+ }
+ }
+}
+
function ostatus_fetchauthor($xpath, $context, $importer, &$contact, $onlyfetch) {
$author = array();
// Delete a message
if ($item["verb"] == "qvitter-delete-notice") {
// ignore "Delete" messages (by now)
+ logger("Ignore delete message ".print_r($item, true));
continue;
}
if ($item["verb"] == ACTIVITY_JOIN) {
// ignore "Join" messages
+ logger("Ignore join message ".print_r($item, true));
continue;
}
}
if ($item["verb"] == ACTIVITY_FAVORITE) {
- // ignore "Favorite" messages
+ $orig_uri = $xpath->query("activity:object/atom:id", $entry)->item(0)->nodeValue;
+ logger("Favorite ".$orig_uri." ".print_r($item, true));
+
+ $item["verb"] = ACTIVITY_LIKE;
+ $item["parent-uri"] = $orig_uri;
+ $item["gravity"] = GRAVITY_LIKE;
+ }
+
+ if ($item["verb"] == NAMESPACE_OSTATUS."/unfavorite") {
+ // Ignore "Unfavorite" message
+ logger("Ignore unfavorite message ".print_r($item, true));
continue;
}
+ // http://activitystrea.ms/schema/1.0/rsvp-yes
+ if (!in_array($item["verb"], array(ACTIVITY_POST, ACTIVITY_LIKE, ACTIVITY_SHARE)))
+ logger("Unhandled verb ".$item["verb"]." ".print_r($item, true));
+
$item["created"] = $xpath->query('atom:published/text()', $entry)->item(0)->nodeValue;
$item["edited"] = $xpath->query('atom:updated/text()', $entry)->item(0)->nodeValue;
$conversation = $xpath->query('ostatus:conversation/text()', $entry)->item(0)->nodeValue;
$conv_as = str_replace(',"statusnet:notice_info":', ',"statusnet_notice_info":', $conv_as);
$conv_as = json_decode($conv_as);
+ $no_of_items = sizeof($items);
+
if (@is_array($conv_as->items))
- $items = array_merge($items, $conv_as->items);
- else
+ foreach ($conv_as->items AS $item)
+ $items[$item->id] = $item;
+
+ if ($no_of_items == sizeof($items))
break;
$pageno++;