mirror of
https://github.com/friendica/friendica
synced 2025-01-28 00:20:04 +00:00
While storing an item, now every contact is stored in the gcontact table.
This commit is contained in:
parent
16e4e61cc5
commit
1a5a00bef8
2 changed files with 52 additions and 33 deletions
|
@ -11,6 +11,7 @@ require_once('include/text.php');
|
||||||
require_once('include/email.php');
|
require_once('include/email.php');
|
||||||
require_once('include/ostatus_conversation.php');
|
require_once('include/ostatus_conversation.php');
|
||||||
require_once('include/threads.php');
|
require_once('include/threads.php');
|
||||||
|
require_once('include/socgraph.php');
|
||||||
|
|
||||||
function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0) {
|
function get_feed_for(&$a, $dfrn_id, $owner_nick, $last_update, $direction = 0) {
|
||||||
|
|
||||||
|
@ -1343,6 +1344,12 @@ function item_store($arr,$force_parent = false, $notify = false, $dontcache = fa
|
||||||
$current_post = $r[0]['id'];
|
$current_post = $r[0]['id'];
|
||||||
logger('item_store: created item ' . $current_post);
|
logger('item_store: created item ' . $current_post);
|
||||||
|
|
||||||
|
// Add every contact to the global contact table
|
||||||
|
// Contacts from the statusnet connector are also added since you could add them in OStatus as well.
|
||||||
|
if (!$arr['private'] AND in_array($arr["network"],
|
||||||
|
array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS, NETWORK_STATUSNET, "")))
|
||||||
|
poco_check($arr["author-link"], $arr["author-name"], $arr["author-avatar"], "", $arr["received"]);
|
||||||
|
|
||||||
// Set "success_update" to the date of the last time we heard from this contact
|
// Set "success_update" to the date of the last time we heard from this contact
|
||||||
// This can be used to filter for inactive contacts and poco.
|
// This can be used to filter for inactive contacts and poco.
|
||||||
// Only do this for public postings to avoid privacy problems, since poco data is public.
|
// Only do this for public postings to avoid privacy problems, since poco data is public.
|
||||||
|
|
|
@ -98,40 +98,8 @@ function poco_load($cid,$uid = 0,$zcid = 0,$url = null) {
|
||||||
if((! $name) || (! $profile_url) || (! $profile_photo))
|
if((! $name) || (! $profile_url) || (! $profile_photo))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
$x = q("SELECT * FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
$gcid = poco_check($profile_url, $name, $profile_photo, $connect_url, $updated);
|
||||||
dbesc(normalise_link($profile_url))
|
|
||||||
);
|
|
||||||
|
|
||||||
if(count($x)) {
|
|
||||||
$gcid = $x[0]['id'];
|
|
||||||
|
|
||||||
if($x[0]['name'] != $name || $x[0]['photo'] != $profile_photo || $x[0]['updated'] < $updated) {
|
|
||||||
q("update gcontact set `name` = '%s', `photo` = '%s', `connect` = '%s', `url` = '%s', `updated` = '%s'
|
|
||||||
where `nurl` = '%s'",
|
|
||||||
dbesc($name),
|
|
||||||
dbesc($profile_photo),
|
|
||||||
dbesc($connect_url),
|
|
||||||
dbesc($profile_url),
|
|
||||||
dbesc($updated),
|
|
||||||
dbesc(normalise_link($profile_url))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
q("insert into `gcontact` (`name`,`url`,`nurl`,`photo`,`connect`, `updated`)
|
|
||||||
values ( '%s', '%s', '%s', '%s','%s') ",
|
|
||||||
dbesc($name),
|
|
||||||
dbesc($profile_url),
|
|
||||||
dbesc(normalise_link($profile_url)),
|
|
||||||
dbesc($profile_photo),
|
|
||||||
dbesc($connect_url),
|
|
||||||
dbesc($updated)
|
|
||||||
);
|
|
||||||
$x = q("SELECT * FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
|
||||||
dbesc(normalise_link($profile_url))
|
|
||||||
);
|
|
||||||
if(count($x))
|
|
||||||
$gcid = $x[0]['id'];
|
|
||||||
}
|
|
||||||
if(! $gcid)
|
if(! $gcid)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -178,6 +146,50 @@ function poco_load($cid,$uid = 0,$zcid = 0,$url = null) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function poco_check($profile_url, $name, $profile_photo, $connect_url, $updated) {
|
||||||
|
$gcid = "";
|
||||||
|
|
||||||
|
if (($profile_url == "") OR ($name == "") OR ($profile_photo == ""))
|
||||||
|
return $gcid;
|
||||||
|
|
||||||
|
logger("profile-check URL: ".$profile_url." name: ".$name." avatar: ".$profile_photo, LOGGER_DEBUG);
|
||||||
|
|
||||||
|
$x = q("SELECT * FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
||||||
|
dbesc(normalise_link($profile_url))
|
||||||
|
);
|
||||||
|
|
||||||
|
if(count($x)) {
|
||||||
|
$gcid = $x[0]['id'];
|
||||||
|
|
||||||
|
if($x[0]['name'] != $name || $x[0]['photo'] != $profile_photo || $x[0]['updated'] < $updated) {
|
||||||
|
q("update gcontact set `name` = '%s', `photo` = '%s', `connect` = '%s', `url` = '%s', `updated` = '%s'
|
||||||
|
where `nurl` = '%s'",
|
||||||
|
dbesc($name),
|
||||||
|
dbesc($profile_photo),
|
||||||
|
dbesc($connect_url),
|
||||||
|
dbesc($profile_url),
|
||||||
|
dbesc($updated),
|
||||||
|
dbesc(normalise_link($profile_url))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
q("insert into `gcontact` (`name`,`url`,`nurl`,`photo`,`connect`, `updated`)
|
||||||
|
values ('%s', '%s', '%s', '%s','%s', '%s')",
|
||||||
|
dbesc($name),
|
||||||
|
dbesc($profile_url),
|
||||||
|
dbesc(normalise_link($profile_url)),
|
||||||
|
dbesc($profile_photo),
|
||||||
|
dbesc($connect_url),
|
||||||
|
dbesc($updated)
|
||||||
|
);
|
||||||
|
$x = q("SELECT * FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
||||||
|
dbesc(normalise_link($profile_url))
|
||||||
|
);
|
||||||
|
if(count($x))
|
||||||
|
$gcid = $x[0]['id'];
|
||||||
|
}
|
||||||
|
return $gcid;
|
||||||
|
}
|
||||||
|
|
||||||
function count_common_friends($uid,$cid) {
|
function count_common_friends($uid,$cid) {
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue