Merge pull request #163 from annando/master

fbsync: Showing shared posts, import only from contacts in your contact list
This commit is contained in:
tobiasd 2013-11-11 08:59:13 -08:00
commit 6509bdcb99
3 changed files with 175 additions and 28 deletions

View File

@ -8,7 +8,6 @@
/* To-Do /* To-Do
FBSync: FBSync:
- A: Make shared posts look like shared posts
- B: Threading for incoming comments - B: Threading for incoming comments
- C: Receiving likes for comments - C: Receiving likes for comments
@ -26,14 +25,79 @@ function fbsync_install() {
register_hook('connector_settings', 'addon/fbsync/fbsync.php', 'fbsync_settings'); register_hook('connector_settings', 'addon/fbsync/fbsync.php', 'fbsync_settings');
register_hook('connector_settings_post', 'addon/fbsync/fbsync.php', 'fbsync_settings_post'); register_hook('connector_settings_post', 'addon/fbsync/fbsync.php', 'fbsync_settings_post');
register_hook('cron', 'addon/fbsync/fbsync.php', 'fbsync_cron'); register_hook('cron', 'addon/fbsync/fbsync.php', 'fbsync_cron');
register_hook('follow', 'addon/fbsync/fbsync.php', 'fbsync_follow');
} }
function fbsync_uninstall() { function fbsync_uninstall() {
unregister_hook('connector_settings', 'addon/fbsync/fbsync.php', 'fbsync_settings'); unregister_hook('connector_settings', 'addon/fbsync/fbsync.php', 'fbsync_settings');
unregister_hook('connector_settings_post', 'addon/fbsync/fbsync.php', 'fbsync_settings_post'); unregister_hook('connector_settings_post', 'addon/fbsync/fbsync.php', 'fbsync_settings_post');
unregister_hook('cron', 'addon/fbsync/fbsync.php', 'fbsync_cron'); unregister_hook('cron', 'addon/fbsync/fbsync.php', 'fbsync_cron');
unregister_hook('follow', 'addon/fbsync/fbsync.php', 'fbsync_follow');
} }
function fbsync_follow($a, &$contact) {
logger("fbsync_follow: Check if contact is facebook contact. ".$contact["url"], LOGGER_DEBUG);
if (!strstr($contact["url"], "://www.facebook.com") AND !strstr($contact["url"], "://facebook.com") AND !strstr($contact["url"], "@facebook.com"))
return;
// contact seems to be a facebook contact, so continue
$nickname = preg_replace("=https?://.*facebook.com/([\w.]*).*=ism", "$1", $contact["url"]);
$nickname = str_replace("@facebook.com", "", $nickname);
$uid = $a->user["uid"];
$access_token = get_pconfig($uid,'facebook','access_token');
$fql = array(
"profile" => "SELECT id, pic_square, url, username, name FROM profile WHERE username = '$nickname'",
"avatar" => "SELECT url FROM square_profile_pic WHERE id IN (SELECT id FROM #profile) AND size = 256");
$url = "https://graph.facebook.com/fql?q=".urlencode(json_encode($fql))."&access_token=".$access_token;
$feed = fetch_url($url);
$data = json_decode($feed);
$id = 0;
logger("fbsync_follow: Query id for nickname ".$nickname, LOGGER_DEBUG);
if (!is_array($data->data))
return;
$contactdata = new stdClass;
foreach($data->data AS $query) {
switch ($query->name) {
case "profile":
$contactdata->id = number_format($query->fql_result_set[0]->id, 0, '', '');
$contactdata->pic_square = $query->fql_result_set[0]->pic_square;
$contactdata->url = $query->fql_result_set[0]->url;
$contactdata->username = $query->fql_result_set[0]->username;
$contactdata->name = $query->fql_result_set[0]->name;
break;
case "avatar":
$contactdata->pic_square = $query->fql_result_set[0]->url;
break;
}
}
logger("fbsync_follow: Got contact for nickname ".$nickname." ".print_r($contactdata, true), LOGGER_DEBUG);
// Create contact
fbsync_fetch_contact($uid, $contactdata, true);
$r = q("SELECT name,nick,url,addr,batch,notify,poll,request,confirm,poco,photo,priority,network,alias,pubkey
FROM `contact` WHERE `uid` = %d AND `alias` = '%s'",
intval($uid),
dbesc("facebook::".$contactdata->id));
if (count($r))
$contact["contact"] = $r[0];
}
function fbsync_settings(&$a,&$s) { function fbsync_settings(&$a,&$s) {
if(! local_user()) if(! local_user())
@ -62,12 +126,12 @@ function fbsync_settings(&$a,&$s) {
$s .= '<label id="fbsync-enable-label" for="fbsync-checkbox">' . t('Import Facebook newsfeed') . '</label>'; $s .= '<label id="fbsync-enable-label" for="fbsync-checkbox">' . t('Import Facebook newsfeed') . '</label>';
$s .= '<input id="fbsync-checkbox" type="checkbox" name="fbsync" value="1" ' . $checked . '/>'; $s .= '<input id="fbsync-checkbox" type="checkbox" name="fbsync" value="1" ' . $checked . '/>';
$s .= '</div><div class="clear"></div>'; $s .= '</div><div class="clear"></div>';
/*
$s .= '<div id="fbsync-create_user-wrapper">'; $s .= '<div id="fbsync-create_user-wrapper">';
$s .= '<label id="fbsync-create_user-label" for="fbsync-create_user">' . t('Automatically create contacts') . '</label>'; $s .= '<label id="fbsync-create_user-label" for="fbsync-create_user">' . t('Automatically create contacts') . '</label>';
$s .= '<input id="fbsync-create_user" type="checkbox" name="create_user" value="1" ' . $def_checked . '/>'; $s .= '<input id="fbsync-create_user" type="checkbox" name="create_user" value="1" ' . $def_checked . '/>';
$s .= '</div><div class="clear"></div>'; $s .= '</div><div class="clear"></div>';
*/
/* provide a submit button */ /* provide a submit button */
$s .= '<div class="settings-submit-wrapper" ><input type="submit" id="fbsync-submit" name="fbsync-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>'; $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="fbsync-submit" name="fbsync-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>';
@ -78,7 +142,7 @@ function fbsync_settings_post(&$a,&$b) {
if(x($_POST,'fbsync-submit')) { if(x($_POST,'fbsync-submit')) {
set_pconfig(local_user(),'fbsync','sync',intval($_POST['fbsync'])); set_pconfig(local_user(),'fbsync','sync',intval($_POST['fbsync']));
//set_pconfig(local_user(),'fbsync','create_user',intval($_POST['create_user'])); set_pconfig(local_user(),'fbsync','create_user',intval($_POST['create_user']));
} }
} }
@ -135,22 +199,61 @@ function fbsync_createpost($a, $uid, $self, $contacts, $applications, $post, $cr
$postarray['parent-uri'] = $postarray['uri']; $postarray['parent-uri'] = $postarray['uri'];
$postarray['plink'] = $post->permalink; $postarray['plink'] = $post->permalink;
$contact_id = fbsync_fetch_contact($uid, $contacts[$post->source_id], $create_user); $postarray['author-name'] = $contacts[$post->actor_id]->name;
$postarray['author-link'] = $contacts[$post->actor_id]->url;
if ($contact_id < 0) $postarray['author-avatar'] = $contacts[$post->actor_id]->pic_square;
return;
elseif ($contact_id == 0)
$contact_id = $self[0]["id"];
$postarray['contact-id'] = $contact_id;
$postarray['owner-name'] = $contacts[$post->source_id]->name; $postarray['owner-name'] = $contacts[$post->source_id]->name;
$postarray['owner-link'] = $contacts[$post->source_id]->url; $postarray['owner-link'] = $contacts[$post->source_id]->url;
$postarray['owner-avatar'] = $contacts[$post->source_id]->pic_square; $postarray['owner-avatar'] = $contacts[$post->source_id]->pic_square;
$postarray['author-name'] = $contacts[$post->actor_id]->name; $contact_id = 0;
$postarray['author-link'] = $contacts[$post->actor_id]->url;
$postarray['author-avatar'] = $contacts[$post->actor_id]->pic_square; if (($post->parent_post_id != "") AND ($post->actor_id == $post->source_id)) {
$pos = strpos($post->parent_post_id, "_");
if ($pos != 0) {
$user_id = substr($post->parent_post_id, 0, $pos);
$userdata = fbsync_fetchuser($a, $uid, $user_id);
$contact_id = $userdata["contact-id"];
$postarray['contact-id'] = $contact_id;
if (array_key_exists("name", $userdata) AND ($userdata["name"] != "") AND !link_compare($userdata["link"], $postarray['author-link'])) {
$postarray['owner-name'] = $userdata["name"];
$postarray['owner-link'] = $userdata["link"];
$postarray['owner-avatar'] = $userdata["avatar"];
if (!intval(get_config('system','wall-to-wall_share'))) {
$prebody = "[share author='".$postarray['author-name'].
"' profile='".$postarray['author-link'].
"' avatar='".$postarray['author-avatar']."']";
$postarray['author-name'] = $postarray['owner-name'];
$postarray['author-link'] = $postarray['owner-link'];
$postarray['author-avatar'] = $postarray['owner-avatar'];
}
}
}
}
if ($contact_id == 0) {
$contact_id = fbsync_fetch_contact($uid, $contacts[$post->source_id], $create_user);
if (($contact_id <= 0) AND !$create_user) {
logger('fbsync_createpost: No matching contact found. Post not imported '.print_r($post, true), LOGGER_DEBUG);
return;
} elseif ($contact_id == 0) {
// This case should never happen
logger('fbsync_createpost: No matching contact found. Using own id. (Should never happen) '.print_r($post, true), LOGGER_DEBUG);
$contact_id = $self[0]["id"];
}
$postarray['contact-id'] = $contact_id;
}
$postarray["body"] = (isset($post->message) ? escape_tags($post->message) : ''); $postarray["body"] = (isset($post->message) ? escape_tags($post->message) : '');
@ -206,6 +309,9 @@ function fbsync_createpost($a, $uid, $self, $contacts, $applications, $post, $cr
if (trim($postarray["body"]) == "") if (trim($postarray["body"]) == "")
return; return;
if ($prebody != "")
$postarray["body"] = $prebody.$postarray["body"]."[/share]";
$postarray['created'] = datetime_convert('UTC','UTC',date("c", $post->created_time)); $postarray['created'] = datetime_convert('UTC','UTC',date("c", $post->created_time));
$postarray['edited'] = datetime_convert('UTC','UTC',date("c", $post->updated_time)); $postarray['edited'] = datetime_convert('UTC','UTC',date("c", $post->updated_time));
@ -227,7 +333,9 @@ function fbsync_createpost($a, $uid, $self, $contacts, $applications, $post, $cr
//$types = array(46, 80, 237, 247, 308); //$types = array(46, 80, 237, 247, 308);
//if (!in_array($post->type, $types)) //if (!in_array($post->type, $types))
// $postarray["body"] = "Type: ".$post->type."\n".$postarray["body"]; // $postarray["body"] = "Type: ".$post->type."\n".$postarray["body"];
//print_r($post);
//print_r($postarray); //print_r($postarray);
$item = item_store($postarray); $item = item_store($postarray);
logger('fbsync_createpost: User '.$self[0]["nick"].' posted feed item '.$item, LOGGER_DEBUG); logger('fbsync_createpost: User '.$self[0]["nick"].' posted feed item '.$item, LOGGER_DEBUG);
} }
@ -638,13 +746,52 @@ function fbsync_convertmsg($a, $body) {
} }
function fbsync_fetchuser($a, $uid, $id) {
$access_token = get_pconfig($uid,'facebook','access_token');
$self_id = get_pconfig($uid,'fbsync','self_id');
$user = array();
$contact = q("SELECT `id`, `name`, `url`, `photo` FROM `contact` WHERE `uid` = %d AND `alias` = '%s' LIMIT 1",
intval($uid), dbesc("facebook::".$id));
if (count($contact)) {
$user["contact-id"] = $contact[0]["id"];
$user["name"] = $contact[0]["name"];
$user["link"] = $contact[0]["url"];
$user["avatar"] = $contact[0]["photo"];
return($user);
}
$own_contact = q("SELECT `id` FROM `contact` WHERE `uid` = %d AND `alias` = '%s' LIMIT 1",
intval($uid), dbesc("facebook::".$self_id));
if (!count($own_contact))
return($user);
$fql = "SELECT name, url, pic_square FROM profile WHERE id = ".$id;
$url = "https://graph.facebook.com/fql?q=".urlencode($fql)."&access_token=".$access_token;
$feed = fetch_url($url);
$data = json_decode($feed);
if (is_array($data->data)) {
$user["contact-id"] = $own_contact[0]["id"];
$user["name"] = $data->data[0]->name;
$user["link"] = $data->data[0]->url;
$user["avatar"] = $data->data[0]->pic_square;
}
return($user);
}
function fbsync_fetchfeed($a, $uid) { function fbsync_fetchfeed($a, $uid) {
$access_token = get_pconfig($uid,'facebook','access_token'); $access_token = get_pconfig($uid,'facebook','access_token');
$last_updated = get_pconfig($uid,'fbsync','last_updated'); $last_updated = get_pconfig($uid,'fbsync','last_updated');
$self_id = get_pconfig($uid,'fbsync','self_id'); $self_id = get_pconfig($uid,'fbsync','self_id');
//$create_user = get_pconfig($uid, 'fbsybc', 'create_user'); $create_user = get_pconfig($uid, 'fbsync', 'create_user');
$create_user = true;
$do_likes = get_config('fbsync', 'do_likes'); $do_likes = get_config('fbsync', 'do_likes');
$self = q("SELECT * FROM `contact` WHERE `self` = 1 AND `uid` = %d LIMIT 1", $self = q("SELECT * FROM `contact` WHERE `self` = 1 AND `uid` = %d LIMIT 1",
@ -764,10 +911,6 @@ function fbsync_fetchfeed($a, $uid) {
if ($post->updated_time > $last_updated) if ($post->updated_time > $last_updated)
$last_updated = $post->updated_time; $last_updated = $post->updated_time;
//print_r($post);
// parent_post_id - Erkennen von geteilten Posts?
fbsync_createpost($a, $uid, $self, $contacts, $application_data, $post, $create_user); fbsync_createpost($a, $uid, $self, $contacts, $application_data, $post, $create_user);
} }
@ -779,10 +922,8 @@ function fbsync_fetchfeed($a, $uid) {
$like->user_id = number_format($like->user_id, 0, '', ''); $like->user_id = number_format($like->user_id, 0, '', '');
fbsync_createlike($a, $uid, $self_id, $self, $contacts, $like); fbsync_createlike($a, $uid, $self_id, $self, $contacts, $like);
} }
set_pconfig($uid,'fbsync','last_updated', $last_updated); set_pconfig($uid,'fbsync','last_updated', $last_updated);
} }
?> ?>

View File

@ -10,15 +10,19 @@
define('FROMGPLUS_DEFAULT_POLL_INTERVAL', 30); // given in minutes define('FROMGPLUS_DEFAULT_POLL_INTERVAL', 30); // given in minutes
function fromgplus_install() { function fromgplus_install() {
register_hook('plugin_settings', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings'); register_hook('connector_settings', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings');
register_hook('plugin_settings_post', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings_post'); register_hook('connector_settings_post', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings_post');
register_hook('cron', 'addon/fromgplus/fromgplus.php', 'fromgplus_cron'); register_hook('cron', 'addon/fromgplus/fromgplus.php', 'fromgplus_cron');
} }
function fromgplus_uninstall() { function fromgplus_uninstall() {
unregister_hook('connector_settings', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings');
unregister_hook('connector_settings_post', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings_post');
unregister_hook('cron', 'addon/fromgplus/fromgplus.php', 'fromgplus_cron');
// Old hooks
unregister_hook('plugin_settings', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings'); unregister_hook('plugin_settings', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings');
unregister_hook('plugin_settings_post', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings_post'); unregister_hook('plugin_settings_post', 'addon/fromgplus/fromgplus.php', 'fromgplus_addon_settings_post');
unregister_hook('cron', 'addon/fromgplus/fromgplus.php', 'fromgplus_cron');
} }
function fromgplus_addon_settings(&$a,&$s) { function fromgplus_addon_settings(&$a,&$s) {

View File

@ -84,6 +84,7 @@ function twitter_uninstall() {
unregister_hook('jot_networks', 'addon/twitter/twitter.php', 'twitter_jot_nets'); unregister_hook('jot_networks', 'addon/twitter/twitter.php', 'twitter_jot_nets');
unregister_hook('cron', 'addon/twitter/twitter.php', 'twitter_cron'); unregister_hook('cron', 'addon/twitter/twitter.php', 'twitter_cron');
unregister_hook('queue_predeliver', 'addon/twitter/twitter.php', 'twitter_queue_hook'); unregister_hook('queue_predeliver', 'addon/twitter/twitter.php', 'twitter_queue_hook');
unregister_hook('follow', 'addon/twitter/twitter.php', 'twitter_follow');
// old setting - remove only // old setting - remove only
unregister_hook('post_local_end', 'addon/twitter/twitter.php', 'twitter_post_hook'); unregister_hook('post_local_end', 'addon/twitter/twitter.php', 'twitter_post_hook');
@ -1411,7 +1412,8 @@ function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing
$postarray['tag'] = $converted["tags"]; $postarray['tag'] = $converted["tags"];
if (!intval(get_config('system','wall-to-wall_share'))) { // Deactivated at the moment, since there are problems with answers to retweets
if (false AND !intval(get_config('system','wall-to-wall_share'))) {
$postarray['body'] = "[share author='".$post->retweeted_status->user->name. $postarray['body'] = "[share author='".$post->retweeted_status->user->name.
"' profile='https://twitter.com/".$post->retweeted_status->user->screen_name. "' profile='https://twitter.com/".$post->retweeted_status->user->screen_name.
"' avatar='".$post->retweeted_status->user->profile_image_url_https. "' avatar='".$post->retweeted_status->user->profile_image_url_https.
@ -1783,7 +1785,7 @@ function twitter_convertmsg($a, $body, $no_tags = false) {
} }
} }
if (($footerlink != "") AND ($footer != "")) { if (($footerlink != "") AND (trim($footer) != "")) {
$removedlink = trim(str_replace($footerlink, "", $body)); $removedlink = trim(str_replace($footerlink, "", $body));
if (strstr($body, $removedlink)) if (strstr($body, $removedlink))